StarPU Handbook - StarPU FAQs
starpu_task.h
Go to the documentation of this file.
1/* StarPU --- Runtime system for heterogeneous multicore architectures.
2 *
3 * Copyright (C) 2009-2025 University of Bordeaux, CNRS (LaBRI UMR 5800), Inria
4 * Copyright (C) 2011 Télécom Sud Paris
5 * Copyright (C) 2016 Uppsala University
6 *
7 * StarPU is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU Lesser General Public License as published by
9 * the Free Software Foundation; either version 2.1 of the License, or (at
10 * your option) any later version.
11 *
12 * StarPU is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
15 *
16 * See the GNU Lesser General Public License in COPYING.LGPL for more details.
17 */
18
19#include <starpu.h>
20
21#ifndef __STARPU_TASK_H__
22#define __STARPU_TASK_H__
23
24#include <errno.h>
25#include <assert.h>
26
27#ifdef STARPU_USE_CUDA
28#include <cuda.h>
29#endif
30
31#ifdef __cplusplus
32extern "C" {
33#endif
34
47#define STARPU_NOWHERE ((1ULL) << 0)
48
52#define STARPU_WORKER_TO_MASK(worker_archtype) (1ULL << (worker_archtype + 1))
53
59#define STARPU_CPU STARPU_WORKER_TO_MASK(STARPU_CPU_WORKER)
60
66#define STARPU_CUDA STARPU_WORKER_TO_MASK(STARPU_CUDA_WORKER)
67
73#define STARPU_HIP STARPU_WORKER_TO_MASK(STARPU_HIP_WORKER)
74
80#define STARPU_OPENCL STARPU_WORKER_TO_MASK(STARPU_OPENCL_WORKER)
81
87#define STARPU_MAX_FPGA STARPU_WORKER_TO_MASK(STARPU_MAX_FPGA_WORKER)
88
94#define STARPU_MPI_MS STARPU_WORKER_TO_MASK(STARPU_MPI_MS_WORKER)
95
101#define STARPU_TCPIP_MS STARPU_WORKER_TO_MASK(STARPU_TCPIP_MS_WORKER)
102
107#define STARPU_CODELET_SIMGRID_EXECUTE (1 << 0)
108
114#define STARPU_CODELET_SIMGRID_EXECUTE_AND_INJECT (1 << 1)
115
120#define STARPU_CODELET_NOPLANS (1 << 2)
121
127#define STARPU_CUDA_ASYNC (1 << 0)
128
133#define STARPU_HIP_ASYNC (1 << 0)
134
140#define STARPU_OPENCL_ASYNC (1 << 0)
141
145#define STARPU_MAIN_RAM 0
146
152{
153 STARPU_SEQ = 0,
169
174{
176#define STARPU_TASK_INIT 0
177#define STARPU_TASK_INVALID STARPU_TASK_INIT
187
191typedef void (*starpu_cpu_func_t)(void **, void *);
192
196typedef void (*starpu_cuda_func_t)(void **, void *);
197
201typedef void (*starpu_hip_func_t)(void **, void *);
202
206typedef void (*starpu_opencl_func_t)(void **, void *);
207
211typedef void (*starpu_max_fpga_func_t)(void **, void *);
212
217typedef int (*starpu_bubble_func_t)(struct starpu_task *t, void *arg);
218
223typedef void (*starpu_bubble_gen_dag_func_t)(struct starpu_task *t, void *arg);
224
232#define STARPU_MULTIPLE_CPU_IMPLEMENTATIONS ((starpu_cpu_func_t)-1)
233
241#define STARPU_MULTIPLE_CUDA_IMPLEMENTATIONS ((starpu_cuda_func_t)-1)
242
250#define STARPU_MULTIPLE_HIP_IMPLEMENTATIONS ((starpu_hip_func_t)-1)
251
259#define STARPU_MULTIPLE_OPENCL_IMPLEMENTATIONS ((starpu_opencl_func_t)-1)
260
266#define STARPU_VARIABLE_NBUFFERS (-1)
267
273#define STARPU_SPECIFIC_NODE_LOCAL (-1)
274
280#define STARPU_SPECIFIC_NODE_CPU (-2)
281
286#define STARPU_SPECIFIC_NODE_SLOW (-3)
287
292#define STARPU_SPECIFIC_NODE_FAST (-4)
293
299#define STARPU_SPECIFIC_NODE_LOCAL_OR_CPU (-5)
300
307#define STARPU_SPECIFIC_NODE_NONE (-6)
308
309struct starpu_transaction;
310struct _starpu_trs_epoch;
311typedef struct _starpu_trs_epoch *starpu_trs_epoch_t;
312struct starpu_task;
313
339{
354 uint32_t where;
355
361 int (*can_execute)(unsigned workerid, struct starpu_task *task, unsigned nimpl);
362
371
378
384 starpu_cpu_func_t cpu_func STARPU_DEPRECATED;
385
391 starpu_cuda_func_t cuda_func STARPU_DEPRECATED;
392
399
416
431
438
453
460
474
481
498
507
513
518
533
544
557
566
582
595
603
613
622
627 const char *name;
628
635 unsigned color;
636
649 void (*callback_func)(void *);
650
654 int flags;
655
656 struct starpu_perf_counter_sample *perf_counter_sample;
657 struct starpu_perf_counter_sample_cl_values *perf_counter_values;
658
663};
664
669
674{
677};
678
689{
697 const char *name;
698
703 const char *file;
704
709 int line;
710
719
727 int32_t where;
728
737
759
768
786
800
808
824
834
857 void *cl_arg;
875
884 void *cl_ret;
885
893
908 void (*epilogue_callback_func)(void *);
909
917
936 void (*callback_func)(void *);
937
951
965 void (*prologue_callback_func)(void *);
966
977
992
1003
1007 struct starpu_transaction *transaction;
1008
1012 starpu_trs_epoch_t trs_epoch;
1013
1023
1034 unsigned cl_arg_free : 1;
1035
1042 unsigned cl_ret_free : 1;
1043
1055 unsigned callback_arg_free : 1;
1056
1065
1078
1092
1103 unsigned use_tag : 1;
1104
1116
1126 unsigned synchronous : 1;
1127
1137
1147 unsigned detach : 1;
1148
1167 unsigned destroy : 1;
1168
1178 unsigned regenerate : 1;
1179
1187 unsigned no_submitorder : 1;
1188
1194 unsigned char mf_skip;
1195
1201 unsigned char failed;
1202
1208 unsigned char scheduled;
1209
1215 unsigned char prefetched;
1216
1228 unsigned workerid;
1229
1244 unsigned workerorder;
1245
1258 uint32_t *workerids;
1259
1270
1293
1302
1311
1321 unsigned type;
1322
1329 unsigned color;
1330
1337 unsigned sched_ctx;
1338
1346
1354
1360
1369
1382 double flops;
1391
1400 double predicted_start;
1401
1408
1415
1421
1422#ifdef STARPU_OPENMP
1427 struct starpu_omp_task *omp_task;
1428#else
1429 void *omp_task;
1430#endif
1431
1436 unsigned long bubble_parent;
1437
1443
1449
1455
1461
1467
1476};
1477
1481#define STARPU_TASK_TYPE_NORMAL 0
1482
1486#define STARPU_TASK_TYPE_INTERNAL (1 << 0)
1487
1491#define STARPU_TASK_TYPE_DATA_ACQUIRE (1 << 1)
1492
1493/* Note: remember to update starpu_task_init and starpu_task_ft_create_retry
1494 * as well */
1500#define STARPU_TASK_INITIALIZER \
1501 { \
1502 .cl = NULL, \
1503 .where = -1, \
1504 .cl_arg = NULL, \
1505 .cl_arg_size = 0, \
1506 .cl_ret = NULL, \
1507 .cl_ret_size = 0, \
1508 .callback_func = NULL, \
1509 .callback_arg = NULL, \
1510 .epilogue_callback_func = NULL, \
1511 .epilogue_callback_arg = NULL, \
1512 .priority = STARPU_DEFAULT_PRIO, \
1513 .use_tag = 0, \
1514 .sequential_consistency = 1, \
1515 .synchronous = 0, \
1516 .execute_on_a_specific_worker = 0, \
1517 .workerorder = 0, \
1518 .bundle = NULL, \
1519 .detach = 1, \
1520 .destroy = 0, \
1521 .regenerate = 0, \
1522 .status = STARPU_TASK_INIT, \
1523 .profiling_info = NULL, \
1524 .predicted = NAN, \
1525 .predicted_transfer = NAN, \
1526 .predicted_start = NAN, \
1527 .starpu_private = NULL, \
1528 .magic = 42, \
1529 .type = 0, \
1530 .color = 0, \
1531 .sched_ctx = STARPU_NMAX_SCHED_CTXS, \
1532 .hypervisor_tag = 0, \
1533 .flops = 0.0, \
1534 .scheduled = 0, \
1535 .prefetched = 0, \
1536 .dyn_handles = NULL, \
1537 .dyn_interfaces = NULL, \
1538 .dyn_modes = NULL, \
1539 .name = NULL, \
1540 .possibly_parallel = 0 \
1541 }
1542
1548#define STARPU_TASK_GET_NBUFFERS(task) ((unsigned)((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS ? ((task)->nbuffers) : ((task)->cl->nbuffers)))
1549
1557#define STARPU_TASK_GET_HANDLE(task, i) (((task)->dyn_handles) ? (task)->dyn_handles[i] : (task)->handles[i])
1558
1565#define STARPU_TASK_GET_HANDLES(task) (((task)->dyn_handles) ? (task)->dyn_handles : (task)->handles)
1566
1574#define STARPU_TASK_SET_HANDLE(task, handle, i) \
1575 do { \
1576 if ((task)->dyn_handles) \
1577 (task)->dyn_handles[i] = handle; \
1578 else \
1579 (task)->handles[i] = handle; \
1580 } \
1581 while (0)
1582
1590#define STARPU_CODELET_GET_MODE(codelet, i) \
1591 (((codelet)->dyn_modes) ? (codelet)->dyn_modes[i] : (assert(i < STARPU_NMAXBUFS), (codelet)->modes[i]))
1592
1600#define STARPU_CODELET_SET_MODE(codelet, mode, i) \
1601 do { \
1602 if ((codelet)->dyn_modes) \
1603 (codelet)->dyn_modes[i] = mode; \
1604 else \
1605 (codelet)->modes[i] = mode; \
1606 } \
1607 while (0)
1608
1616#define STARPU_TASK_GET_MODE(task, i) \
1617 ((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS || (task)->dyn_modes ? (((task)->dyn_modes) ? (task)->dyn_modes[i] : (task)->modes[i]) : STARPU_CODELET_GET_MODE((task)->cl, i))
1618
1626#define STARPU_TASK_SET_MODE(task, mode, i) \
1627 do { \
1628 if ((task)->cl->nbuffers == STARPU_VARIABLE_NBUFFERS || (task)->cl->nbuffers > STARPU_NMAXBUFS) \
1629 if ((task)->dyn_modes) \
1630 (task)->dyn_modes[i] = mode; \
1631 else \
1632 (task)->modes[i] = mode; \
1633 else \
1634 { \
1635 enum starpu_data_access_mode cl_mode = STARPU_CODELET_GET_MODE((task)->cl, i); \
1636 STARPU_ASSERT_MSG(cl_mode == mode, \
1637 "Task <%s> can't set its %d-th buffer mode to %d as the codelet it derives from uses %d", \
1638 (task)->cl->name, i, mode, cl_mode); \
1639 } \
1640 } \
1641 while (0)
1642
1650#define STARPU_CODELET_GET_NODE(codelet, i) (((codelet)->dyn_nodes) ? (codelet)->dyn_nodes[i] : (codelet)->nodes[i])
1651
1659#define STARPU_CODELET_SET_NODE(codelet, __node, i) \
1660 do { \
1661 if ((codelet)->dyn_nodes) \
1662 (codelet)->dyn_nodes[i] = __node; \
1663 else \
1664 (codelet)->nodes[i] = __node; \
1665 } \
1666 while (0)
1667
1677
1691
1704
1715
1726
1735
1754int starpu_task_submit(struct starpu_task *task) STARPU_WARN_UNUSED_RESULT;
1755
1756#ifdef STARPU_USE_FXT
1757static inline int starpu_task_submit_line(struct starpu_task *task, const char *file, int line)
1758{
1759 task->file = file;
1760 task->line = line;
1761 return starpu_task_submit(task);
1762}
1763#define starpu_task_submit(task) starpu_task_submit_line((task), __FILE__, __LINE__)
1764#endif
1765
1774int starpu_task_submit_nodeps(struct starpu_task *task) STARPU_WARN_UNUSED_RESULT;
1775
1782int starpu_task_submit_to_ctx(struct starpu_task *task, unsigned sched_ctx_id);
1783
1788int starpu_task_finished(struct starpu_task *task) STARPU_WARN_UNUSED_RESULT;
1789
1798int starpu_task_wait(struct starpu_task *task) STARPU_WARN_UNUSED_RESULT;
1799
1806int starpu_task_wait_array(struct starpu_task **tasks, unsigned nb_tasks) STARPU_WARN_UNUSED_RESULT;
1807
1815
1823
1829int starpu_task_wait_for_all_in_ctx(unsigned sched_ctx_id);
1830
1837int starpu_task_wait_for_n_submitted_in_ctx(unsigned sched_ctx_id, unsigned n);
1838
1844
1852
1858
1873void starpu_iteration_push(unsigned long iteration);
1874
1886
1894
1900
1908
1922
1927const char *starpu_task_get_model_name(struct starpu_task *task);
1928
1934const char *starpu_task_get_name(struct starpu_task *task);
1935
1941
1947void starpu_task_set_implementation(struct starpu_task *task, unsigned impl);
1948
1955
1961void starpu_create_sync_task(starpu_tag_t sync_tag, unsigned ndeps, starpu_tag_t *deps, void (*callback)(void *), void *callback_arg);
1962
1967void starpu_create_callback_task(void (*callback)(void *), void *callback_arg);
1968
1982void starpu_task_ft_prologue(void *check_ft);
1983
2000struct starpu_task *starpu_task_ft_create_retry(const struct starpu_task *meta_task, const struct starpu_task *template_task, void (*check_ft)(void *));
2001
2013
2019void starpu_task_ft_success(struct starpu_task *meta_task);
2020
2026void starpu_task_watchdog_set_hook(void (*hook)(void *), void *hook_arg);
2027
2032
2041
2050
2065struct starpu_transaction *starpu_transaction_open(int (*do_start_func)(void *buffer, void *arg), void *do_start_arg);
2066
2071void starpu_transaction_next_epoch(struct starpu_transaction *p_trs, void *do_start_arg);
2072
2077void starpu_transaction_close(struct starpu_transaction *p_trs);
2078
2081#ifdef __cplusplus
2082}
2083#endif
2084
2085#endif /* __STARPU_TASK_H__ */
void(* starpu_bubble_gen_dag_func_t)(struct starpu_task *t, void *arg)
Definition: starpu_task.h:223
int(* starpu_bubble_func_t)(struct starpu_task *t, void *arg)
Definition: starpu_task.h:217
starpu_task_bundle_t bundle
Definition: starpu_task.h:1359
unsigned specific_nodes
Definition: starpu_task.h:565
void(* callback_func)(void *)
Definition: starpu_task.h:936
starpu_max_fpga_func_t max_fpga_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:497
int max_parallelism
Definition: starpu_task.h:377
void * bubble_func_arg
Definition: starpu_task.h:1448
unsigned sched_ctx
Definition: starpu_task.h:1337
starpu_bubble_gen_dag_func_t bubble_gen_dag_func
Definition: starpu_task.h:1454
unsigned nb_termination_call_required
Definition: starpu_task.h:1466
unsigned synchronous
Definition: starpu_task.h:1126
int checked
Definition: starpu_task.h:662
int nbuffers
Definition: starpu_task.h:532
void * cl_ret
Definition: starpu_task.h:884
void * cl_arg
Definition: starpu_task.h:857
void(* epilogue_callback_func)(void *)
Definition: starpu_task.h:908
starpu_opencl_func_t opencl_func
Definition: starpu_task.h:398
double predicted_transfer
Definition: starpu_task.h:1399
struct starpu_perfmodel * model
Definition: starpu_task.h:602
unsigned long per_worker_stats[STARPU_NMAXWORKERS]
Definition: starpu_task.h:621
starpu_bubble_gen_dag_func_t bubble_gen_dag_func
Definition: starpu_task.h:517
int(* can_execute)(unsigned workerid, struct starpu_task *task, unsigned nimpl)
Definition: starpu_task.h:361
starpu_bubble_func_t bubble_func
Definition: starpu_task.h:512
char opencl_flags[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:480
unsigned use_tag
Definition: starpu_task.h:1103
unsigned callback_arg_free
Definition: starpu_task.h:1055
unsigned epilogue_callback_arg_free
Definition: starpu_task.h:1064
starpu_trs_epoch_t trs_epoch
Definition: starpu_task.h:1012
starpu_cuda_func_t cuda_func
Definition: starpu_task.h:391
unsigned cl_arg_free
Definition: starpu_task.h:1034
unsigned destroy
Definition: starpu_task.h:1167
int * dyn_nodes
Definition: starpu_task.h:594
enum starpu_data_access_mode modes[STARPU_NMAXBUFS]
Definition: starpu_task.h:823
void * prologue_callback_arg
Definition: starpu_task.h:976
int hypervisor_tag
Definition: starpu_task.h:1345
int32_t where
Definition: starpu_task.h:727
uint32_t where
Definition: starpu_task.h:354
void(* callback_func)(void *)
Definition: starpu_task.h:649
int line
Definition: starpu_task.h:709
unsigned execute_on_a_specific_worker
Definition: starpu_task.h:1136
starpu_data_handle_t * dyn_handles
Definition: starpu_task.h:758
starpu_cpu_func_t cpu_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:415
void * starpu_private
Definition: starpu_task.h:1420
unsigned type
Definition: starpu_task.h:1321
unsigned prologue_callback_arg_free
Definition: starpu_task.h:1077
size_t cl_ret_size
Definition: starpu_task.h:892
enum starpu_data_access_mode modes[STARPU_NMAXBUFS]
Definition: starpu_task.h:543
unsigned workerid
Definition: starpu_task.h:1228
unsigned char mf_skip
Definition: starpu_task.h:1194
unsigned workerorder
Definition: starpu_task.h:1244
struct starpu_transaction * transaction
Definition: starpu_task.h:1007
enum starpu_task_status status
Definition: starpu_task.h:1301
starpu_opencl_func_t opencl_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:473
unsigned workerids_len
Definition: starpu_task.h:1269
struct starpu_profiling_task_info * profiling_info
Definition: starpu_task.h:1368
const char * name
Definition: starpu_task.h:697
double flops
Definition: starpu_task.h:1382
starpu_tag_t tag_id
Definition: starpu_task.h:1022
void * prologue_callback_pop_arg
Definition: starpu_task.h:1002
starpu_bubble_func_t bubble_func
Definition: starpu_task.h:1442
void ** dyn_interfaces
Definition: starpu_task.h:767
unsigned char failed
Definition: starpu_task.h:1201
unsigned cl_ret_free
Definition: starpu_task.h:1042
const char * file
Definition: starpu_task.h:703
unsigned possibly_parallel
Definition: starpu_task.h:1353
double predicted
Definition: starpu_task.h:1390
unsigned char * handles_sequential_consistency
Definition: starpu_task.h:833
unsigned char prefetched
Definition: starpu_task.h:1215
unsigned detach
Definition: starpu_task.h:1147
int priority
Definition: starpu_task.h:1292
unsigned char scheduled
Definition: starpu_task.h:1208
enum starpu_data_access_mode * dyn_modes
Definition: starpu_task.h:556
void * callback_arg
Definition: starpu_task.h:950
starpu_cuda_func_t cuda_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:430
int nbuffers
Definition: starpu_task.h:736
char cuda_flags[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:437
char hip_flags[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:459
void * bubble_gen_dag_func_arg
Definition: starpu_task.h:1460
struct starpu_omp_task * omp_task
Definition: starpu_task.h:1427
enum starpu_data_access_mode mode
Definition: starpu_task.h:676
int nodes[STARPU_NMAXBUFS]
Definition: starpu_task.h:581
unsigned color
Definition: starpu_task.h:1329
starpu_hip_func_t hip_funcs[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:452
const char * cpu_funcs_name[STARPU_MAXIMPLEMENTATIONS]
Definition: starpu_task.h:506
struct starpu_codelet * cl
Definition: starpu_task.h:718
int magic
Definition: starpu_task.h:1310
starpu_data_handle_t handle
Definition: starpu_task.h:675
uint32_t * workerids
Definition: starpu_task.h:1258
int flags
Definition: starpu_task.h:654
void(* prologue_callback_pop_func)(void *)
Definition: starpu_task.h:991
starpu_cpu_func_t cpu_func
Definition: starpu_task.h:384
unsigned color
Definition: starpu_task.h:635
unsigned long bubble_parent
Definition: starpu_task.h:1436
size_t cl_arg_size
Definition: starpu_task.h:874
void * sched_data
Definition: starpu_task.h:1475
const char * name
Definition: starpu_task.h:627
struct starpu_task * prev
Definition: starpu_task.h:1407
struct starpu_task * next
Definition: starpu_task.h:1414
void(* prologue_callback_func)(void *)
Definition: starpu_task.h:965
enum starpu_data_access_mode * dyn_modes
Definition: starpu_task.h:785
unsigned sequential_consistency
Definition: starpu_task.h:1115
unsigned prologue_callback_pop_arg_free
Definition: starpu_task.h:1091
void * epilogue_callback_arg
Definition: starpu_task.h:916
unsigned regenerate
Definition: starpu_task.h:1178
starpu_data_handle_t handles[STARPU_NMAXBUFS]
Definition: starpu_task.h:799
enum starpu_codelet_type type
Definition: starpu_task.h:370
unsigned no_submitorder
Definition: starpu_task.h:1187
struct starpu_perfmodel * energy_model
Definition: starpu_task.h:612
void * interfaces[STARPU_NMAXBUFS]
Definition: starpu_task.h:807
starpu_task_status
Definition: starpu_task.h:174
void(* starpu_cuda_func_t)(void **, void *)
Definition: starpu_task.h:196
void starpu_codelet_display_stats(struct starpu_codelet *cl)
int starpu_task_nready(void)
void(* starpu_cpu_func_t)(void **, void *)
Definition: starpu_task.h:191
int starpu_task_wait_array(struct starpu_task **tasks, unsigned nb_tasks)
int starpu_task_wait(struct starpu_task *task)
void starpu_do_schedule(void)
int starpu_task_submit_to_ctx(struct starpu_task *task, unsigned sched_ctx_id)
char * starpu_task_status_get_as_string(enum starpu_task_status status)
void starpu_codelet_init(struct starpu_codelet *cl)
struct starpu_task * starpu_task_create(void) STARPU_ATTRIBUTE_MALLOC
void starpu_task_ft_prologue(void *check_ft)
int starpu_task_wait_for_no_ready(void)
struct starpu_task * starpu_task_create_sync(starpu_data_handle_t handle, enum starpu_data_access_mode mode) STARPU_ATTRIBUTE_MALLOC
void(* starpu_opencl_func_t)(void **, void *)
Definition: starpu_task.h:206
int starpu_task_wait_for_n_submitted(unsigned n)
const char * starpu_task_get_name(struct starpu_task *task)
void starpu_task_ft_failed(struct starpu_task *task)
const char * starpu_task_get_model_name(struct starpu_task *task)
void starpu_set_limit_max_submitted_tasks(int limit_min)
void starpu_iteration_pop(void)
void starpu_create_sync_task(starpu_tag_t sync_tag, unsigned ndeps, starpu_tag_t *deps, void(*callback)(void *), void *callback_arg)
int starpu_task_get_current_data_node(unsigned i)
void starpu_set_limit_min_submitted_tasks(int limit_min)
void starpu_task_destroy(struct starpu_task *task)
void starpu_task_watchdog_set_hook(void(*hook)(void *), void *hook_arg)
void starpu_create_callback_task(void(*callback)(void *), void *callback_arg)
struct starpu_task * starpu_task_ft_create_retry(const struct starpu_task *meta_task, const struct starpu_task *template_task, void(*check_ft)(void *))
int starpu_task_submit_nodeps(struct starpu_task *task)
void starpu_task_set_implementation(struct starpu_task *task, unsigned impl)
unsigned starpu_task_get_implementation(struct starpu_task *task)
struct starpu_task * starpu_task_get_current(void)
int starpu_task_wait_for_n_submitted_in_ctx(unsigned sched_ctx_id, unsigned n)
starpu_codelet_type
Definition: starpu_task.h:152
int starpu_task_finished(struct starpu_task *task)
void starpu_task_ft_success(struct starpu_task *meta_task)
int starpu_task_wait_for_all(void)
void starpu_iteration_push(unsigned long iteration)
int starpu_task_submit(struct starpu_task *task)
struct starpu_codelet starpu_codelet_nop
#define STARPU_NMAXBUFS
Definition: starpu_config.h:247
void starpu_task_init(struct starpu_task *task)
int starpu_task_nsubmitted(void)
void(* starpu_max_fpga_func_t)(void **, void *)
Definition: starpu_task.h:211
void(* starpu_hip_func_t)(void **, void *)
Definition: starpu_task.h:201
void starpu_task_clean(struct starpu_task *task)
void starpu_task_set_destroy(struct starpu_task *task)
int starpu_task_wait_for_all_in_ctx(unsigned sched_ctx_id)
struct starpu_task * starpu_task_dup(struct starpu_task *task)
@ STARPU_TASK_BLOCKED_ON_DATA
Definition: starpu_task.h:184
@ STARPU_TASK_READY
Definition: starpu_task.h:179
@ STARPU_TASK_BLOCKED_ON_TAG
Definition: starpu_task.h:182
@ STARPU_TASK_STOPPED
Definition: starpu_task.h:185
@ STARPU_TASK_INIT
Definition: starpu_task.h:175
@ STARPU_TASK_BLOCKED_ON_TASK
Definition: starpu_task.h:183
@ STARPU_TASK_RUNNING
Definition: starpu_task.h:180
@ STARPU_TASK_BLOCKED
Definition: starpu_task.h:178
@ STARPU_TASK_FINISHED
Definition: starpu_task.h:181
@ STARPU_FORKJOIN
Definition: starpu_task.h:162
@ STARPU_SPMD
Definition: starpu_task.h:156
@ STARPU_SEQ
Definition: starpu_task.h:153
Definition: starpu_task.h:339
Definition: starpu_task.h:674
Definition: starpu_task.h:689
starpu_data_access_mode
Definition: starpu_data.h:56
struct _starpu_data_state * starpu_data_handle_t
Definition: starpu_data.h:45
uint64_t starpu_tag_t
Definition: starpu_task_dep.h:134
Definition: starpu_perfmodel.h:193
Definition: starpu_profiling.h:55
#define STARPU_MAXIMPLEMENTATIONS
Definition: starpu_config.h:321
struct _starpu_task_bundle * starpu_task_bundle_t
Definition: starpu_task_bundle.h:39
#define STARPU_ATTRIBUTE_MALLOC
Definition: starpu_util.h:129
void starpu_transaction_close(struct starpu_transaction *p_trs)
struct starpu_transaction * starpu_transaction_open(int(*do_start_func)(void *buffer, void *arg), void *do_start_arg)
void starpu_transaction_next_epoch(struct starpu_transaction *p_trs, void *do_start_arg)
#define STARPU_NMAXWORKERS
Definition: starpu_config.h:305