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