StarPU Handbook
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
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 - 2012 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 {
23 #endif
24 
25 
26 
28 {
29  void (*notify_idle_cycle)(unsigned sched_ctx_id, int worker, double idle_time);
30  void (*notify_poped_task)(unsigned sched_ctx_id, int worker);
31  void (*notify_pushed_task)(unsigned sched_ctx_id, int worker);
32  void (*notify_post_exec_task)(struct starpu_task *task, size_t data_size, uint32_t footprint, int hypervisor_tag, double flops);
33  void (*notify_submitted_job)(struct starpu_task *task, uint32_t footprint, size_t data_size);
34  void (*notify_empty_ctx)(unsigned sched_ctx_id, struct starpu_task *task);
35  void (*notify_delete_context)(unsigned sched_ctx);
36 };
37 
38 #ifdef STARPU_USE_SC_HYPERVISOR
39 void starpu_sched_ctx_set_perf_counters(unsigned sched_ctx_id, void *perf_counters);
40 #endif //STARPU_USE_SC_HYPERVISOR
41 
43 
45 
46 #ifdef __cplusplus
47 }
48 #endif
49 
50 #endif /* __STARPU_SCHED_CTX_HYPERVISOR_H__ */
void(* notify_delete_context)(unsigned sched_ctx)
Definition: starpu_sched_ctx_hypervisor.h:35
void(* notify_pushed_task)(unsigned sched_ctx_id, int worker)
Definition: starpu_sched_ctx_hypervisor.h:31
unsigned sched_ctx
Definition: starpu_task.h:183
unsigned starpu_sched_ctx_check_if_hypervisor_exists(void)
Definition: starpu_task.h:123
void(* notify_submitted_job)(struct starpu_task *task, uint32_t footprint, size_t data_size)
Definition: starpu_sched_ctx_hypervisor.h:33
void starpu_sched_ctx_set_perf_counters(unsigned sched_ctx_id, void *perf_counters)
void(* notify_idle_cycle)(unsigned sched_ctx_id, int worker, double idle_time)
Definition: starpu_sched_ctx_hypervisor.h:29
Definition: starpu_sched_ctx_hypervisor.h:27
void starpu_sched_ctx_notify_hypervisor_exists(void)
void(* notify_poped_task)(unsigned sched_ctx_id, int worker)
Definition: starpu_sched_ctx_hypervisor.h:30
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:32
double flops
Definition: starpu_task.h:191
int hypervisor_tag
Definition: starpu_task.h:184