.. SPDX-License-Identifier: GPL-2.0 .. include:: ../disclaimer-zh_TW.rst :Original: Documentation/cpu-freq/cpufreq-stats.rst :çż»čŻ: 司延騰 Yanteng Si <siyanteng@loongson.cn> :ć ˇčŻ: ĺ”č—ťčź Tang Yizhou <tangyeechou@gmail.com> ========================================== sysfs CPUFreq Stats的一č¬čŞŞćŽ ========================================== ç˛ä˝żç”¨č€…ćş–ĺ‚™çš„äżˇćŻ ä˝śč€…: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> .. Contents 1. 簡介 2. ćŹäľ›çš„çµ±č¨ć•¸ć“š(č‰äľ‹čŞŞćŽ) 3. é…Ťç˝®cpufreq-stats 1. 簡介 =============== cpufreq-statsćŻä¸€ç¨®ç˛ćŻŹĺ€‹CPUćŹäľ›CPUé »çŽ‡çµ±č¨çš„驅動。 這些統č¨ć•¸ć“šä»Ą/sysfsä¸ä¸€çł»ĺ—只讀接口的形式ĺ‘現。cpufreq-stats接口ďĽč‹Ąĺ·˛é…Ťç˝®ďĽ‰ĺ°‡ç˛ćŻŹĺ€‹CPU生ć /sysfsďĽ<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)ä¸cpufreq目錄下的stats目錄。 ĺ„é …çµ±č¨ć•¸ć“šĺ°‡ĺś¨stats目錄下形ć對應的只讀文件。 ć¤é©…ĺ‹•ćŻä»ĄçŤ¨ç«‹ć–Ľä»»ä˝•可č˝é‹čˇŚĺś¨ä˝ 所用CPU上的特定cpufreq_driver的方式č¨č¨çš„ă€‚ĺ› ć¤ďĽŚĺ®ĺ°‡č˝ĺ’Śä»»ä˝• cpufreq_driver協ĺŚĺ·Ąä˝śă€‚ 2. ĺ·˛ćŹäľ›çš„çµ±č¨ć•¸ć“š(有例ĺ) ===================================== cpufreq statsćŹäľ›äş†ä»Ąä¸‹çµ±č¨ć•¸ć“šďĽĺś¨ä¸‹éť˘č©łç´°č§Łé‡‹ďĽ‰ă€‚ - time_in_state - total_trans - trans_table 所有統č¨ć•¸ć“šäľ†č‡Şä»Ąä¸‹ć™‚間範圍:從統č¨é©…ĺ‹•č˘«ĺŠ čĽ‰çš„ć™‚é–“ďĽć–çµ±č¨ć•¸ć“šč˘«é‡Ťç˝®çš„時間)開始,ĺ°ćźä¸€çµ±č¨ć•¸ć“šč˘«č®€ĺŹ–çš„ć™‚é–“ç˛ć˘ă€‚ 顯然,統č¨é©…動不ćśäżťĺĺ®č˘«ĺŠ čĽ‰äą‹ĺ‰Ťçš„ä»»ä˝•é »çŽ‡č˝‰ćŹ›äżˇćŻă€‚ :: <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l total 0 drwxr-xr-x 2 root root 0 May 14 16:06 . drwxr-xr-x 3 root root 0 May 14 15:58 .. --w------- 1 root root 4096 May 14 16:06 reset -r--r--r-- 1 root root 4096 May 14 16:06 time_in_state -r--r--r-- 1 root root 4096 May 14 16:06 total_trans -r--r--r-- 1 root root 4096 May 14 16:06 trans_table - **reset** 只寫屬性,可用於重置統č¨č¨ć•¸ĺ™¨ă€‚這對於評估不ĺŚčŞżçŻ€ĺ™¨çš„çł»çµ±čˇŚç˛éťžĺ¸¸ćś‰ç”¨ďĽŚä¸”無需重啓。 - **time_in_state** ć¤ć–‡ä»¶çµ¦ĺ‡şäş†ĺś¨ćś¬CPU支ćŚçš„ćŻŹĺ€‹é »çŽ‡ä¸Šĺ†ĺĄčŠ±č˛»çš„ć™‚é–“ă€‚cat輸出的每一行é˝ćŻä¸€ĺ€‹"<frequency> <time>"對,表示這個CPU在<frequency>上花費了<time>個usertime單位的時間。輸出的每一行對應 一個CPU支ćŚçš„é »çŽ‡ă€‚é€™čŁŹusertime單位ćŻ10mSďĽéˇžäĽĽć–Ľ/proc導出的其ĺ®ć™‚間)。 :: <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state 3600000 2089 3400000 136 3200000 34 3000000 67 2800000 172488 - **total_trans** ć¤ć–‡ä»¶çµ¦ĺ‡şäş†é€™ĺ€‹CPUé »çŽ‡č˝‰ćŹ›çš„ç¸˝ć¬ˇć•¸ă€‚cat的輸出ćŻä¸€ĺ€‹č¨ć•¸ĺ€ĽďĽŚĺ®ĺ°±ćŻé »çŽ‡č˝‰ćŹ›çš„ç¸˝ć¬ˇć•¸ă€‚ :: <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans 20 - **trans_table** 本文件ćŹäľ›ć‰€ćś‰CPUé »çŽ‡č˝‰ćŹ›çš„ç´°ç˛’ĺş¦äżˇćŻă€‚這裏的cat輸出ćŻä¸€ĺ€‹äşŚç¶çź©é™ŁďĽŚĺ…¶ä¸ä¸€ĺ€‹ć˘ťç›®<i, j>ďĽç¬¬ i行,第jĺ—)代表從Freq_iĺ°Freq_j的轉換次數。Freq_i行和Freq_jĺ—éµĺľŞé©…動最ĺťćŹäľ›çµ¦cpufreq ć ¸ĺżçš„é »çŽ‡čˇ¨çš„ćŽ’ĺ—é †ĺşŹďĽŚĺ› ć¤ĺŹŻä»Ąĺ·˛ćŽ’ĺşŹďĽĺŤ‡ĺşŹć–降序)ć–未排序。這裏的輸出也包ĺ«äş†ĺŻ¦éš› é »çŽ‡ĺ€ĽďĽŚĺ†ĺĄćŚ‰čˇŚĺ’ŚćŚ‰ĺ—顯示,以便更好地閱讀。 如果轉換表大於PAGE_SIZE,讀取時將返回一個-EFBIG錯誤。 :: <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table From : To : 3600000 3400000 3200000 3000000 2800000 3600000: 0 5 0 0 0 3400000: 4 0 2 0 0 3200000: 0 1 0 2 0 3000000: 0 0 1 0 3 2800000: 0 0 0 2 0 3. é…Ťç˝®cpufreq-stats ============================ ćŚ‰ä»Ąä¸‹ć–ąĺĽŹĺś¨ä˝ çš„ĺ…§ć ¸ä¸é…Ťç˝®cpufreq-stats:: Config Main Menu Power management options (ACPI, APM) ---> CPU Frequency scaling ---> [*] CPU Frequency scaling [*] CPU frequency translation statistics "CPU Frequency scaling" (CONFIG_CPU_FREQ) 應該被啓用,以支ćŚé…Ťç˝®cpufreq-stats。 "CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)ćŹäľ›äş†ĺڅ㋬ time_in_stateă€total_transĺ’Śtrans_table的統č¨ć•¸ć“šă€‚ 一旦啓用了這個é¸é …ďĽŚä¸¦ä¸”ä˝ çš„CPU支ćŚcpufrequencyďĽŚä˝ ĺ°±ĺŹŻä»Ąĺś¨/sysfsä¸çś‹ĺ°CPUé »çŽ‡çµ±č¨ă€‚