| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 | /* StarPU --- Runtime system for heterogeneous multicore architectures. * * Copyright (C) 2010 - 2012  INRIA * * StarPU is free software; you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation; either version 2.1 of the License, or (at * your option) any later version. * * StarPU is distributed in the hope that it will be useful, but * WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU Lesser General Public License in COPYING.LGPL for more details. */#ifndef __STARPU_SCHED_CTX_H__#define __STARPU_SCHED_CTX_H__#include <starpu.h>#ifdef __cplusplusextern "C"{#endif#define STARPU_SCHED_CTX_POLICY_NAME		 (1<<16)#define STARPU_SCHED_CTX_POLICY_STRUCT		 (2<<16)#define STARPU_SCHED_CTX_POLICY_MIN_PRIO	 (3<<16)#define STARPU_SCHED_CTX_POLICY_MAX_PRIO	 (4<<16)#define STARPU_SCHED_CTX_HIERARCHY_LEVEL         (5<<16)#define STARPU_SCHED_CTX_NESTED                  (6<<16)#define STARPU_SCHED_CTX_AWAKE_WORKERS           (7<<16)#define STARPU_SCHED_CTX_POLICY_INIT             (8<<16)unsigned starpu_sched_ctx_create(int *workerids_ctx, int nworkers_ctx, const char *sched_ctx_name, ...);unsigned starpu_sched_ctx_create_inside_interval(const char *policy_name, const char *sched_ctx_name, int min_ncpus, int max_ncpus, int min_ngpus, int max_ngpus, unsigned allow_overlap);void starpu_sched_ctx_register_close_callback(unsigned sched_ctx_id, void (*close_callback)(unsigned sched_ctx_id, void* args), void *args);void starpu_sched_ctx_add_workers(int *workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id);void starpu_sched_ctx_remove_workers(int *workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id);void starpu_sched_ctx_display_workers(unsigned sched_ctx_id, FILE *f);void starpu_sched_ctx_delete(unsigned sched_ctx_id);void starpu_sched_ctx_set_inheritor(unsigned sched_ctx_id, unsigned inheritor);unsigned starpu_sched_ctx_get_inheritor(unsigned sched_ctx_id);unsigned starpu_sched_ctx_get_hierarchy_level(unsigned sched_ctx_id);void starpu_sched_ctx_set_context(unsigned *sched_ctx_id);unsigned starpu_sched_ctx_get_context(void);void starpu_sched_ctx_stop_task_submission(void);void starpu_sched_ctx_finished_submit(unsigned sched_ctx_id);unsigned starpu_sched_ctx_get_workers_list(unsigned sched_ctx_id, int **workerids);unsigned starpu_sched_ctx_get_nworkers(unsigned sched_ctx_id);unsigned starpu_sched_ctx_get_nshared_workers(unsigned sched_ctx_id, unsigned sched_ctx_id2);unsigned starpu_sched_ctx_contains_worker(int workerid, unsigned sched_ctx_id);unsigned starpu_sched_ctx_contains_type_of_worker(enum starpu_worker_archtype arch, unsigned sched_ctx_id);unsigned starpu_sched_ctx_worker_get_id(unsigned sched_ctx_id);unsigned starpu_sched_ctx_get_ctx_for_task(struct starpu_task *task);unsigned starpu_sched_ctx_overlapping_ctxs_on_worker(int workerid);int starpu_sched_get_min_priority(void);int starpu_sched_get_max_priority(void);int starpu_sched_set_min_priority(int min_prio);int starpu_sched_set_max_priority(int max_prio);int starpu_sched_ctx_get_min_priority(unsigned sched_ctx_id);int starpu_sched_ctx_get_max_priority(unsigned sched_ctx_id);int starpu_sched_ctx_set_min_priority(unsigned sched_ctx_id, int min_prio);int starpu_sched_ctx_set_max_priority(unsigned sched_ctx_id, int max_prio);int starpu_sched_ctx_min_priority_is_set(unsigned sched_ctx_id);int starpu_sched_ctx_max_priority_is_set(unsigned sched_ctx_id);#define STARPU_MIN_PRIO		(starpu_sched_get_min_priority())#define STARPU_MAX_PRIO		(starpu_sched_get_max_priority())#define STARPU_DEFAULT_PRIO	0struct starpu_worker_collection *starpu_sched_ctx_create_worker_collection(unsigned sched_ctx_id, enum starpu_worker_collection_type type) STARPU_ATTRIBUTE_MALLOC;void starpu_sched_ctx_delete_worker_collection(unsigned sched_ctx_id);struct starpu_worker_collection *starpu_sched_ctx_get_worker_collection(unsigned sched_ctx_id);void starpu_sched_ctx_set_policy_data(unsigned sched_ctx_id, void *policy_data);void *starpu_sched_ctx_get_policy_data(unsigned sched_ctx_id);void *starpu_sched_ctx_exec_parallel_code(void* (*func)(void*), void *param, unsigned sched_ctx_id);int starpu_sched_ctx_get_nready_tasks(unsigned sched_ctx_id);double starpu_sched_ctx_get_nready_flops(unsigned sched_ctx_id);void starpu_sched_ctx_list_task_counters_increment(unsigned sched_ctx_id, int workerid);void starpu_sched_ctx_list_task_counters_decrement(unsigned sched_ctx_id, int workerid);void starpu_sched_ctx_list_task_counters_reset(unsigned sched_ctx_id, int workerid);void starpu_sched_ctx_list_task_counters_increment_all(struct starpu_task *task, unsigned sched_ctx_id);void starpu_sched_ctx_list_task_counters_decrement_all(struct starpu_task *task, unsigned sched_ctx_id);void starpu_sched_ctx_list_task_counters_reset_all(struct starpu_task *task, unsigned sched_ctx_id);void starpu_sched_ctx_set_priority(int *workers, int nworkers, unsigned sched_ctx_id, unsigned priority);void starpu_sched_ctx_set_priority_on_level(int* workers_to_add, unsigned nworkers_to_add, unsigned sched_ctx, unsigned priority);unsigned starpu_sched_ctx_get_priority(int worker, unsigned sched_ctx_id);void starpu_sched_ctx_get_available_cpuids(unsigned sched_ctx_id, int **cpuids, int *ncpuids);void starpu_sched_ctx_bind_current_thread_to_cpuid(unsigned cpuid);int starpu_sched_ctx_book_workers_for_task(unsigned sched_ctx_id, int *workerids, int nworkers);void starpu_sched_ctx_unbook_workers_for_task(unsigned sched_ctx_id, int master);/* return the first context (child of sched_ctx_id) where the workerid is master */unsigned starpu_sched_ctx_worker_is_master_for_child_ctx(int workerid, unsigned sched_ctx_id);/* Returns the context id of masterid if it master of a context. *//* If not, returns STARPU_NMAX_SCHED_CTXS. */unsigned starpu_sched_ctx_master_get_context(int masterid);void starpu_sched_ctx_revert_task_counters(unsigned sched_ctx_id, double flops);void starpu_sched_ctx_move_task_to_ctx(struct starpu_task *task, unsigned sched_ctx, unsigned manage_mutex);int starpu_sched_ctx_get_worker_rank(unsigned sched_ctx_id);void (*starpu_sched_ctx_get_sched_policy_init(unsigned sched_ctx_id))(void);unsigned starpu_sched_ctx_has_starpu_scheduler(unsigned sched_ctx_id, unsigned *awake_workers);#ifdef STARPU_USE_SC_HYPERVISORvoid starpu_sched_ctx_call_pushed_task_cb(int workerid, unsigned sched_ctx_id);#endif /* STARPU_USE_SC_HYPERVISOR */#ifdef __cplusplus}#endif#endif /* __STARPU_SCHED_CTX_H__ */
 |