parallel_phase Interface for Task Arena#
Note
To enable this feature, set TBB_PREVIEW_PARALLEL_PHASE macro to 1.
Description#
This feature extends the tbb::task_arena specification with the following API:
Adds the
leave_policyenumeration class totask_arena.Adds
leave_policyas the last parameter intask_arenaconstructors andtask_arena::initializemethods. This allows you to inform the scheduler about the preferred policy for worker threads when they are about to leave task_arena due to a lack of available work.Adds new
start_parallel_phaseandend_parallel_phaseinterfaces to thetask_arenaclass and thethis_task_arenanamespace. These interfaces work as hints to the scheduler to mark the start and end of parallel work submission into the arena, enabling different worker thread retention policies.Adds the Resource Acquisition is Initialization (RAII) class
scoped_parallel_phasetotask_arena.
More details about motivation, semantics and conditions for becoming fully supported functionality can be found in the corresponding Request For Comments document for parallel_phase.
API#
Header#
#define TBB_PREVIEW_PARALLEL_PHASE 1
#include <oneapi/tbb/task_arena.h>
Synopsis#
namespace oneapi {
namespace tbb {
class task_arena {
public:
enum class leave_policy : /* unspecified type */ {
automatic = /* unspecifed */,
fast = /* unspecifed */,
};
task_arena(int max_concurrency = automatic, unsigned reserved_for_masters = 1,
priority a_priority = priority::normal,
leave_policy a_leave_policy = leave_policy::automatic);
task_arena(const constraints& constraints_, unsigned reserved_for_masters = 1,
priority a_priority = priority::normal,
leave_policy a_leave_policy = leave_policy::automatic);
void initialize(int max_concurrency, unsigned reserved_for_masters = 1,
priority a_priority = priority::normal,
leave_policy a_leave_policy = leave_policy::automatic);
void initialize(constraints a_constraints, unsigned reserved_for_masters = 1,
priority a_priority = priority::normal,
leave_policy a_leave_policy = leave_policy::automatic);
void start_parallel_phase();
void end_parallel_phase(bool with_fast_leave = false);
class scoped_parallel_phase {
public:
scoped_parallel_phase(task_arena& ta, bool with_fast_leave = false);
};
}; // class task_arena
namespace this_task_arena {
void start_parallel_phase();
void end_parallel_phase(bool with_fast_leave = false);
} // namespace this_task_arena
} // namespace tbb
} // namespace oneapi
Member Types#
-
enum leave_policy::automatic#
When passed to a constructor or the initialize method, the initialized task_arena has
the default (possibly system specific) policy for how quickly worker threads leave the arena
when there is no more work available in the arena and when the arena is not in a parallel phase.
Note
Worker threads in task_arena might be retained based on internal heuristics.
-
enum leave_policy::fast#
When passed to a constructor or the initialize method, the initialized task_arena
has policy that allows worker threads to more quickly leave the arena when there is no more work
available in the arena and when the arena is not in a parallel phase.
-
class scoped_parallel_phase#
The RAII class to map a parallel phase to a code scope.
-
scoped_parallel_phase::scoped_parallel_phase(task_arena &ta, bool with_fast_leave = false)#
Constructs a scoped_parallel_phase object that starts a parallel phase in the specified task_arena.
If with_fast_leave is true, the worker threads leave policy is temporarily set to fast.
Note
For task_arena initialized with leave_policy::fast, with_fast_leave setting has no effect.
Note
When worker threads enter the arena with no active parallel phases, the leave policy is reset to the value set during the initialization of the arena.
Member Functions#
-
task_arena(const task_arena&)#
Copies settings from task_arena instance including the leave_policy.
-
void start_parallel_phase()#
Indicates a point from where the scheduler can use a hint to keep threads in the arena for longer.
Note
This function can also be a warm-up hint for the scheduler. It allows the scheduler to wake up worker threads in advance.
-
void end_parallel_phase(bool with_fast_leave = false)#
Indicates the point when the scheduler may drop a hint and no longer retain threads in the arena.
If with_fast_leave is true, worker threads leave policy is temporarily set to fast.
Note
For task_arena initialized with leave_policy::fast, with_fast_leave setting has no effect.
Note
When worker threads enter the arena with no active parallel phases, the leave policy is reset to the value set during the initialization of the arena.
Functions#
-
void this_task_arena::start_parallel_phase()#
Indicates the start of the parallel phase in the current task_arena.
-
void this_task_arena::end_parallel_phase(bool with_fast_leave = false)#
Indicates the end of the parallel phase in the current task_arena.
If with_fast_leave is true, worker threads leave policy is temporarily set to fast.
Example#
In this example, task_arena is created with leave_policy::fast. It means that
worker threads are not expected to remain in task_arena once parallel work is completed.
However, the workflow includes a sequence of parallel work (initializing and sorting data) interceded by serial work (prefix sum).
To hint the start and end of parallel work, scoped_parallel_phase is used. This provides a hint to the scheduler
that worker threads might need to remain in task_arena since there is more parallel work to come.