Merge branches 'pm-cpuidle', 'pm-cpufreq' and 'pm-cpufreq-sched'
[linux-2.6-block.git] / Documentation / cpu-freq / cpufreq-stats.txt
CommitLineData
21e3024c 1
53cb4726 2 CPU frequency and voltage scaling statistics in the Linux(TM) kernel
21e3024c
VP
3
4
5 L i n u x c p u f r e q - s t a t s d r i v e r
6
7 - information for users -
8
9
10 Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
11
12Contents
131. Introduction
142. Statistics Provided (with example)
153. Configuring cpufreq-stats
16
17
181. Introduction
19
a982ac06 20cpufreq-stats is a driver that provides CPU frequency statistics for each CPU.
53cb4726
ML
21These statistics are provided in /sysfs as a bunch of read_only interfaces. This
22interface (when configured) will appear in a separate directory under cpufreq
21e3024c
VP
23in /sysfs (<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/) for each CPU.
24Various statistics will form read_only files under this directory.
25
26This driver is designed to be independent of any particular cpufreq_driver
27that may be running on your CPU. So, it will work with any cpufreq_driver.
28
29
302. Statistics Provided (with example)
31
32cpufreq stats provides following statistics (explained in detail below).
33- time_in_state
34- total_trans
35- trans_table
36
7de962c0
VK
37All the statistics will be from the time the stats driver has been inserted
38(or the time the stats were reset) to the time when a read of a particular
39statistic is done. Obviously, stats driver will not have any information
40about the frequency transitions before the stats driver insertion.
21e3024c
VP
41
42--------------------------------------------------------------------------------
43<mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l
44total 0
45drwxr-xr-x 2 root root 0 May 14 16:06 .
46drwxr-xr-x 3 root root 0 May 14 15:58 ..
ee7930ee 47--w------- 1 root root 4096 May 14 16:06 reset
21e3024c
VP
48-r--r--r-- 1 root root 4096 May 14 16:06 time_in_state
49-r--r--r-- 1 root root 4096 May 14 16:06 total_trans
50-r--r--r-- 1 root root 4096 May 14 16:06 trans_table
51--------------------------------------------------------------------------------
52
ee7930ee
MM
53- reset
54Write-only attribute that can be used to reset the stat counters. This can be
55useful for evaluating system behaviour under different governors without the
56need for a reboot.
57
21e3024c
VP
58- time_in_state
59This gives the amount of time spent in each of the frequencies supported by
60this CPU. The cat output will have "<frequency> <time>" pair in each line, which
61will mean this CPU spent <time> usertime units of time at <frequency>. Output
a2ffd275 62will have one line for each of the supported frequencies. usertime units here
21e3024c
VP
63is 10mS (similar to other time exported in /proc).
64
65--------------------------------------------------------------------------------
66<mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state
673600000 2089
683400000 136
693200000 34
703000000 67
712800000 172488
72--------------------------------------------------------------------------------
73
74
75- total_trans
76This gives the total number of frequency transitions on this CPU. The cat
77output will have a single count which is the total number of frequency
78transitions.
79
80--------------------------------------------------------------------------------
81<mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans
8220
83--------------------------------------------------------------------------------
84
85- trans_table
86This will give a fine grained information about all the CPU frequency
87transitions. The cat output here is a two dimensional matrix, where an entry
88<i,j> (row i, column j) represents the count of number of transitions from
8d72ee32
VK
89Freq_i to Freq_j. Freq_i rows and Freq_j columns follow the sorting order in
90which the driver has provided the frequency table initially to the cpufreq core
91and so can be sorted (ascending or descending) or unsorted. The output here
92also contains the actual freq values for each row and column for better
93readability.
21e3024c 94
f7bc9b20
GS
95If the transition table is bigger than PAGE_SIZE, reading this will
96return an -EFBIG error.
97
21e3024c
VP
98--------------------------------------------------------------------------------
99<mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table
100 From : To
101 : 3600000 3400000 3200000 3000000 2800000
102 3600000: 0 5 0 0 0
103 3400000: 4 0 2 0 0
104 3200000: 0 1 0 2 0
105 3000000: 0 0 1 0 3
106 2800000: 0 0 0 2 0
107--------------------------------------------------------------------------------
108
109
1103. Configuring cpufreq-stats
111
112To configure cpufreq-stats in your kernel
113Config Main Menu
114 Power management options (ACPI, APM) --->
115 CPU Frequency scaling --->
116 [*] CPU Frequency scaling
3732b30a 117 [*] CPU frequency translation statistics
21e3024c
VP
118
119
120"CPU Frequency scaling" (CONFIG_CPU_FREQ) should be enabled to configure
121cpufreq-stats.
122
123"CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT) provides the
7de962c0 124statistics which includes time_in_state, total_trans and trans_table.
21e3024c 125
7de962c0 126Once this option is enabled and your CPU supports cpufrequency, you
21e3024c 127will be able to see the CPU frequency statistics in /sysfs.