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