| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286 | /* * This file is part of the StarPU Handbook. * Copyright (C) 2009--2011  Universit@'e de Bordeaux * Copyright (C) 2010, 2011, 2012, 2013, 2014  Centre National de la Recherche Scientifique * Copyright (C) 2011, 2012 Institut National de Recherche en Informatique et Automatique * See the file version.doxy for copying conditions. *//*! \defgroup API_Scheduling_Contexts Scheduling Contexts\brief StarPU permits on one hand grouping workers in combined workersin order to execute a parallel task and on the other hand groupingtasks in bundles that will be executed by a single specified worker.In contrast when we group workers in scheduling contexts we submitstarpu tasks to them and we schedule them with the policy assigned tothe context. Scheduling contexts can be created, deleted and modifieddynamically.\struct starpu_sched_ctx_performance_countersPerformance counters used by the starpu to indicate thehypervisor how the application and the resources are executing.\ingroup API_Scheduling_Contexts\var void (*starpu_sched_ctx_performance_counters::notify_idle_cycle)(unsigned sched_ctx_id, int worker, double idle_time)        Informs the hypervisor for how long a worker has been idle in the specified context\var void (*starpu_sched_ctx_performance_counters::notify_pushed_task)(unsigned sched_ctx_id, int worker)        Notifies the hypervisor that a task has been scheduled on the queue of the worker corresponding to the specified context\var void (*starpu_sched_ctx_performance_counters::notify_poped_task)(unsigned sched_ctx_id, int worker)        Informs the hypervisor that a task executing a specified number of instructions has been poped from the worker\var void (*starpu_sched_ctx_performance_counters::notify_post_exec_task)(struct starpu_task *task, size_t data_size, uint32_t footprint, int hypervisor_tag, double flops)        Notifies the hypervisor that a task has just been executed\var void (*starpu_sched_ctx_performance_counters::notify_submitted_job)(struct starpu_task *task, uint32_t footprint, size_t data_size)        Notifies the hypervisor that a task has just been submitted\var void (*starpu_sched_ctx_performance_counters::notify_delete_context)(unsigned sched_ctx)        Notifies the hypervisor that the context was deleted@name Scheduling Contexts Basic API\ingroup API_Scheduling_Contexts\fn unsigned starpu_sched_ctx_create(int *workerids_ctx, int nworkers_ctx, const char *sched_ctx_name, ...)\ingroup API_Scheduling_ContextsThis function creates a scheduling context with the given parameters(see below) and assigns the workers in \p workerids_ctx to execute thetasks submitted to it. The return value represents the identifier ofthe context that has just been created. It will be further used toindicate the context the tasks will be submitted to. The return valueshould be at most \ref STARPU_NMAX_SCHED_CTXS.The arguments following the name of the scheduling context can be ofthe following types:<ul><li> ::STARPU_SCHED_CTX_POLICY_NAME, followed by the name of apredefined scheduling policy</li><li> ::STARPU_SCHED_CTX_POLICY_STRUCT, followed by a pointer to acustom scheduling policy (struct starpu_sched_policy *)</li><li> ::STARPU_SCHED_CTX_POLICY_MIN_PRIO, followed by a integerrepresenting the minimum priority value to be defined for thescheduling policy.</li><li> ::STARPU_SCHED_CTX_POLICY_MAX_PRIO, followed by a integerrepresenting the maximum priority value to be defined for thescheduling policy.</li></ul>\def STARPU_SCHED_CTX_POLICY_NAME\ingroup API_Scheduling_ContextsThis macro is used when calling starpu_sched_ctx_create() to specify aname for a scheduling policy\def STARPU_SCHED_CTX_POLICY_STRUCT\ingroup API_Scheduling_ContextsThis macro is used when calling starpu_sched_ctx_create() to specify apointer to a scheduling policy\def STARPU_SCHED_CTX_POLICY_MIN_PRIO\ingroup API_Scheduling_ContextsThis macro is used when calling starpu_sched_ctx_create() to specify aminimum scheduler priority value.\def STARPU_SCHED_CTX_POLICY_MAX_PRIO\ingroup API_Scheduling_ContextsThis macro is used when calling starpu_sched_ctx_create() to specify amaximum scheduler priority value.\fn 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)\ingroup API_Scheduling_ContextsCreate a context indicating an approximate interval of resources\fn void starpu_sched_ctx_register_close_callback(unsigned sched_ctx_id, void (*close_callback)(unsigned sched_ctx_id, void* args), void *args)\ingroup API_Scheduling_ContextsExecute the callback whenever the last task of the context finished executing, it is called with the pramaters: sched_ctx and any other paramter neededby the application (packed in a void*)\fn void starpu_sched_ctx_add_workers(int *workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsThis function adds dynamically the workers in \p workerids_ctx to thecontext \p sched_ctx_id. The last argument cannot be greater than\ref STARPU_NMAX_SCHED_CTXS.\fn void starpu_sched_ctx_remove_workers(int *workerids_ctx, int nworkers_ctx, unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsThis function removes the workers in \p workerids_ctx from the context\p sched_ctx_id. The last argument cannot be greater thanSTARPU_NMAX_SCHED_CTXS.\fn void starpu_sched_ctx_display_workers(unsigned sched_ctx_id, FILE *f)\ingroup API_Scheduling_ContextsThis function prints on the file \p f the worker names belonging to the context \p sched_ctx_id\fn void starpu_sched_ctx_delete(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsDelete scheduling context \p sched_ctx_id and transfer remainingworkers to the inheritor scheduling context.\fn void starpu_sched_ctx_set_inheritor(unsigned sched_ctx_id, unsigned inheritor)\ingroup API_Scheduling_ContextsIndicate which context whill inherit the resources of this contextwhen he will be deleted.\fn void starpu_sched_ctx_set_context(unsigned *sched_ctx_id)\ingroup API_Scheduling_ContextsSet the scheduling context the subsequent tasks will be submitted to\fn unsigned starpu_sched_ctx_get_context(void)\ingroup API_Scheduling_ContextsReturn the scheduling context the tasks are currently submitted to,or ::STARPU_NMAX_SCHED_CTXS if no default context has been definedby calling the function starpu_sched_ctx_set_context().\fn void starpu_sched_ctx_stop_task_submission(void)\ingroup API_Scheduling_ContextsStop submitting tasks from the empty context list until the next timethe context has time to check the empty context list\fn void starpu_sched_ctx_finished_submit(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsIndicate starpu that the application finished submitting to thiscontext in order to move the workers to the inheritor as soon aspossible.\fn unsigned starpu_sched_ctx_get_workers_list(unsigned sched_ctx_id, int **workerids)\ingroup API_Scheduling_ContextsReturns the list of workers in the array \p workerids, the returned value is the number of workers. The user should free the \p workerids table after finishingusing it (it is allocated inside the function with the proper size)\fn unsigned starpu_sched_ctx_get_nworkers(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturn the number of workers managed by the specified contexts(Usually needed to verify if it manages any workers or if it should beblocked)\fn unsigned starpu_sched_ctx_get_nshared_workers(unsigned sched_ctx_id, unsigned sched_ctx_id2)\ingroup API_Scheduling_Contexts    Return the number of workers shared by two contexts.\fn unsigned starpu_sched_ctx_contains_worker(int workerid, unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturn 1 if the worker belongs to the context and 0 otherwise\fn unsigned starpu_sched_ctx_worker_get_id(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturn the workerid if the worker belongs to the context and -1 otherwise.If the thread calling this function is not a worker the function returns -1as it calls the function \ref starpu_worker_get_id()\fn unsigned starpu_sched_ctx_overlapping_ctxs_on_worker(int workerid)\ingroup API_Scheduling_ContextsCheck if a worker is shared between several contexts@name Scheduling Context Priorities\ingroup API_Scheduling_Contexts\def STARPU_MIN_PRIO\ingroup API_Scheduling_ContextsProvided for legacy reasons.\def STARPU_MAX_PRIO\ingroup API_Scheduling_ContextsProvided for legacy reasons.\def STARPU_DEFAULT_PRIO\ingroup API_Scheduling_ContextsBy convention, the default priority level should be 0 so that we canstatically allocate tasks with a default priority.\fn int starpu_sched_ctx_set_min_priority(unsigned sched_ctx_id, int min_prio)\ingroup API_Scheduling_ContextsDefines the minimum task priority level supported by the schedulingpolicy of the given scheduler context. The default minimum prioritylevel is the same as the default priority level which is 0 byconvention. The application may access that value by calling the functionstarpu_sched_ctx_get_min_priority(). This function should onlybe called from the initialization method of the scheduling policy, andshould not be used directly from the application.\fn int starpu_sched_ctx_set_max_priority(unsigned sched_ctx_id, int max_prio)\ingroup API_Scheduling_ContextsDefines the maximum priority level supported by the scheduling policyof the given scheduler context. The default maximum priority level is1. The application may access that value by calling thestarpu_sched_ctx_get_max_priority function. This function should onlybe called from the initialization method of the scheduling policy, andshould not be used directly from the application.\fn int starpu_sched_ctx_get_min_priority(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturns the current minimum priority level supported by the schedulingpolicy of the given scheduler context.\fn int starpu_sched_ctx_get_max_priority(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturns the current maximum priority level supported by the schedulingpolicy of the given scheduler context.\fn int starpu_sched_ctx_min_priority_is_set(unsigned sched_ctx_id)\ingroup API_Scheduling_Contextstodo\fn int starpu_sched_ctx_max_priority_is_set(unsigned sched_ctx_id)\ingroup API_Scheduling_Contextstodo@name Scheduling Context Worker Collection\ingroup API_Scheduling_Contexts\fn struct starpu_worker_collection *starpu_sched_ctx_create_worker_collection(unsigned sched_ctx_id, enum starpu_worker_collection_type type)\ingroup API_Scheduling_ContextsCreate a worker collection of the type indicated by the last parameterfor the context specified through the first parameter.\fn void starpu_sched_ctx_delete_worker_collection(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsDelete the worker collection of the specified scheduling context\fn struct starpu_worker_collection *starpu_sched_ctx_get_worker_collection(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturn the worker collection managed by the indicated context@name Scheduling Context Link with Hypervisor\ingroup API_Scheduling_Contexts\fn void starpu_sched_ctx_set_perf_counters(unsigned sched_ctx_id, void *perf_counters)\ingroup API_Scheduling_ContextsIndicates to starpu the pointer to the performance counter\fn void starpu_sched_ctx_call_pushed_task_cb(int workerid, unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsCallback that lets the scheduling policy tell the hypervisor that atask was pushed on a worker\fn void starpu_sched_ctx_notify_hypervisor_exists(void)\ingroup API_Scheduling_ContextsAllow the hypervisor to let starpu know he's initialised\fn unsigned starpu_sched_ctx_check_if_hypervisor_exists(void)\ingroup API_Scheduling_ContextsAsk starpu if he is informed if the hypervisor is initialised\fn void starpu_sched_ctx_set_policy_data(unsigned sched_ctx_id, void *policy_data)\ingroup API_Scheduling_ContextsAllocate the scheduling policy data (private information of the scheduler like queues, variables,additional condition variables) the context\fn void *starpu_sched_ctx_get_policy_data(unsigned sched_ctx_id)\ingroup API_Scheduling_ContextsReturn the scheduling policy data (private information of the scheduler) of the contexts previously assigned to.\fn void *starpu_sched_ctx_exec_parallel_code(void* (*func)(void*), void *param, unsigned sched_ctx_id)\ingroup API_Scheduling_Contextsexecute any parallel code on the workers of the sched_ctx (workers are blocked)\fn int starpu_sched_ctx_get_nready_tasks(unsigned sched_ctx_id)\ingroup API_Scheduling_Contextstodo\fn double starpu_sched_ctx_get_nready_flops(unsigned sched_ctx_id)\ingroup API_Scheduling_Contextstodo*/
 |