20 #ifndef __STARPU_TASK_H__ 21 #define __STARPU_TASK_H__ 30 #if defined STARPU_USE_CUDA && !defined STARPU_DONT_INCLUDE_CUDA_HEADERS 39 #define STARPU_NOWHERE ((1ULL)<<0) 40 #define STARPU_CPU ((1ULL)<<1) 41 #define STARPU_CUDA ((1ULL)<<3) 42 #define STARPU_OPENCL ((1ULL)<<6) 43 #define STARPU_MIC ((1ULL)<<7) 44 #define STARPU_SCC ((1ULL)<<8) 46 #define STARPU_CODELET_SIMGRID_EXECUTE (1<<0) 47 #define STARPU_CUDA_ASYNC (1<<0) 48 #define STARPU_OPENCL_ASYNC (1<<0) 60 #define STARPU_TASK_INVALID 0 82 #define STARPU_MULTIPLE_CPU_IMPLEMENTATIONS ((starpu_cpu_func_t) -1) 83 #define STARPU_MULTIPLE_CUDA_IMPLEMENTATIONS ((starpu_cuda_func_t) -1) 84 #define STARPU_MULTIPLE_OPENCL_IMPLEMENTATIONS ((starpu_opencl_func_t) -1) 86 #define STARPU_VARIABLE_NBUFFERS (-1) 148 void (*callback_func)(
void *);
152 void (*prologue_callback_func)(
void *);
155 void (*prologue_callback_pop_func)(
void *);
156 void *prologue_callback_pop_arg;
165 unsigned prologue_callback_pop_arg_free:1;
179 unsigned prefetched:1;
194 unsigned possibly_parallel;
208 struct starpu_omp_task *omp_task;
214 #define STARPU_TASK_TYPE_NORMAL 0 215 #define STARPU_TASK_TYPE_INTERNAL (1<<0) 216 #define STARPU_TASK_TYPE_DATA_ACQUIRE (1<<1) 219 #define STARPU_TASK_INITIALIZER \ 224 .callback_func = NULL, \ 225 .callback_arg = NULL, \ 226 .priority = STARPU_DEFAULT_PRIO, \ 228 .sequential_consistency = 1, \ 230 .execute_on_a_specific_worker = 0, \ 236 .status = STARPU_TASK_INVALID, \ 237 .profiling_info = NULL, \ 239 .predicted_transfer = NAN, \ 240 .starpu_private = NULL, \ 244 .sched_ctx = STARPU_NMAX_SCHED_CTXS, \ 245 .hypervisor_tag = 0, \ 249 .dyn_handles = NULL, \ 250 .dyn_interfaces = NULL, \ 253 .possibly_parallel = 0 \ 256 #define STARPU_TASK_GET_NBUFFERS(task) ((unsigned)((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS ? ((task)->nbuffers) : ((task)->cl->nbuffers))) 258 #define STARPU_TASK_GET_HANDLE(task, i) (((task)->dyn_handles) ? (task)->dyn_handles[i] : (task)->handles[i]) 259 #define STARPU_TASK_GET_HANDLES(task) (((task)->dyn_handles) ? (task)->dyn_handles : (task)->handles) 260 #define STARPU_TASK_SET_HANDLE(task, handle, i) do { if ((task)->dyn_handles) (task)->dyn_handles[i] = handle; else (task)->handles[i] = handle; } while(0) 262 #define STARPU_CODELET_GET_MODE(codelet, i) (((codelet)->dyn_modes) ? (codelet)->dyn_modes[i] : (assert(i < STARPU_NMAXBUFS), (codelet)->modes[i])) 263 #define STARPU_CODELET_SET_MODE(codelet, mode, i) do { if ((codelet)->dyn_modes) (codelet)->dyn_modes[i] = mode; else (codelet)->modes[i] = mode; } while(0) 265 #define STARPU_TASK_GET_MODE(task, i) ((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS || (task)->dyn_modes ? \ 266 (((task)->dyn_modes) ? (task)->dyn_modes[i] : (task)->modes[i]) : \ 267 STARPU_CODELET_GET_MODE((task)->cl, i) ) 268 #define STARPU_TASK_SET_MODE(task, mode, i) do { \ 269 if ((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS || (task)->cl->nbuffers > STARPU_NMAXBUFS) \ 270 if ((task)->dyn_modes) (task)->dyn_modes[i] = mode; else (task)->modes[i] = mode; \ 272 STARPU_CODELET_SET_MODE((task)->cl, mode, i); \ 275 #define STARPU_CODELET_GET_NODE(codelet, i) (((codelet)->dyn_nodes) ? (codelet)->dyn_nodes[i] : (codelet)->nodes[i]) 276 #define STARPU_CODELET_SET_NODE(codelet, __node, i) do { if ((codelet)->dyn_nodes) (codelet)->dyn_nodes[i] = __node; else (codelet)->nodes[i] = __node; } while(0) 322 void starpu_do_schedule(
void);
unsigned color
Definition: starpu_task.h:124
Definition: starpu_task.h:65
struct starpu_perfmodel * energy_model
Definition: starpu_task.h:119
unsigned use_tag
Definition: starpu_task.h:167
void * prologue_callback_arg
Definition: starpu_task.h:153
starpu_opencl_func_t opencl_func
Definition: starpu_task.h:98
char cuda_flags[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:102
Definition: starpu_task.h:89
starpu_opencl_func_t opencl_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:103
starpu_scc_func_t scc_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:106
Definition: starpu_profiling.h:34
enum starpu_data_access_mode modes[STARPU_NMAXBUFS]
Definition: starpu_task.h:111
int nbuffers
Definition: starpu_task.h:135
void(* starpu_mic_kernel_t)(void **, void *)
Definition: starpu_task.h:76
unsigned regenerate
Definition: starpu_task.h:174
int max_parallelism
Definition: starpu_task.h:94
starpu_mic_kernel_t(* starpu_mic_func_t)(void)
Definition: starpu_task.h:79
void ** dyn_interfaces
Definition: starpu_task.h:142
int starpu_task_submit_to_ctx(struct starpu_task *task, unsigned sched_ctx_id)
struct starpu_profiling_task_info * profiling_info
Definition: starpu_task.h:198
enum starpu_data_access_mode * dyn_modes
Definition: starpu_task.h:143
unsigned execute_on_a_specific_worker
Definition: starpu_task.h:170
int * dyn_nodes
Definition: starpu_task.h:116
int starpu_task_nready(void)
#define STARPU_TASK_INVALID
Definition: starpu_task.h:60
unsigned type
Definition: starpu_task.h:189
struct starpu_codelet * cl
Definition: starpu_task.h:133
void starpu_tag_declare_deps(starpu_tag_t id, unsigned ndeps,...)
double predicted
Definition: starpu_task.h:201
starpu_mic_func_t mic_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:105
struct starpu_perfmodel * model
Definition: starpu_task.h:118
struct starpu_task * prev
Definition: starpu_task.h:204
Definition: starpu_task.h:61
int priority
Definition: starpu_task.h:184
void * callback_arg
Definition: starpu_task.h:149
int starpu_task_submit(struct starpu_task *task) STARPU_WARN_UNUSED_RESULT
char opencl_flags[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:104