2021-05-20 10:49:33 +00:00
|
|
|
// Copyright 2009-2021 Intel Corporation
|
2021-04-20 16:38:09 +00:00
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "../sys/platform.h"
|
|
|
|
#include "../sys/alloc.h"
|
|
|
|
#include "../sys/barrier.h"
|
|
|
|
#include "../sys/thread.h"
|
|
|
|
#include "../sys/mutex.h"
|
|
|
|
#include "../sys/condition.h"
|
|
|
|
#include "../sys/ref.h"
|
|
|
|
|
2022-11-24 14:45:59 +00:00
|
|
|
#if defined(__WIN32__) && !defined(NOMINMAX)
|
2021-04-20 16:38:09 +00:00
|
|
|
# define NOMINMAX
|
|
|
|
#endif
|
|
|
|
|
2024-02-24 11:40:55 +00:00
|
|
|
#if defined(__INTEL_LLVM_COMPILER)
|
|
|
|
// prevents "'__thiscall' calling convention is not supported for this target" warning from TBB
|
|
|
|
#pragma clang diagnostic push
|
|
|
|
#pragma clang diagnostic ignored "-Wignored-attributes"
|
|
|
|
#endif
|
|
|
|
|
2021-04-20 16:38:09 +00:00
|
|
|
// We need to define these to avoid implicit linkage against
|
|
|
|
// tbb_debug.lib under Windows. When removing these lines debug build
|
|
|
|
// under Windows fails.
|
|
|
|
#define __TBB_NO_IMPLICIT_LINKAGE 1
|
|
|
|
#define __TBBMALLOC_NO_IMPLICIT_LINKAGE 1
|
|
|
|
#define TBB_SUPPRESS_DEPRECATED_MESSAGES 1
|
|
|
|
#define TBB_PREVIEW_ISOLATED_TASK_GROUP 1
|
|
|
|
#include "tbb/tbb.h"
|
|
|
|
#include "tbb/parallel_sort.h"
|
|
|
|
|
2024-02-24 11:40:55 +00:00
|
|
|
#if defined(TASKING_TBB) && (TBB_INTERFACE_VERSION_MAJOR >= 8)
|
|
|
|
# define USE_TASK_ARENA 1
|
|
|
|
#else
|
|
|
|
# define USE_TASK_ARENA 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(TASKING_TBB) && (TBB_INTERFACE_VERSION >= 11009) // TBB 2019 Update 9
|
|
|
|
# define TASKING_TBB_USE_TASK_ISOLATION 1
|
|
|
|
#else
|
|
|
|
# define TASKING_TBB_USE_TASK_ISOLATION 0
|
|
|
|
#endif
|
|
|
|
|
2021-04-20 16:38:09 +00:00
|
|
|
namespace embree
|
|
|
|
{
|
|
|
|
struct TaskScheduler
|
|
|
|
{
|
|
|
|
/*! initializes the task scheduler */
|
|
|
|
static void create(size_t numThreads, bool set_affinity, bool start_threads);
|
|
|
|
|
|
|
|
/*! destroys the task scheduler again */
|
|
|
|
static void destroy();
|
|
|
|
|
|
|
|
/* returns the ID of the current thread */
|
|
|
|
static __forceinline size_t threadID()
|
|
|
|
{
|
|
|
|
return threadIndex();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* returns the index (0..threadCount-1) of the current thread */
|
|
|
|
static __forceinline size_t threadIndex()
|
|
|
|
{
|
|
|
|
#if TBB_INTERFACE_VERSION >= 9100
|
|
|
|
return tbb::this_task_arena::current_thread_index();
|
|
|
|
#elif TBB_INTERFACE_VERSION >= 9000
|
|
|
|
return tbb::task_arena::current_thread_index();
|
|
|
|
#else
|
|
|
|
return 0;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
/* returns the total number of threads */
|
|
|
|
static __forceinline size_t threadCount() {
|
|
|
|
#if TBB_INTERFACE_VERSION >= 9100
|
|
|
|
return tbb::this_task_arena::max_concurrency();
|
|
|
|
#else
|
|
|
|
return tbb::task_scheduler_init::default_num_threads();
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
2024-02-24 11:40:55 +00:00
|
|
|
|
|
|
|
#if defined(__INTEL_LLVM_COMPILER)
|
|
|
|
#pragma clang diagnostic pop
|
|
|
|
#endif
|