// ======================================================================== // // Copyright 2009-2017 Intel Corporation // // // // Licensed under the Apache License, Version 2.0 (the "License"); // // you may not use this file except in compliance with the License. // // You may obtain a copy of the License at // // // // http://www.apache.org/licenses/LICENSE-2.0 // // // // Unless required by applicable law or agreed to in writing, software // // distributed under the License is distributed on an "AS IS" BASIS, // // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // // See the License for the specific language governing permissions and // // limitations under the License. // // ======================================================================== // #include "taskschedulerppl.h" namespace embree { static bool g_ppl_threads_initialized = false; void TaskScheduler::create(size_t numThreads, bool set_affinity, bool start_threads) { assert(numThreads); /* first terminate threads in case we configured them */ if (g_ppl_threads_initialized) { g_ppl_threads_initialized = false; } /* now either keep default settings or configure number of threads */ if (numThreads == std::numeric_limits::max()) { g_ppl_threads_initialized = false; numThreads = threadCount(); } else { g_ppl_threads_initialized = true; try { concurrency::Scheduler::SetDefaultSchedulerPolicy(concurrency::SchedulerPolicy(2, concurrency::MinConcurrency, numThreads, concurrency::MaxConcurrency, numThreads)); } catch(concurrency::default_scheduler_exists &) { } } } void TaskScheduler::destroy() { if (g_ppl_threads_initialized) { g_ppl_threads_initialized = false; } } }