modularized_scheduler.doxy 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465
  1. /*
  2. * This file is part of the StarPU Handbook.
  3. * Copyright (C) 2013 Simon Archipoff
  4. * Copyright (C) 2009--2011 Universit@'e de Bordeaux
  5. * Copyright (C) 2014, 2015, 2016, 2017 CNRS
  6. * Copyright (C) 2013, 2014 INRIA
  7. * See the file version.doxy for copying conditions.
  8. */
  9. /*! \defgroup API_Modularized_Scheduler Modularized Scheduler Interface
  10. \enum starpu_sched_component_properties
  11. \ingroup API_Modularized_Scheduler
  12. flags for starpu_sched_component::properties
  13. \var starpu_sched_component_properties::STARPU_SCHED_COMPONENT_HOMOGENEOUS
  14. indicate that all workers have the same starpu_worker_archtype
  15. \var starpu_sched_component_properties::STARPU_SCHED_COMPONENT_SINGLE_MEMORY_NODE
  16. indicate that all workers have the same memory component
  17. \def STARPU_SCHED_COMPONENT_IS_HOMOGENEOUS
  18. \ingroup API_Modularized_Scheduler
  19. indicate if component is homogeneous
  20. \def STARPU_SCHED_COMPONENT_IS_SINGLE_MEMORY_NODE
  21. \ingroup API_Modularized_Scheduler
  22. indicate if all workers have the same memory component
  23. \struct starpu_sched_component
  24. \ingroup API_Modularized_Scheduler
  25. This structure represent a scheduler module. A scheduler is a
  26. tree-like structure of them, some parts of scheduler can be shared by
  27. several contexes to perform some local optimisations, so, for all
  28. components, a list of parent is defined by \c sched_ctx_id. They
  29. embed there specialised method in a pseudo object-style, so calls are
  30. like <c>component->push_task(component,task)</c>
  31. \var struct starpu_sched_tree *starpu_sched_component::tree
  32. The tree containing the component
  33. \var struct starpu_bitmap *starpu_sched_component::workers
  34. this member contain the set of underlying workers
  35. \var starpu_sched_component::workers_in_ctx
  36. this member contain the subset of starpu_sched_component::workers that is currently available in the context
  37. The push method should take this member into account.
  38. this member is set with :
  39. component->workers UNION tree->workers UNION
  40. component->child[i]->workers_in_ctx iff exist x such as component->children[i]->parents[x] == component
  41. \var void *starpu_sched_component::data
  42. private data
  43. \var int starpu_sched_component::nchildren
  44. the number of compoments's children
  45. \var struct starpu_sched_component **starpu_sched_component::children
  46. the vector of component's children
  47. \var int starpu_sched_component::nparents
  48. the numbers of component's parents
  49. \var struct starpu_sched_component **starpu_sched_component::parents
  50. the vector of component's parents
  51. \var void(*starpu_sched_component::add_child)(struct starpu_sched_component *component, struct starpu_sched_component *child)
  52. add a child to component
  53. \var void(*starpu_sched_component::remove_child)(struct starpu_sched_component *component, struct starpu_sched_component *child)
  54. remove a child from component
  55. \var void(*starpu_sched_component::add_parent)(struct starpu_sched_component *component, struct starpu_sched_component *parent)
  56. todo
  57. \var void(*starpu_sched_component::remove_parent)(struct starpu_sched_component *component, struct starpu_sched_component *parent)
  58. todo
  59. \var int (*starpu_sched_component::push_task)(struct starpu_sched_component *, struct starpu_task *)
  60. push a task in the scheduler module. this function is called to
  61. push a task on component subtree, this can either perform a
  62. recursive call on a child or store the task in the component,
  63. then it will be returned by a further pull_task call.
  64. the caller must ensure that component is able to execute task.
  65. \var struct starpu_task * (*starpu_sched_component::pull_task)(struct starpu_sched_component *)
  66. pop a task from the scheduler module. this function is called by workers to get a task from their
  67. parents. this function should first return a locally stored task
  68. or perform a recursive call on the parents.
  69. the task returned by this function is executable by the caller
  70. \var int (*starpu_sched_component::can_push)(struct starpu_sched_component *component)
  71. This function is called by a component which implements a queue,
  72. allowing it to signify to its parents that an empty slot is
  73. available in its queue. The basic implementation of this function
  74. is a recursive call to its parents, the user have to specify a
  75. personally-made function to catch those calls.
  76. \var void (*starpu_sched_component::can_pull)(struct starpu_sched_component *component)
  77. This function allow a component to wake up a worker. It is
  78. currently called by component which implements a queue, to
  79. signify to its children that a task have been pushed in its local
  80. queue, and is available to been popped by a worker, for example.
  81. The basic implementation of this function is a recursive call to
  82. its children, until at least one worker have been woken up.
  83. \var double (*starpu_sched_component::estimated_load)(struct starpu_sched_component *component)
  84. is an heuristic to compute load of scheduler module. Basically the number of tasks divided by the sum
  85. of relatives speedup of workers available in context.
  86. estimated_load(component) = sum(estimated_load(component_children)) + nb_local_tasks / average(relative_speedup(underlying_worker))
  87. \var starpu_sched_component::estimated_end
  88. return the time when a worker will enter in starvation. This function is relevant only if the task->predicted
  89. member has been set.
  90. \var void (*starpu_sched_component::deinit_data)(struct starpu_sched_component *component)
  91. called by starpu_sched_component_destroy. Should free data allocated during creation
  92. \var void (*starpu_sched_component::notify_change_workers)(struct starpu_sched_component *component)
  93. this function is called for each component when workers are added or removed from a context
  94. \var int starpu_sched_component::properties
  95. todo
  96. \var hwloc_obj_t starpu_sched_component::obj
  97. the hwloc object associated to scheduler module. points to the
  98. part of topology that is binded to this component, eg: a numa
  99. node for a ws component that would balance load between
  100. underlying sockets
  101. \struct starpu_sched_tree
  102. \ingroup API_Modularized_Scheduler
  103. The actual scheduler
  104. \var struct starpu_sched_component *starpu_sched_tree::root
  105. this is the entry module of the scheduler
  106. \var struct starpu_bitmap *starpu_sched_tree::workers
  107. this is the set of workers available in this context, this value is used to mask workers in modules
  108. \var unsigned starpu_sched_tree::sched_ctx_id
  109. the context id of the scheduler
  110. \var starpu_pthread_mutex_t starpu_sched_tree::lock
  111. this lock is used to protect the scheduler, it is taken in
  112. read mode pushing a task and in write mode for adding or
  113. removing workers
  114. \var struct starpu_sched_component *starpu_sched_tree::worker_components[STARPU_NMAXWORKERS]
  115. worker components
  116. @name Scheduling Tree API
  117. \ingroup API_Modularized_Scheduler
  118. \fn struct starpu_sched_tree *starpu_sched_tree_create(unsigned sched_ctx_id)
  119. \ingroup API_Modularized_Scheduler
  120. create a empty initialized starpu_sched_tree
  121. \fn void starpu_sched_tree_destroy(struct starpu_sched_tree *tree)
  122. \ingroup API_Modularized_Scheduler
  123. destroy tree and free all non shared component in it.
  124. \fn void starpu_sched_tree_update_workers(struct starpu_sched_tree *t)
  125. \ingroup API_Modularized_Scheduler
  126. recursively set all starpu_sched_component::workers, do not take into account shared parts (except workers).
  127. \fn void starpu_sched_tree_update_workers_in_ctx(struct starpu_sched_tree *t)
  128. \ingroup API_Modularized_Scheduler
  129. recursively set all starpu_sched_component::workers_in_ctx, do not take into account shared parts (except workers)
  130. \fn int starpu_sched_tree_push_task(struct starpu_task *task)
  131. \ingroup API_Modularized_Scheduler
  132. compatibility with starpu_sched_policy interface
  133. \fn struct starpu_task *starpu_sched_tree_pop_task(unsigned sched_ctx)
  134. \ingroup API_Modularized_Scheduler
  135. compatibility with starpu_sched_policy interface
  136. \fn void starpu_sched_tree_add_workers(unsigned sched_ctx_id, int *workerids, unsigned nworkers)
  137. \ingroup API_Modularized_Scheduler
  138. compatibility with starpu_sched_policy interface
  139. \fn void starpu_sched_tree_remove_workers(unsigned sched_ctx_id, int *workerids, unsigned nworkers)
  140. \ingroup API_Modularized_Scheduler
  141. compatibility with starpu_sched_policy interface
  142. \fn void starpu_sched_component_connect(struct starpu_sched_component *parent, struct starpu_sched_component *child)
  143. \ingroup API_Modularized_Scheduler
  144. Attaches component \p child to parent \p parent. Some component may accept only one child, others accept several (e.g. MCT)
  145. @name Generic Scheduling Component API
  146. \ingroup API_Modularized_Scheduler
  147. \fn struct starpu_sched_component *starpu_sched_component_create(struct starpu_sched_tree *tree, const char *name)
  148. \ingroup API_Modularized_Scheduler
  149. allocate and initialize component field with defaults values :
  150. .pop_task make recursive call on father
  151. .estimated_load compute relative speedup and tasks in sub tree
  152. .estimated_end return the average of recursive call on children
  153. .add_child is starpu_sched_component_add_child
  154. .remove_child is starpu_sched_component_remove_child
  155. .notify_change_workers does nothing
  156. .deinit_data does nothing
  157. \fn void starpu_sched_component_destroy(struct starpu_sched_component *component)
  158. \ingroup API_Modularized_Scheduler
  159. free data allocated by starpu_sched_component_create and call component->deinit_data(component)
  160. set to <c>NULL</c> the member starpu_sched_component::fathers[sched_ctx_id] of all child if its equal to \p component
  161. \fn void starpu_sched_component_destroy_rec(struct starpu_sched_component *component)
  162. \ingroup API_Modularized_Scheduler
  163. recursively destroy non shared parts of a \p component 's tree
  164. \fn int starpu_sched_component_can_execute_task(struct starpu_sched_component *component, struct starpu_task *task)
  165. \ingroup API_Modularized_Scheduler
  166. return true iff \p component can execute \p task, this function take into account the workers available in the scheduling context
  167. \fn int starpu_sched_component_execute_preds(struct starpu_sched_component *component, struct starpu_task *task, double *length)
  168. \ingroup API_Modularized_Scheduler
  169. return a non <c>NULL</c> value if \p component can execute \p task.
  170. write the execution prediction length for the best implementation of the best worker available and write this at \p length address.
  171. this result is more relevant if starpu_sched_component::is_homogeneous is non <c>NULL</c>.
  172. if a worker need to be calibrated for an implementation, nan is set to \p length.
  173. \fn double starpu_sched_component_transfer_length(struct starpu_sched_component *component, struct starpu_task *task)
  174. \ingroup API_Modularized_Scheduler
  175. return the average time to transfer \p task data to underlying \p component workers.
  176. @name Worker Component API
  177. \ingroup API_Modularized_Scheduler
  178. \fn struct starpu_sched_component *starpu_sched_component_worker_get(unsigned sched_ctx, int workerid)
  179. \ingroup API_Modularized_Scheduler
  180. return the struct starpu_sched_component corresponding to \p workerid. Undefined if \p workerid is not a valid workerid
  181. \fn int starpu_sched_component_worker_get_workerid(struct starpu_sched_component *worker_component)
  182. \ingroup API_Modularized_Scheduler
  183. return the workerid of \p worker_component, undefined if starpu_sched_component_is_worker(worker_component) == 0
  184. \fn int starpu_sched_component_is_worker(struct starpu_sched_component *component)
  185. \ingroup API_Modularized_Scheduler
  186. return true iff \p component is a worker component
  187. \fn int starpu_sched_component_is_simple_worker(struct starpu_sched_component *component)
  188. \ingroup API_Modularized_Scheduler
  189. return true iff \p component is a simple worker component
  190. \fn int starpu_sched_component_is_combined_worker(struct starpu_sched_component *component)
  191. \ingroup API_Modularized_Scheduler
  192. return true iff \p component is a combined worker component
  193. \fn void starpu_sched_component_worker_pre_exec_hook(struct starpu_task *task, unsigned sched_ctx_id)
  194. \ingroup API_Modularized_Scheduler
  195. compatibility with starpu_sched_policy interface
  196. update predictions for workers
  197. \fn void starpu_sched_component_worker_post_exec_hook(struct starpu_task *task, unsigned sched_ctx_id)
  198. \ingroup API_Modularized_Scheduler
  199. compatibility with starpu_sched_policy interface
  200. @name Flow-control Fifo Component API
  201. \ingroup API_Modularized_Scheduler
  202. \fn double starpu_sched_component_estimated_load(struct starpu_sched_component * component);
  203. \ingroup API_Modularized_Scheduler
  204. default function for the estimated_load component method, just sums up the loads
  205. of the children of the component.
  206. \fn double starpu_sched_component_estimated_end_min(struct starpu_sched_component * component);
  207. \ingroup API_Modularized_Scheduler
  208. function that can be used for the estimated_end component method, which just computes the minimum completion time of the children.
  209. \fn double starpu_sched_component_estimated_end_average(struct starpu_sched_component * component);
  210. \ingroup API_Modularized_Scheduler
  211. default function for the estimated_end component method, which just computes the average completion time of the children.
  212. \struct starpu_sched_component_fifo_data
  213. \ingroup API_Modularized_Scheduler
  214. \var unsigned starpu_sched_component_fifo_data::ntasks_threshold
  215. todo
  216. \var double starpu_sched_component_fifo_data::exp_len_threshold
  217. todo
  218. \fn struct starpu_sched_component *starpu_sched_component_fifo_create(struct starpu_sched_tree *tree, struct starpu_sched_component_fifo_data *fifo_data)
  219. \ingroup API_Modularized_Scheduler
  220. Return a struct starpu_sched_component with a fifo. A stable sort is performed according to tasks priorities.
  221. A push_task call on this component does not perform recursive calls, underlying components will have to call pop_task to get it.
  222. starpu_sched_component::estimated_end function compute the estimated length by dividing the sequential length by the number of underlying workers. Do not take into account tasks that are currently executed.
  223. \fn int starpu_sched_component_is_fifo(struct starpu_sched_component *component)
  224. \ingroup API_Modularized_Scheduler
  225. return true iff \p component is a fifo component
  226. @name Flow-control Prio Component API
  227. \ingroup API_Modularized_Scheduler
  228. \struct starpu_sched_component_prio_data
  229. \ingroup API_Modularized_Scheduler
  230. \var unsigned starpu_sched_component_prio_data::ntasks_threshold
  231. todo
  232. \var double starpu_sched_component_prio_data::exp_len_threshold
  233. todo
  234. \fn struct starpu_sched_component *starpu_sched_component_prio_create(struct starpu_sched_tree *tree, struct starpu_sched_component_prio_data *prio_data)
  235. \ingroup API_Modularized_Scheduler
  236. todo
  237. \fn int starpu_sched_component_is_prio(struct starpu_sched_component *component)
  238. \ingroup API_Modularized_Scheduler
  239. todo
  240. @name Resource-mapping Work-Stealing Component API
  241. \ingroup API_Modularized_Scheduler
  242. \fn struct starpu_sched_component *starpu_sched_component_work_stealing_create(struct starpu_sched_tree *tree, void *arg)
  243. \ingroup API_Modularized_Scheduler
  244. return a component that perform a work stealing scheduling. Tasks are pushed in a round robin way. estimated_end return the average of expected length of fifos, starting at the average of the expected_end of his children. When a worker have to steal a task, it steal a task in a round robin way, and get the last pushed task of the higher priority.
  245. \fn int starpu_sched_tree_work_stealing_push_task(struct starpu_task *task)
  246. \ingroup API_Modularized_Scheduler
  247. undefined if there is no work stealing component in the scheduler. If any, \p task is pushed in a default way if the caller is the application, and in the caller's fifo if its a worker.
  248. \fn int starpu_sched_component_is_work_stealing(struct starpu_sched_component *component)
  249. \ingroup API_Modularized_Scheduler
  250. return true iff \p component is a work stealing component
  251. @name Resource-mapping Random Component API
  252. \ingroup API_Modularized_Scheduler
  253. \fn struct starpu_sched_component *starpu_sched_component_random_create(struct starpu_sched_tree *tree, void *arg)
  254. \ingroup API_Modularized_Scheduler
  255. create a component that perform a random scheduling
  256. \fn int starpu_sched_component_is_random(struct starpu_sched_component *)
  257. \ingroup API_Modularized_Scheduler
  258. return true iff \p component is a random component
  259. @name Resource-mapping Eager Component API
  260. \ingroup API_Modularized_Scheduler
  261. \fn struct starpu_sched_component *starpu_sched_component_eager_create(struct starpu_sched_tree *tree, void *arg)
  262. \ingroup API_Modularized_Scheduler
  263. todo
  264. \fn int starpu_sched_component_is_eager(struct starpu_sched_component *)
  265. \ingroup API_Modularized_Scheduler
  266. todo
  267. @name Resource-mapping Eager-Calibration Component API
  268. \ingroup API_Modularized_Scheduler
  269. \fn struct starpu_sched_component *starpu_sched_component_eager_calibration_create(struct starpu_sched_tree *tree, void *arg)
  270. \ingroup API_Modularized_Scheduler
  271. todo
  272. \fn int starpu_sched_component_is_eager_calibration(struct starpu_sched_component *)
  273. \ingroup API_Modularized_Scheduler
  274. todo
  275. @name Resource-mapping MCT Component API
  276. \ingroup API_Modularized_Scheduler
  277. \struct starpu_sched_component_mct_data
  278. \ingroup API_Modularized_Scheduler
  279. \var double starpu_sched_component_mct_data::alpha
  280. todo
  281. \var double starpu_sched_component_mct_data::beta
  282. todo
  283. \var double starpu_sched_component_mct_data::_gamma
  284. todo
  285. \var double starpu_sched_component_mct_data::idle_power
  286. todo
  287. \fn struct starpu_sched_component *starpu_sched_component_mct_create(struct starpu_sched_tree *tree, struct starpu_sched_component_mct_data *mct_data)
  288. \ingroup API_Modularized_Scheduler
  289. create a component with mct_data paremeters. the mct component doesnt
  290. do anything but pushing tasks on no_perf_model_component and
  291. calibrating_component
  292. \fn int starpu_sched_component_is_mct(struct starpu_sched_component *component);
  293. \ingroup API_Modularized_Scheduler
  294. todo
  295. @name Resource-mapping Heft Component API
  296. \ingroup API_Modularized_Scheduler
  297. \fn struct starpu_sched_component *starpu_sched_component_heft_create(struct starpu_sched_tree *tree, struct starpu_sched_component_mct_data *mct_data)
  298. \ingroup API_Modularized_Scheduler
  299. this component perform a heft scheduling
  300. \fn int starpu_sched_component_is_heft(struct starpu_sched_component *component)
  301. \ingroup API_Modularized_Scheduler
  302. return true iff \p component is a heft component
  303. @name Special-purpose Best_Implementation Component API
  304. \ingroup API_Modularized_Scheduler
  305. \fn struct starpu_sched_component *starpu_sched_component_best_implementation_create(struct starpu_sched_tree *tree, void *arg)
  306. \ingroup API_Modularized_Scheduler
  307. Select the implementation that offer the shortest computation length for the first worker that can execute the task.
  308. Or an implementation that need to be calibrated.
  309. Also set starpu_task::predicted and starpu_task::predicted_transfer for memory component of the first suitable workerid.
  310. If starpu_sched_component::push method is called and starpu_sched_component::nchild > 1 the result is undefined.
  311. @name Special-purpose Perfmodel_Select Component API
  312. \ingroup API_Modularized_Scheduler
  313. \struct starpu_sched_component_perfmodel_select_data
  314. \ingroup API_Modularized_Scheduler
  315. \var struct starpu_sched_component *starpu_sched_component_perfmodel_select_data::calibrator_component
  316. todo
  317. \var struct starpu_sched_component *starpu_sched_component_perfmodel_select_data::no_perfmodel_component
  318. todo
  319. \var struct starpu_sched_component *starpu_sched_component_perfmodel_select_data::perfmodel_component
  320. todo
  321. \fn struct starpu_sched_component *starpu_sched_component_perfmodel_select_create(struct starpu_sched_tree *tree, struct starpu_sched_component_perfmodel_select_data *perfmodel_select_data)
  322. \ingroup API_Modularized_Scheduler
  323. todo
  324. \fn int starpu_sched_component_is_perfmodel_select(struct starpu_sched_component *component)
  325. \ingroup API_Modularized_Scheduler
  326. todo
  327. @name Recipe Component API
  328. \ingroup API_Modularized_Scheduler
  329. \struct starpu_sched_component_composed_recipe
  330. \ingroup API_Modularized_Scheduler
  331. parameters for starpu_sched_component_composed_component_create
  332. \fn struct starpu_sched_component_composed_recipe *starpu_sched_component_composed_recipe_create(void)
  333. \ingroup API_Modularized_Scheduler
  334. return an empty recipe for a composed component, it should not be used without modification
  335. \fn struct starpu_sched_component_composed_recipe *starpu_sched_component_composed_recipe_create_singleton(struct starpu_sched_component *(*create_component)(struct starpu_sched_tree *tree, void *arg), void *arg)
  336. \ingroup API_Modularized_Scheduler
  337. return a recipe to build a composed component with a \p create_component
  338. \fn void starpu_sched_component_composed_recipe_add(struct starpu_sched_component_composed_recipe *recipe, struct starpu_sched_component *(*create_component)(struct starpu_sched_tree *tree, void *arg), void *arg)
  339. \ingroup API_Modularized_Scheduler
  340. add \p create_component under all previous components in recipe
  341. \fn void starpu_sched_component_composed_recipe_destroy(struct starpu_sched_component_composed_recipe *)
  342. \ingroup API_Modularized_Scheduler
  343. destroy composed_sched_component, this should be done after starpu_sched_component_composed_component_create was called
  344. \fn struct starpu_sched_component *starpu_sched_component_composed_component_create(struct starpu_sched_tree *tree, struct starpu_sched_component_composed_recipe *recipe)
  345. \ingroup API_Modularized_Scheduler
  346. create a component that behave as all component of recipe where linked. Except that you cant use starpu_sched_component_is_foo function
  347. if recipe contain a single create_foo arg_foo pair, create_foo(arg_foo) is returned instead of a composed component
  348. \struct starpu_sched_component_specs
  349. \ingroup API_Modularized_Scheduler
  350. Define how build a scheduler according to topology. Each level (except for hwloc_machine_composed_sched_component) can be <c>NULL</c>, then
  351. the level is just skipped. Bugs everywhere, do not rely on.
  352. \var struct starpu_sched_component_composed_recipe *starpu_sched_specs::hwloc_machine_composed_sched_component
  353. the composed component to put on the top of the scheduler
  354. this member must not be <c>NULL</c> as it is the root of the topology
  355. \var struct starpu_sched_component_composed_recipe *starpu_sched_specs::hwloc_component_composed_sched_component
  356. the composed component to put for each memory component
  357. \var struct starpu_sched_component_composed_recipe *starpu_sched_specs::hwloc_socket_composed_sched_component
  358. the composed component to put for each socket
  359. \var struct starpu_sched_component_composed_recipe *starpu_sched_specs::hwloc_cache_composed_sched_component
  360. the composed component to put for each cache
  361. \var struct starpu_sched_component_composed_recipe *(*starpu_sched_specs::worker_composed_sched_component)(enum starpu_worker_archtype archtype)
  362. a function that return a starpu_sched_component_composed_recipe to put on top of a worker of type \p archtype.
  363. <c>NULL</c> is a valid return value, then no component will be added on top
  364. \var starpu_sched_specs::mix_heterogeneous_workers
  365. this flag is a dirty hack because of the poor expressivity of this interface. As example, if you want to build
  366. a heft component with a fifo component per numa component, and you also have GPUs, if this flag is set, GPUs will share those fifos.
  367. If this flag is not set, a new fifo will be built for each of them (if they have the same starpu_perf_arch and the same
  368. numa component it will be shared. it indicates if heterogenous workers should be brothers or cousins, as example, if a gpu and a cpu should share or not there numa node
  369. \fn struct starpu_sched_tree *starpu_sched_component_make_scheduler(unsigned sched_ctx_id, struct starpu_sched_component_specs s)
  370. \ingroup API_Modularized_Scheduler
  371. this function build a scheduler for \p sched_ctx_id according to \p s and the hwloc topology of the machine.
  372. \fn int starpu_sched_component_push_task(struct starpu_sched_component *from, struct starpu_sched_component *to, struct starpu_task *task)
  373. \ingroup API_Modularized_Scheduler
  374. Push a task to a component. This is a helper for <c>component->push_task(component, task)</c> plus tracing.
  375. \fn struct starpu_task *starpu_sched_component_pull_task(struct starpu_sched_component *from, struct starpu_sched_component *to)
  376. \ingroup API_Modularized_Scheduler
  377. Pull a task from a component. This is a helper for <c>component->pull_task(component)</c> plus tracing.
  378. */