| 
									
										
										
										
											2021-05-20 12:49:33 +02:00
										 |  |  | // Copyright 2009-2021 Intel Corporation
 | 
					
						
							| 
									
										
										
										
											2021-04-20 18:38:09 +02: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 11:45:59 -03:00
										 |  |  | #if defined(__WIN32__) && !defined(NOMINMAX)
 | 
					
						
							| 
									
										
										
										
											2021-04-20 18:38:09 +02:00
										 |  |  | #  define NOMINMAX
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-02-24 12:40:55 +01: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 18:38:09 +02: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 12:40:55 +01: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 18:38:09 +02: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 12:40:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #if defined(__INTEL_LLVM_COMPILER)
 | 
					
						
							|  |  |  | #pragma clang diagnostic pop
 | 
					
						
							|  |  |  | #endif
 |