| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186 | // Copyright 2009-2021 Intel Corporation// SPDX-License-Identifier: Apache-2.0#pragma once#include "../tasking/taskscheduler.h"#include "../sys/array.h"#include "../math/math.h"#include "../math/range.h"namespace embree{  /* parallel_for without range */  template<typename Index, typename Func>    __forceinline void parallel_for( const Index N, const Func& func)  {#if defined(TASKING_INTERNAL)    if (N) {      TaskScheduler::spawn(Index(0),N,Index(1),[&] (const range<Index>& r) {          assert(r.size() == 1);          func(r.begin());        });      if (!TaskScheduler::wait())        // -- GODOT start --        // throw std::runtime_error("task cancelled");        abort();        // -- GODOT end --    }    #elif defined(TASKING_TBB)  #if TBB_INTERFACE_VERSION >= 12002    tbb::task_group_context context;    tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {        func(i);      },context);    if (context.is_group_execution_cancelled())      // -- GODOT start --      // throw std::runtime_error("task cancelled");      abort();      // -- GODOT end --  #else    tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {        func(i);      });    if (tbb::task::self().is_cancelled())      // -- GODOT start --      // throw std::runtime_error("task cancelled");      abort();      // -- GODOT end --  #endif#elif defined(TASKING_PPL)    concurrency::parallel_for(Index(0),N,Index(1),[&](Index i) {         func(i);      });#else#  error "no tasking system enabled"#endif  }    /* parallel for with range and granulatity */  template<typename Index, typename Func>    __forceinline void parallel_for( const Index first, const Index last, const Index minStepSize, const Func& func)  {    assert(first <= last);#if defined(TASKING_INTERNAL)    TaskScheduler::spawn(first,last,minStepSize,func);    if (!TaskScheduler::wait())      // -- GODOT start --      // throw std::runtime_error("task cancelled");      abort();      // -- GODOT end --#elif defined(TASKING_TBB)  #if TBB_INTERFACE_VERSION >= 12002    tbb::task_group_context context;    tbb::parallel_for(tbb::blocked_range<Index>(first,last,minStepSize),[&](const tbb::blocked_range<Index>& r) {        func(range<Index>(r.begin(),r.end()));      },context);    if (context.is_group_execution_cancelled())      // -- GODOT start --      // throw std::runtime_error("task cancelled");      abort();      // -- GODOT end --  #else    tbb::parallel_for(tbb::blocked_range<Index>(first,last,minStepSize),[&](const tbb::blocked_range<Index>& r) {        func(range<Index>(r.begin(),r.end()));      });    if (tbb::task::self().is_cancelled())      // -- GODOT start --      // throw std::runtime_error("task cancelled");      abort();      // -- GODOT end --  #endif#elif defined(TASKING_PPL)    concurrency::parallel_for(first, last, Index(1) /*minStepSize*/, [&](Index i) {         func(range<Index>(i,i+1));       });#else#  error "no tasking system enabled"#endif  }    /* parallel for with range */  template<typename Index, typename Func>    __forceinline void parallel_for( const Index first, const Index last, const Func& func)  {    assert(first <= last);    parallel_for(first,last,(Index)1,func);  }#if defined(TASKING_TBB) && (TBB_INTERFACE_VERSION > 4001)  template<typename Index, typename Func>    __forceinline void parallel_for_static( const Index N, const Func& func)  {    #if TBB_INTERFACE_VERSION >= 12002      tbb::task_group_context context;      tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {          func(i);        },tbb::simple_partitioner(),context);      if (context.is_group_execution_cancelled())        // -- GODOT start --        // throw std::runtime_error("task cancelled");        abort();        // -- GODOT end --    #else      tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {          func(i);        },tbb::simple_partitioner());      if (tbb::task::self().is_cancelled())        // -- GODOT start --        // throw std::runtime_error("task cancelled");        abort();        // -- GODOT end --    #endif  }  typedef tbb::affinity_partitioner affinity_partitioner;  template<typename Index, typename Func>    __forceinline void parallel_for_affinity( const Index N, const Func& func, tbb::affinity_partitioner& ap)  {    #if TBB_INTERFACE_VERSION >= 12002      tbb::task_group_context context;      tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {          func(i);        },ap,context);      if (context.is_group_execution_cancelled())        // -- GODOT start --        // throw std::runtime_error("task cancelled");        abort();        // -- GODOT end --    #else      tbb::parallel_for(Index(0),N,Index(1),[&](Index i) {          func(i);        },ap);      if (tbb::task::self().is_cancelled())        // -- GODOT start --        // throw std::runtime_error("task cancelled");        abort();        // -- GODOT end --    #endif  }#else  template<typename Index, typename Func>    __forceinline void parallel_for_static( const Index N, const Func& func)   {    parallel_for(N,func);  }  struct affinity_partitioner {  };  template<typename Index, typename Func>    __forceinline void parallel_for_affinity( const Index N, const Func& func, affinity_partitioner& ap)   {    parallel_for(N,func);  }#endif}
 |