From 2c17b3897d72fb94a8cec0be6d50f606860472ed Mon Sep 17 00:00:00 2001 From: Alexander Peskov Date: Tue, 1 Dec 2020 11:00:58 +0300 Subject: [PATCH] Restore compilaltion with tbb 2017u7 (#3007) * Restore compilaltion with tbb 2017u7 Signed-off-by: Alexander Peskov * Fix unsupported arg for tbb deterministic_reduce Signed-off-by: Alexander Peskov Co-authored-by: Alexander Zhogov --- inference-engine/cmake/ie_parallel.cmake | 1 + inference-engine/include/ie_parallel.hpp | 15 ++++++++++++--- .../functional/inference_engine/CMakeLists.txt | 7 +++++++ 3 files changed, 20 insertions(+), 3 deletions(-) diff --git a/inference-engine/cmake/ie_parallel.cmake b/inference-engine/cmake/ie_parallel.cmake index de39ac7cfb4743..f8988aa1057634 100644 --- a/inference-engine/cmake/ie_parallel.cmake +++ b/inference-engine/cmake/ie_parallel.cmake @@ -7,6 +7,7 @@ function(set_ie_threading_interface_for TARGET_NAME) find_package(TBB COMPONENTS tbb tbbmalloc) set("TBB_FOUND" ${TBB_FOUND} PARENT_SCOPE) set("TBB_IMPORTED_TARGETS" ${TBB_IMPORTED_TARGETS} PARENT_SCOPE) + set("TBB_VERSION" ${TBB_VERSION} PARENT_SCOPE) if (TBB_FOUND) if (TBB_VERSION VERSION_LESS 2020) ext_message(WARNING "TBB version is less than OpenVINO recommends to use.\ diff --git a/inference-engine/include/ie_parallel.hpp b/inference-engine/include/ie_parallel.hpp index 67286f3e165efb..bc33c92e01266a 100644 --- a/inference-engine/include/ie_parallel.hpp +++ b/inference-engine/include/ie_parallel.hpp @@ -58,6 +58,15 @@ inline int parallel_get_env_threads() { } #if IE_THREAD == IE_THREAD_TBB #define PARTITIONING , tbb::static_partitioner() + +// The TBB version less than 2018u1 has no static_partitioner argument for +// tbb::parallel_deterministic_reduce. So will fallback to non deterministic version. +#if (TBB_INTERFACE_VERSION >= 10001) +#define _TBB_REDUCE_FUNC tbb::parallel_deterministic_reduce +#else +#define _TBB_REDUCE_FUNC tbb::parallel_reduce +#endif + #else #define PARTITIONING #endif @@ -186,7 +195,7 @@ void parallel_sort(I begin, I end, const F& comparator) { template R parallel_sum(const T0& D0, const R& input, const F& func) { #if (IE_THREAD == IE_THREAD_TBB || IE_THREAD == IE_THREAD_TBB_AUTO) - return tbb::parallel_deterministic_reduce( + return _TBB_REDUCE_FUNC( tbb::blocked_range(0, D0), input, [&](const tbb::blocked_range& r, R init) -> R { R sum = init; @@ -218,7 +227,7 @@ R parallel_sum(const T0& D0, const R& input, const F& func) { template R parallel_sum2d(const T0& D0, const T1& D1, const R& input, const F& func) { #if (IE_THREAD == IE_THREAD_TBB || IE_THREAD == IE_THREAD_TBB_AUTO) - return tbb::parallel_deterministic_reduce( + return _TBB_REDUCE_FUNC( tbb::blocked_range2d(0, D0, 0, D1), input, [&](const tbb::blocked_range2d& r, R init) -> R { R sum = init; @@ -257,7 +266,7 @@ R parallel_sum2d(const T0& D0, const T1& D1, const R& input, const F& func) { template R parallel_sum3d(const T0& D0, const T1& D1, const T2& D2, const R& input, const F& func) { #if (IE_THREAD == IE_THREAD_TBB || IE_THREAD == IE_THREAD_TBB_AUTO) - return tbb::parallel_deterministic_reduce( + return _TBB_REDUCE_FUNC( tbb::blocked_range3d(0, D0, 0, D1, 0, D2), input, [&](const tbb::blocked_range3d& r, R init) -> R { R sum = init; diff --git a/inference-engine/tests/functional/inference_engine/CMakeLists.txt b/inference-engine/tests/functional/inference_engine/CMakeLists.txt index 4664302c1fe91f..e7b461791729c9 100644 --- a/inference-engine/tests/functional/inference_engine/CMakeLists.txt +++ b/inference-engine/tests/functional/inference_engine/CMakeLists.txt @@ -152,6 +152,13 @@ function(ie_headers_compilation_with_custom_flags) # To include TBB headers as system set_ie_threading_interface_for(${target_name}) + # To avoid further TBB find_package action in next call of this function. Some version of TBB + # has an issue with cmake config which lead to fail in case of multiple call of find_package + # from one cmake script file. + set("TBB_FOUND" ${TBB_FOUND} PARENT_SCOPE) + set("TBB_IMPORTED_TARGETS" ${TBB_IMPORTED_TARGETS} PARENT_SCOPE) + set("TBB_VERSION" ${TBB_VERSION} PARENT_SCOPE) + set_target_properties(${target_name} PROPERTIES CXX_STANDARD ${IE_TEST_CXX_STANDARD} CXX_STANDARD_REQUIRED OFF)