Back to home page

OSCL-LXR

 
 

    


0001 .. SPDX-License-Identifier: GPL-2.0
0002 
0003 .. include:: ../disclaimer-zh_TW.rst
0004 
0005 :Original: :doc:`../../../cpu-freq/cpufreq-stats`
0006 :Translator: Yanteng Si <siyanteng@loongson.cn>
0007              Hu Haowen <src.res@email.cn>
0008 
0009 .. _tw_cpufreq-stats.rst:
0010 
0011 
0012 ==========================================
0013 sysfs CPUFreq Stats的一般說明
0014 ==========================================
0015 
0016 用戶信息
0017 
0018 
0019 作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
0020 
0021 .. Contents
0022 
0023    1. 簡介
0024    2. 提供的統計數據(舉例說明)
0025    3. 配置cpufreq-stats
0026 
0027 
0028 1. 簡介
0029 ===============
0030 
0031 cpufreq-stats是一個爲每個CPU提供CPU頻率統計的驅動。
0032 這些統計數據在/sysfs中以一堆只讀接口的形式提供。這個接口(在配置好後)將出現在
0033 /sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq下的一個單
0034 獨的目錄中,提供給每個CPU。
0035 各種統計數據將在此目錄下形成只讀文件。
0036 
0037 此驅動是獨立於任何可能運行在你所用CPU上的特定cpufreq_driver而設計的。因此,它將與所有
0038 cpufreq_driver一起工作。
0039 
0040 
0041 2. 提供的統計數據(舉例說明)
0042 =====================================
0043 
0044 cpufreq stats提供了以下統計數據(在下面詳細解釋)。
0045 
0046 -  time_in_state
0047 -  total_trans
0048 -  trans_table
0049 
0050 所有的統計數據將從統計驅動被載入的時間(或統計被重置的時間)開始,到某一統計數據被讀取的時間爲止。
0051 顯然,統計驅動不會有任何關於統計驅動載入之前的頻率轉換信息。
0052 
0053 ::
0054 
0055     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l
0056     total 0
0057     drwxr-xr-x  2 root root    0 May 14 16:06 .
0058     drwxr-xr-x  3 root root    0 May 14 15:58 ..
0059     --w-------  1 root root 4096 May 14 16:06 reset
0060     -r--r--r--  1 root root 4096 May 14 16:06 time_in_state
0061     -r--r--r--  1 root root 4096 May 14 16:06 total_trans
0062     -r--r--r--  1 root root 4096 May 14 16:06 trans_table
0063 
0064 - **reset**
0065 
0066 只寫屬性,可用於重置統計計數器。這對於評估不同調節器下的系統行爲非常有用,且無需重啓。
0067 
0068 
0069 - **time_in_state**
0070 
0071 此項給出了這個CPU所支持的每個頻率所花費的時間。cat輸出的每一行都會有"<frequency>
0072 <time>"對,表示這個CPU在<frequency>上花費了<time>個usertime單位的時間。這裡的
0073 usertime單位是10mS(類似於/proc中輸出的其他時間)。
0074 
0075 ::
0076 
0077     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state
0078     3600000 2089
0079     3400000 136
0080     3200000 34
0081     3000000 67
0082     2800000 172488
0083 
0084 
0085 - **total_trans**
0086 
0087 給出了這個CPU上頻率轉換的總次數。cat的輸出將有一個單一的計數,這就是頻率轉換的總數。
0088 
0089 ::
0090 
0091     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans
0092     20
0093 
0094 - **trans_table**
0095 
0096 這將提供所有CPU頻率轉換的細粒度信息。這裡的cat輸出是一個二維矩陣,其中一個條目<i, j>(第
0097 i行,第j列)代表從Freq_i到Freq_j的轉換次數。Freq_i行和Freq_j列遵循驅動最初提供給cpufreq
0098 核的頻率表的排序順序,因此可以排序(升序或降序)或不排序。 這裡的輸出也包含了每行每列的實際
0099 頻率值,以便更好地閱讀。
0100 
0101 如果轉換表大於PAGE_SIZE,讀取時將返回一個-EFBIG錯誤。
0102 
0103 ::
0104 
0105     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table
0106     From  :    To
0107             :   3600000   3400000   3200000   3000000   2800000
0108     3600000:         0         5         0         0         0
0109     3400000:         4         0         2         0         0
0110     3200000:         0         1         0         2         0
0111     3000000:         0         0         1         0         3
0112     2800000:         0         0         0         2         0
0113 
0114 3. 配置cpufreq-stats
0115 ============================
0116 
0117 要在你的內核中配置cpufreq-stats::
0118 
0119         Config Main Menu
0120                 Power management options (ACPI, APM)  --->
0121                         CPU Frequency scaling  --->
0122                                 [*] CPU Frequency scaling
0123                                 [*]   CPU frequency translation statistics
0124 
0125 
0126 "CPU Frequency scaling" (CONFIG_CPU_FREQ) 應該被啓用以配置cpufreq-stats。
0127 
0128 "CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括
0129 time_in_state、total_trans和trans_table的統計數據。
0130 
0131 一旦啓用了這個選項,並且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU頻率統計。
0132