| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 | /* * This file is part of the StarPU Handbook. * Copyright (C) 2009--2011  Universit@'e de Bordeaux 1 * Copyright (C) 2010, 2011, 2012, 2013  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_Profiling Profiling\struct starpu_profiling_task_info\ingroup API_ProfilingThis structure contains information about the execution of atask. It is accessible from the field starpu_task::profiling_info ifprofiling was enabled.\var starpu_profiling_task_info::submit_timeDate of task submission (relative to the initialization of StarPU).\var starpu_profiling_task_info::push_start_timeTime when the task was submitted to the scheduler.\var starpu_profiling_task_info::push_end_timeTime when the scheduler finished with the task submission.\var starpu_profiling_task_info::pop_start_timeTime when the scheduler started to be requested for a task, and eventually gave that task.\var starpu_profiling_task_info::pop_end_timeTime when the scheduler finished providing the task for execution.\var starpu_profiling_task_info::acquire_data_start_timeTime when the worker started fetching input data.\var starpu_profiling_task_info::acquire_data_end_timeTime when the worker finished fetching input data.\var starpu_profiling_task_info::start_timeDate of task execution beginning (relative to the initialization of StarPU).\var starpu_profiling_task_info::end_timeDate of task execution termination (relative to the initialization of StarPU).\var starpu_profiling_task_info::release_data_start_timeTime when the worker started releasing data.\var starpu_profiling_task_info::release_data_end_timeTime when the worker finished releasing data.\var starpu_profiling_task_info::callback_start_time        Time when the worker started the application callback for the task.\var starpu_profiling_task_info::callback_end_time        Time when the worker finished the application callback for the task.\var starpu_profiling_task_info::workerid        Identifier of the worker which has executed the task.\var starpu_profiling_task_info::used_cycles        Number of cycles used by the task, only available in the MoviSim\var starpu_profiling_task_info::stall_cycles        Number of cycles stalled within the task, only available in the MoviSim\var starpu_profiling_task_info::power_consumed        Power consumed by the task, only available in the MoviSim\struct starpu_profiling_worker_infoThis structure contains the profiling information associated toa worker. The timing is provided since the previous call tostarpu_profiling_worker_get_info()\ingroup API_Profiling\var starpu_profiling_worker_info::start_time        Starting date for the reported profiling measurements.\var starpu_profiling_worker_info::total_time        Duration of the profiling measurement interval.\var starpu_profiling_worker_info::executing_time        Time spent by the worker to execute tasks during the profiling measurement interval.\var starpu_profiling_worker_info::sleeping_time        Time spent idling by the worker during the profiling measurement interval.\var starpu_profiling_worker_info::executed_tasks        Number of tasks executed by the worker during the profiling measurement interval.\var starpu_profiling_worker_info::used_cycles        Number of cycles used by the worker, only available in the MoviSim\var starpu_profiling_worker_info::stall_cycles        Number of cycles stalled within the worker, only available in the MoviSim\var starpu_profiling_worker_info::power_consumed        Power consumed by the worker, only available in the MoviSim\struct starpu_profiling_bus_infotodo\ingroup API_Profiling\var starpu_profiling_bus_info::start_time        Time of bus profiling startup.\var starpu_profiling_bus_info::total_time        Total time of bus profiling.\var starpu_profiling_bus_info::transferred_bytes        Number of bytes transferred during profiling.\var starpu_profiling_bus_info::transfer_count        Number of transfers during profiling.\typedef STARPU_PROFILING_DISABLE\ingroup API_ProfilingThis value is used when calling the functionstarpu_profiling_status_set() to disable profiling.\typedef STARPU_PROFILING_ENABLE\ingroup API_ProfilingThis value is used when calling the functionstarpu_profiling_status_set() to enable profiling.\fn int starpu_profiling_status_set(int status)\ingroup API_ProfilingThis function sets the profiling status. Profiling is activatedby passing \ref STARPU_PROFILING_ENABLE in status. Passing\ref STARPU_PROFILING_DISABLE disables profiling. Calling this functionresets all profiling measurements. When profiling is enabled, thefield starpu_task::profiling_info points to a valid structurestarpu_profiling_task_info containing information about the executionof the task. Negative return values indicate an error, otherwise theprevious status is returned.\fn int starpu_profiling_status_get(void)\ingroup API_ProfilingReturn the current profiling status or a negative value in casethere was an error.\fn void starpu_profiling_init(void)\ingroup API_ProfilingThis function resets performance counters and enable profiling if theenvironment variable \ref STARPU_PROFILING is set to a positive value.\fn void starpu_profiling_set_id(int new_id)\ingroup API_ProfilingThis function sets the ID used for profiling trace filename. Itneeds to be called before starpu_init().\fn int starpu_profiling_worker_get_info(int workerid, struct starpu_profiling_worker_info *worker_info)\ingroup API_ProfilingGet the profiling info associated to the worker identified by\p workerid, and reset the profiling measurements. If the argument \pworker_info is NULL, only reset the counters associated to worker\p workerid. Upon successful completion, this function returns 0.Otherwise, a negative value is returned.\fn int starpu_bus_get_profiling_info(int busid, struct starpu_profiling_bus_info *bus_info)\ingroup API_Profilingtodo\fn int starpu_bus_get_count(void)\ingroup API_ProfilingReturn the number of buses in the machine\fn int starpu_bus_get_id(int src, int dst)\ingroup API_ProfilingReturn the identifier of the bus between \p src and \p dst\fn int starpu_bus_get_src(int busid)\ingroup API_ProfilingReturn the source point of bus \p busid\fn int starpu_bus_get_dst(int busid)\ingroup API_ProfilingReturn the destination point of bus \p busid\fn double starpu_timing_timespec_delay_us(struct timespec *start, struct timespec *end)\ingroup API_ProfilingReturns the time elapsed between \p start and \p end in microseconds.\fn double starpu_timing_timespec_to_us(struct timespec *ts)\ingroup API_ProfilingConverts the given timespec \p ts into microseconds\fn void starpu_profiling_bus_helper_display_summary(void)\ingroup API_ProfilingDisplays statistics about the bus on stderr. if the environmentvariable \ref STARPU_BUS_STATS is defined. The function is calledautomatically by starpu_shutdown().\fn void starpu_profiling_worker_helper_display_summary(void)\ingroup API_ProfilingDisplays statistics about the workers on stderr if theenvironment variable \ref STARPU_WORKER_STATS is defined. The function iscalled automatically by starpu_shutdown().\fn void starpu_data_display_memory_stats()\ingroup API_ProfilingDisplay statistics about the current data handles registeredwithin StarPU. StarPU must have been configured with the configureoption \ref enable-memory-stats "--enable-memory-stats" (see \ref MemoryFeedback).*/
 |