StarPU Handbook
starpu_sched_ctx_hypervisor.h
Go to the documentation of this file.
1 /* StarPU --- Runtime system for heterogeneous multicore architectures.
2  *
3  * Copyright (C) 2010-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
4  *
5  * StarPU is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU Lesser General Public License as published by
7  * the Free Software Foundation; either version 2.1 of the License, or (at
8  * your option) any later version.
9  *
10  * StarPU is distributed in the hope that it will be useful, but
11  * WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
13  *
14  * See the GNU Lesser General Public License in COPYING.LGPL for more details.
15  */
16 
17 #ifndef __STARPU_SCHED_CTX_HYPERVISOR_H__
18 #define __STARPU_SCHED_CTX_HYPERVISOR_H__
19 
20 #ifdef __cplusplus
21 extern "C" {
22 #endif
23 
39 {
44  void (*notify_idle_cycle)(unsigned sched_ctx_id, int worker, double idle_time);
45 
50  void (*notify_poped_task)(unsigned sched_ctx_id, int worker);
51 
57  void (*notify_pushed_task)(unsigned sched_ctx_id, int worker);
58 
62  void (*notify_post_exec_task)(struct starpu_task *task, size_t data_size, uint32_t footprint, int hypervisor_tag, double flops);
63 
67  void (*notify_submitted_job)(struct starpu_task *task, uint32_t footprint, size_t data_size);
68 
69  void (*notify_empty_ctx)(unsigned sched_ctx_id, struct starpu_task *task);
70 
74  void (*notify_delete_context)(unsigned sched_ctx);
75 };
76 
80 void starpu_sched_ctx_set_perf_counters(unsigned sched_ctx_id, void *perf_counters);
81 
86 void starpu_sched_ctx_call_pushed_task_cb(int workerid, unsigned sched_ctx_id);
87 
92 
97 
98 void starpu_sched_ctx_update_start_resizing_sample(unsigned sched_ctx_id, double start_sample);
99 
104 #ifdef __cplusplus
105 }
106 #endif
107 
108 #endif /* __STARPU_SCHED_CTX_HYPERVISOR_H__ */
unsigned sched_ctx
Definition: starpu_task.h:1293
int hypervisor_tag
Definition: starpu_task.h:1301
unsigned workerid
Definition: starpu_task.h:1186
double flops
Definition: starpu_task.h:1338
Definition: starpu_task.h:662
void starpu_sched_ctx_call_pushed_task_cb(int workerid, unsigned sched_ctx_id)
unsigned starpu_sched_ctx_check_if_hypervisor_exists(void)
void starpu_sched_ctx_notify_hypervisor_exists(void)
void starpu_sched_ctx_set_perf_counters(unsigned sched_ctx_id, void *perf_counters)
Definition: starpu_sched_ctx_hypervisor.h:39
void(* notify_poped_task)(unsigned sched_ctx_id, int worker)
Definition: starpu_sched_ctx_hypervisor.h:50
void(* notify_post_exec_task)(struct starpu_task *task, size_t data_size, uint32_t footprint, int hypervisor_tag, double flops)
Definition: starpu_sched_ctx_hypervisor.h:62
void(* notify_pushed_task)(unsigned sched_ctx_id, int worker)
Definition: starpu_sched_ctx_hypervisor.h:57
void(* notify_delete_context)(unsigned sched_ctx)
Definition: starpu_sched_ctx_hypervisor.h:74
void(* notify_idle_cycle)(unsigned sched_ctx_id, int worker, double idle_time)
Definition: starpu_sched_ctx_hypervisor.h:44
void(* notify_submitted_job)(struct starpu_task *task, uint32_t footprint, size_t data_size)
Definition: starpu_sched_ctx_hypervisor.h:67