xref: /linux/Documentation/translations/zh_TW/cpu-freq/cpufreq-stats.rst (revision be239684b18e1cdcafcf8c7face4a2f562c745ad)
1.. SPDX-License-Identifier: GPL-2.0
2
3.. include:: ../disclaimer-zh_TW.rst
4
5:Original: Documentation/cpu-freq/cpufreq-stats.rst
6
7:翻譯:
8
9 司延騰 Yanteng Si <siyanteng@loongson.cn>
10
11:校譯:
12
13 唐藝舟 Tang Yizhou <tangyeechou@gmail.com>
14
15==========================================
16sysfs CPUFreq Stats的一般說明
17==========================================
18
19爲使用者準備的信息
20
21
22作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
23
24.. Contents
25
26   1. 簡介
27   2. 提供的統計數據(舉例說明)
28   3. 配置cpufreq-stats
29
30
311. 簡介
32===============
33
34cpufreq-stats是一種爲每個CPU提供CPU頻率統計的驅動。
35這些統計數據以/sysfs中一系列只讀接口的形式呈現。cpufreq-stats接口(若已配置)將爲每個CPU生成
36/sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq目錄下的stats目錄。
37各項統計數據將在stats目錄下形成對應的只讀文件。
38
39此驅動是以獨立於任何可能運行在你所用CPU上的特定cpufreq_driver的方式設計的。因此,它將能和任何
40cpufreq_driver協同工作。
41
42
432. 已提供的統計數據(有例子)
44=====================================
45
46cpufreq stats提供了以下統計數據(在下面詳細解釋)。
47
48-  time_in_state
49-  total_trans
50-  trans_table
51
52所有統計數據來自以下時間範圍:從統計驅動被加載的時間(或統計數據被重置的時間)開始,到某一統計數據被讀取的時間爲止。
53顯然,統計驅動不會保存它被加載之前的任何頻率轉換信息。
54
55::
56
57    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l
58    total 0
59    drwxr-xr-x  2 root root    0 May 14 16:06 .
60    drwxr-xr-x  3 root root    0 May 14 15:58 ..
61    --w-------  1 root root 4096 May 14 16:06 reset
62    -r--r--r--  1 root root 4096 May 14 16:06 time_in_state
63    -r--r--r--  1 root root 4096 May 14 16:06 total_trans
64    -r--r--r--  1 root root 4096 May 14 16:06 trans_table
65
66- **reset**
67
68只寫屬性,可用於重置統計計數器。這對於評估不同調節器的系統行爲非常有用,且無需重啓。
69
70
71- **time_in_state**
72
73此文件給出了在本CPU支持的每個頻率上分別花費的時間。cat輸出的每一行都是一個"<frequency>
74<time>"對,表示這個CPU在<frequency>上花費了<time>個usertime單位的時間。輸出的每一行對應
75一個CPU支持的頻率。這裏usertime單位是10mS(類似於/proc導出的其它時間)。
76
77::
78
79    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state
80    3600000 2089
81    3400000 136
82    3200000 34
83    3000000 67
84    2800000 172488
85
86
87- **total_trans**
88
89此文件給出了這個CPU頻率轉換的總次數。cat的輸出是一個計數值,它就是頻率轉換的總次數。
90
91::
92
93    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans
94    20
95
96- **trans_table**
97
98本文件提供所有CPU頻率轉換的細粒度信息。這裏的cat輸出是一個二維矩陣,其中一個條目<i, j>(第
99i行,第j列)代表從Freq_i到Freq_j的轉換次數。Freq_i行和Freq_j列遵循驅動最初提供給cpufreq
100核心的頻率表的排列順序,因此可以已排序(升序或降序)或未排序。這裏的輸出也包含了實際
101頻率值,分別按行和按列顯示,以便更好地閱讀。
102
103如果轉換表大於PAGE_SIZE,讀取時將返回一個-EFBIG錯誤。
104
105::
106
107    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table
108    From  :    To
109	    :   3600000   3400000   3200000   3000000   2800000
110    3600000:         0         5         0         0         0
111    3400000:         4         0         2         0         0
112    3200000:         0         1         0         2         0
113    3000000:         0         0         1         0         3
114    2800000:         0         0         0         2         0
115
1163. 配置cpufreq-stats
117============================
118
119按以下方式在你的內核中配置cpufreq-stats::
120
121	Config Main Menu
122		Power management options (ACPI, APM)  --->
123			CPU Frequency scaling  --->
124				[*] CPU Frequency scaling
125				[*]   CPU frequency translation statistics
126
127
128"CPU Frequency scaling" (CONFIG_CPU_FREQ) 應該被啓用,以支持配置cpufreq-stats。
129
130"CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括
131time_in_state、total_trans和trans_table的統計數據。
132
133一旦啓用了這個選項,並且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU頻率統計。
134
135