1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374 |
- timer_stats - timer usage statistics
- ------------------------------------
- timer_stats is a debugging facility to make the timer (ab)usage in a Linux
- system visible to kernel and userspace developers. If enabled in the config
- but not used it has almost zero runtime overhead, and a relatively small
- data structure overhead. Even if collection is enabled runtime all the
- locking is per-CPU and lookup is hashed.
- timer_stats should be used by kernel and userspace developers to verify that
- their code does not make unduly use of timers. This helps to avoid unnecessary
- wakeups, which should be avoided to optimize power consumption.
- It can be enabled by CONFIG_TIMER_STATS in the "Kernel hacking" configuration
- section.
- timer_stats collects information about the timer events which are fired in a
- Linux system over a sample period:
- - the pid of the task(process) which initialized the timer
- - the name of the process which initialized the timer
- - the function where the timer was initialized
- - the callback function which is associated to the timer
- - the number of events (callbacks)
- timer_stats adds an entry to /proc: /proc/timer_stats
- This entry is used to control the statistics functionality and to read out the
- sampled information.
- The timer_stats functionality is inactive on bootup.
- To activate a sample period issue:
- # echo 1 >/proc/timer_stats
- To stop a sample period issue:
- # echo 0 >/proc/timer_stats
- The statistics can be retrieved by:
- # cat /proc/timer_stats
- While sampling is enabled, each readout from /proc/timer_stats will see
- newly updated statistics. Once sampling is disabled, the sampled information
- is kept until a new sample period is started. This allows multiple readouts.
- Sample output of /proc/timer_stats:
- Timerstats sample period: 3.888770 s
- 12, 0 swapper hrtimer_stop_sched_tick (hrtimer_sched_tick)
- 15, 1 swapper hcd_submit_urb (rh_timer_func)
- 4, 959 kedac schedule_timeout (process_timeout)
- 1, 0 swapper page_writeback_init (wb_timer_fn)
- 28, 0 swapper hrtimer_stop_sched_tick (hrtimer_sched_tick)
- 22, 2948 IRQ 4 tty_flip_buffer_push (delayed_work_timer_fn)
- 3, 3100 bash schedule_timeout (process_timeout)
- 1, 1 swapper queue_delayed_work_on (delayed_work_timer_fn)
- 1, 1 swapper queue_delayed_work_on (delayed_work_timer_fn)
- 1, 1 swapper neigh_table_init_no_netlink (neigh_periodic_timer)
- 1, 2292 ip __netdev_watchdog_up (dev_watchdog)
- 1, 23 events/1 do_cache_clean (delayed_work_timer_fn)
- 90 total events, 30.0 events/sec
- The first column is the number of events, the second column the pid, the third
- column is the name of the process. The forth column shows the function which
- initialized the timer and in parenthesis the callback function which was
- executed on expiry.
- Thomas, Ingo
- Added flag to indicate 'deferrable timer' in /proc/timer_stats. A deferrable
- timer will appear as follows
- 10D, 1 swapper queue_delayed_work_on (delayed_work_timer_fn)
|