starpu_sched_ctx.h 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010,2012-2017 Inria
  4. * Copyright (C) 2012-2014,2017 CNRS
  5. * Copyright (C) 2012,2014,2016 Université de Bordeaux
  6. * Copyright (C) 2016 Uppsala University
  7. *
  8. * StarPU is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU Lesser General Public License as published by
  10. * the Free Software Foundation; either version 2.1 of the License, or (at
  11. * your option) any later version.
  12. *
  13. * StarPU is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  16. *
  17. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  18. */
  19. #ifndef __STARPU_SCHED_CTX_H__
  20. #define __STARPU_SCHED_CTX_H__
  21. #include <starpu.h>
  22. #ifdef __cplusplus
  23. extern "C"
  24. {
  25. #endif
  26. #define STARPU_SCHED_CTX_POLICY_NAME (1<<16)
  27. #define STARPU_SCHED_CTX_POLICY_STRUCT (2<<16)
  28. #define STARPU_SCHED_CTX_POLICY_MIN_PRIO (3<<16)
  29. #define STARPU_SCHED_CTX_POLICY_MAX_PRIO (4<<16)
  30. #define STARPU_SCHED_CTX_HIERARCHY_LEVEL (5<<16)
  31. #define STARPU_SCHED_CTX_NESTED (6<<16)
  32. #define STARPU_SCHED_CTX_AWAKE_WORKERS (7<<16)
  33. #define STARPU_SCHED_CTX_POLICY_INIT (8<<16)
  34. #define STARPU_SCHED_CTX_USER_DATA (9<<16)
  35. #define STARPU_SCHED_CTX_CUDA_NSMS (10<<16)
  36. #define STARPU_SCHED_CTX_SUB_CTXS (11<<16)
  37. unsigned starpu_sched_ctx_create(int *workerids_ctx, int nworkers_ctx, const char *sched_ctx_name, ...);
  38. unsigned starpu_sched_ctx_create_inside_interval(const char *policy_name, const char *sched_ctx_name, int min_ncpus, int max_ncpus, int min_ngpus, int max_ngpus, unsigned allow_overlap);
  39. void starpu_sched_ctx_register_close_callback(unsigned sched_ctx_id, void (*close_callback)(unsigned sched_ctx_id, void* args), void *args);
  40. void starpu_sched_ctx_add_workers(int *workerids_ctx, unsigned nworkers_ctx, unsigned sched_ctx_id);
  41. void starpu_sched_ctx_remove_workers(int *workerids_ctx, unsigned nworkers_ctx, unsigned sched_ctx_id);
  42. void starpu_sched_ctx_display_workers(unsigned sched_ctx_id, FILE *f);
  43. void starpu_sched_ctx_delete(unsigned sched_ctx_id);
  44. void starpu_sched_ctx_set_inheritor(unsigned sched_ctx_id, unsigned inheritor);
  45. unsigned starpu_sched_ctx_get_inheritor(unsigned sched_ctx_id);
  46. unsigned starpu_sched_ctx_get_hierarchy_level(unsigned sched_ctx_id);
  47. void starpu_sched_ctx_set_context(unsigned *sched_ctx_id);
  48. unsigned starpu_sched_ctx_get_context(void);
  49. void starpu_sched_ctx_stop_task_submission(void);
  50. void starpu_sched_ctx_finished_submit(unsigned sched_ctx_id);
  51. unsigned starpu_sched_ctx_get_workers_list(unsigned sched_ctx_id, int **workerids);
  52. unsigned starpu_sched_ctx_get_workers_list_raw(unsigned sched_ctx_id, int **workerids);
  53. unsigned starpu_sched_ctx_get_nworkers(unsigned sched_ctx_id);
  54. unsigned starpu_sched_ctx_get_nshared_workers(unsigned sched_ctx_id, unsigned sched_ctx_id2);
  55. unsigned starpu_sched_ctx_contains_worker(int workerid, unsigned sched_ctx_id);
  56. unsigned starpu_sched_ctx_contains_type_of_worker(enum starpu_worker_archtype arch, unsigned sched_ctx_id);
  57. unsigned starpu_sched_ctx_worker_get_id(unsigned sched_ctx_id);
  58. unsigned starpu_sched_ctx_get_ctx_for_task(struct starpu_task *task);
  59. unsigned starpu_sched_ctx_overlapping_ctxs_on_worker(int workerid);
  60. int starpu_sched_get_min_priority(void);
  61. int starpu_sched_get_max_priority(void);
  62. int starpu_sched_set_min_priority(int min_prio);
  63. int starpu_sched_set_max_priority(int max_prio);
  64. int starpu_sched_ctx_get_min_priority(unsigned sched_ctx_id);
  65. int starpu_sched_ctx_get_max_priority(unsigned sched_ctx_id);
  66. int starpu_sched_ctx_set_min_priority(unsigned sched_ctx_id, int min_prio);
  67. int starpu_sched_ctx_set_max_priority(unsigned sched_ctx_id, int max_prio);
  68. int starpu_sched_ctx_min_priority_is_set(unsigned sched_ctx_id);
  69. int starpu_sched_ctx_max_priority_is_set(unsigned sched_ctx_id);
  70. #define STARPU_MIN_PRIO (starpu_sched_get_min_priority())
  71. #define STARPU_MAX_PRIO (starpu_sched_get_max_priority())
  72. #define STARPU_DEFAULT_PRIO 0
  73. void *starpu_sched_ctx_get_user_data(unsigned sched_ctx_id);
  74. void starpu_sched_ctx_set_user_data(unsigned sched_ctx_id, void* user_data);
  75. struct starpu_worker_collection *starpu_sched_ctx_create_worker_collection(unsigned sched_ctx_id, enum starpu_worker_collection_type type) STARPU_ATTRIBUTE_MALLOC;
  76. void starpu_sched_ctx_delete_worker_collection(unsigned sched_ctx_id);
  77. struct starpu_worker_collection *starpu_sched_ctx_get_worker_collection(unsigned sched_ctx_id);
  78. void starpu_sched_ctx_set_policy_data(unsigned sched_ctx_id, void *policy_data);
  79. void *starpu_sched_ctx_get_policy_data(unsigned sched_ctx_id);
  80. struct starpu_sched_policy *starpu_sched_ctx_get_sched_policy(unsigned sched_ctx_id);
  81. void *starpu_sched_ctx_exec_parallel_code(void* (*func)(void*), void *param, unsigned sched_ctx_id);
  82. int starpu_sched_ctx_get_nready_tasks(unsigned sched_ctx_id);
  83. double starpu_sched_ctx_get_nready_flops(unsigned sched_ctx_id);
  84. void starpu_sched_ctx_list_task_counters_increment(unsigned sched_ctx_id, int workerid);
  85. void starpu_sched_ctx_list_task_counters_decrement(unsigned sched_ctx_id, int workerid);
  86. void starpu_sched_ctx_list_task_counters_reset(unsigned sched_ctx_id, int workerid);
  87. void starpu_sched_ctx_list_task_counters_increment_all_ctx_locked(struct starpu_task *task, unsigned sched_ctx_id);
  88. void starpu_sched_ctx_list_task_counters_decrement_all_ctx_locked(struct starpu_task *task, unsigned sched_ctx_id);
  89. void starpu_sched_ctx_list_task_counters_reset_all(struct starpu_task *task, unsigned sched_ctx_id);
  90. void starpu_sched_ctx_set_priority(int *workers, int nworkers, unsigned sched_ctx_id, unsigned priority);
  91. unsigned starpu_sched_ctx_get_priority(int worker, unsigned sched_ctx_id);
  92. void starpu_sched_ctx_get_available_cpuids(unsigned sched_ctx_id, int **cpuids, int *ncpuids);
  93. void starpu_sched_ctx_bind_current_thread_to_cpuid(unsigned cpuid);
  94. int starpu_sched_ctx_book_workers_for_task(unsigned sched_ctx_id, int *workerids, int nworkers);
  95. void starpu_sched_ctx_unbook_workers_for_task(unsigned sched_ctx_id, int master);
  96. /* return the first context (child of sched_ctx_id) where the workerid is master */
  97. unsigned starpu_sched_ctx_worker_is_master_for_child_ctx(int workerid, unsigned sched_ctx_id);
  98. /* Returns the context id of masterid if it master of a context. */
  99. /* If not, returns STARPU_NMAX_SCHED_CTXS. */
  100. unsigned starpu_sched_ctx_master_get_context(int masterid);
  101. void starpu_sched_ctx_revert_task_counters_ctx_locked(unsigned sched_ctx_id, double flops);
  102. void starpu_sched_ctx_move_task_to_ctx_locked(struct starpu_task *task, unsigned sched_ctx, unsigned with_repush);
  103. int starpu_sched_ctx_get_worker_rank(unsigned sched_ctx_id);
  104. void (*starpu_sched_ctx_get_sched_policy_init(unsigned sched_ctx_id))(unsigned);
  105. unsigned starpu_sched_ctx_has_starpu_scheduler(unsigned sched_ctx_id, unsigned *awake_workers);
  106. #ifdef STARPU_USE_SC_HYPERVISOR
  107. void starpu_sched_ctx_call_pushed_task_cb(int workerid, unsigned sched_ctx_id);
  108. #endif /* STARPU_USE_SC_HYPERVISOR */
  109. int starpu_sched_ctx_get_stream_worker(unsigned sub_ctx);
  110. int starpu_sched_ctx_get_nsms(unsigned sched_ctx);
  111. void starpu_sched_ctx_get_sms_interval(int stream_workerid, int *start, int *end);
  112. #ifdef __cplusplus
  113. }
  114. #endif
  115. #endif /* __STARPU_SCHED_CTX_H__ */