StarPU Handbook
starpu_scheduler_toolbox.h
Go to the documentation of this file.
1/* StarPU --- Runtime system for heterogeneous multicore architectures.
2 *
3 * Copyright (C) 2008-2025 University of Bordeaux, CNRS (LaBRI UMR 5800), Inria
4 * Copyright (C) 2016-2016 Uppsala University
5 *
6 * StarPU is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU Lesser General Public License as published by
8 * the Free Software Foundation; either version 2.1 of the License, or (at
9 * your option) any later version.
10 *
11 * StarPU is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
14 *
15 * See the GNU Lesser General Public License in COPYING.LGPL for more details.
16 */
17
18#include <starpu.h>
19
20#ifndef __STARPU_SCHEDULER_TOOLBOX_FIFO_QUEUES_H__
21#define __STARPU_SCHEDULER_TOOLBOX_FIFO_QUEUES_H__
22
23#include <starpu_scheduler.h>
24
25#ifdef __cplusplus
26extern "C" {
27#endif
28
45typedef struct starpu_st_fifo_taskq *starpu_st_fifo_taskq_t;
46
49void starpu_st_fifo_taskq_init(starpu_st_fifo_taskq_t fifo);
50void starpu_st_fifo_taskq_destroy(starpu_st_fifo_taskq_t fifo);
51int starpu_st_fifo_taskq_empty(starpu_st_fifo_taskq_t fifo);
52double starpu_st_fifo_taskq_get_exp_len_prev_task_list(starpu_st_fifo_taskq_t fifo_queue, struct starpu_task *task, int workerid, int nimpl, int *fifo_ntasks);
53
56
59
62
65
68
76
82
85
88
91
94
97
100
103
106
109
110int starpu_st_fifo_taskq_push_sorted_task(starpu_st_fifo_taskq_t fifo_queue, struct starpu_task *task);
111int starpu_st_fifo_taskq_push_task(starpu_st_fifo_taskq_t fifo, struct starpu_task *task);
112int starpu_st_fifo_taskq_push_back_task(starpu_st_fifo_taskq_t fifo_queue, struct starpu_task *task);
113
114int starpu_st_fifo_taskq_pop_this_task(starpu_st_fifo_taskq_t fifo_queue, int workerid, struct starpu_task *task);
115struct starpu_task *starpu_st_fifo_taskq_pop_task(starpu_st_fifo_taskq_t fifo, int workerid);
122
127
131typedef struct starpu_st_prio_deque *starpu_st_prio_deque_t;
132
137void starpu_st_prio_deque_destroy(starpu_st_prio_deque_t pdeque);
140
141int starpu_st_prio_deque_push_back_task(starpu_st_prio_deque_t pdeque, struct starpu_task *task);
144
149struct starpu_task *starpu_st_prio_deque_deque_first_ready_task(starpu_st_prio_deque_t pdeque, unsigned workerid);
150
151struct starpu_task *starpu_st_prio_deque_pop_task(starpu_st_prio_deque_t pdeque);
152struct starpu_task *starpu_st_prio_deque_highest_task(starpu_st_prio_deque_t pdeque);
153struct starpu_task *starpu_st_prio_deque_pop_back_task(starpu_st_prio_deque_t pdeque);
154int starpu_st_prio_deque_pop_this_task(starpu_st_prio_deque_t pdeque, int workerid, struct starpu_task *task);
155
156void starpu_st_prio_deque_erase(starpu_st_prio_deque_t pdeque, struct starpu_task *task);
157
158int starpu_st_normalize_prio(int priority, int num_priorities, unsigned sched_ctx_id);
159int starpu_st_non_ready_buffers_count(struct starpu_task *task, unsigned worker);
160void starpu_st_non_ready_buffers_size(struct starpu_task *task, unsigned worker, size_t *non_readyp, size_t *non_loadingp, size_t *non_allocatedp);
161
164#ifdef __cplusplus
165}
166#endif
167
168#endif /* __STARPU_SCHEDULER_TOOLBOX_FIFO_QUEUES_H__ */
unsigned workerid
Definition: starpu_task.h:1228
int priority
Definition: starpu_task.h:1292
Definition: starpu_task.h:689
double starpu_st_fifo_exp_start_get(starpu_st_fifo_taskq_t fifo)
double starpu_st_fifo_exp_end_get(starpu_st_fifo_taskq_t fifo)
int starpu_st_prio_deque_is_empty(starpu_st_prio_deque_t pdeque)
void starpu_st_prio_deque_init(starpu_st_prio_deque_t pdeque)
void starpu_st_fifo_exp_len_set(starpu_st_fifo_taskq_t fifo, double exp_len)
struct starpu_task * starpu_st_prio_deque_pop_task_for_worker(starpu_st_prio_deque_t pdeque, int workerid, struct starpu_task **skipped)
void starpu_st_fifo_pipeline_len_inc(starpu_st_fifo_taskq_t fifo, double pipeline_len)
double starpu_st_fifo_pipeline_len_get(starpu_st_fifo_taskq_t fifo)
struct starpu_st_prio_deque * starpu_st_prio_deque_t
Definition: starpu_scheduler_toolbox.h:131
void starpu_st_fifo_exp_len_inc(starpu_st_fifo_taskq_t fifo, double exp_len)
struct starpu_task * starpu_st_fifo_taskq_pop_first_ready_task(starpu_st_fifo_taskq_t fifo_queue, unsigned workerid, int num_priorities)
int starpu_st_prio_deque_push_front_task(starpu_st_prio_deque_t pdeque, struct starpu_task *task)
unsigned starpu_st_fifo_ntasks_get(starpu_st_fifo_taskq_t fifo)
starpu_st_fifo_taskq_t starpu_st_fifo_taskq_create(void) STARPU_ATTRIBUTE_MALLOC
void starpu_st_fifo_exp_start_set(starpu_st_fifo_taskq_t fifo, double exp_start)
struct starpu_st_fifo_taskq * starpu_st_fifo_taskq_t
Definition: starpu_scheduler_toolbox.h:45
void starpu_st_fifo_pipeline_len_set(starpu_st_fifo_taskq_t fifo, double pipeline_len)
void starpu_st_fifo_exp_end_set(starpu_st_fifo_taskq_t fifo, double exp_end)
double * starpu_st_fifo_exp_len_per_priority_get(starpu_st_fifo_taskq_t fifo)
unsigned * starpu_st_fifo_ntasks_per_priority_get(starpu_st_fifo_taskq_t fifo)
struct starpu_task * starpu_st_prio_deque_deque_task_for_worker(starpu_st_prio_deque_t pdeque, int workerid, struct starpu_task **skipped)
void starpu_st_fifo_nprocessed_inc(starpu_st_fifo_taskq_t fifo, int n)
struct starpu_task * starpu_st_fifo_taskq_pop_local_task(starpu_st_fifo_taskq_t fifo)
unsigned starpu_st_fifo_nprocessed_get(starpu_st_fifo_taskq_t fifo)
void starpu_st_fifo_ntasks_inc(starpu_st_fifo_taskq_t fifo, int n)
double starpu_st_fifo_exp_len_get(starpu_st_fifo_taskq_t fifo)
#define STARPU_ATTRIBUTE_MALLOC
Definition: starpu_util.h:129