162306a36Sopenharmony_ci.. SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci 362306a36Sopenharmony_ci.. include:: ../disclaimer-zh_TW.rst 462306a36Sopenharmony_ci 562306a36Sopenharmony_ci:Original: :doc:`../../../cpu-freq/cpufreq-stats` 662306a36Sopenharmony_ci:Translator: Yanteng Si <siyanteng@loongson.cn> 762306a36Sopenharmony_ci Hu Haowen <src.res.211@gmail.com> 862306a36Sopenharmony_ci 962306a36Sopenharmony_ci.. _tw_cpufreq-stats.rst: 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci========================================== 1362306a36Sopenharmony_cisysfs CPUFreq Stats的一般說明 1462306a36Sopenharmony_ci========================================== 1562306a36Sopenharmony_ci 1662306a36Sopenharmony_ci用戶信息 1762306a36Sopenharmony_ci 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_ci.. Contents 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ci 1. 簡介 2462306a36Sopenharmony_ci 2. 提供的統計數據(舉例說明) 2562306a36Sopenharmony_ci 3. 配置cpufreq-stats 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci1. 簡介 2962306a36Sopenharmony_ci=============== 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_cicpufreq-stats是一個爲每個CPU提供CPU頻率統計的驅動。 3262306a36Sopenharmony_ci這些統計數據在/sysfs中以一堆只讀接口的形式提供。這個接口(在配置好後)將出現在 3362306a36Sopenharmony_ci/sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq下的一個單 3462306a36Sopenharmony_ci獨的目錄中,提供給每個CPU。 3562306a36Sopenharmony_ci各種統計數據將在此目錄下形成只讀文件。 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci此驅動是獨立於任何可能運行在你所用CPU上的特定cpufreq_driver而設計的。因此,它將與所有 3862306a36Sopenharmony_cicpufreq_driver一起工作。 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci2. 提供的統計數據(舉例說明) 4262306a36Sopenharmony_ci===================================== 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_cicpufreq stats提供了以下統計數據(在下面詳細解釋)。 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci- time_in_state 4762306a36Sopenharmony_ci- total_trans 4862306a36Sopenharmony_ci- trans_table 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci所有的統計數據將從統計驅動被載入的時間(或統計被重置的時間)開始,到某一統計數據被讀取的時間爲止。 5162306a36Sopenharmony_ci顯然,統計驅動不會有任何關於統計驅動載入之前的頻率轉換信息。 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ci:: 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l 5662306a36Sopenharmony_ci total 0 5762306a36Sopenharmony_ci drwxr-xr-x 2 root root 0 May 14 16:06 . 5862306a36Sopenharmony_ci drwxr-xr-x 3 root root 0 May 14 15:58 .. 5962306a36Sopenharmony_ci --w------- 1 root root 4096 May 14 16:06 reset 6062306a36Sopenharmony_ci -r--r--r-- 1 root root 4096 May 14 16:06 time_in_state 6162306a36Sopenharmony_ci -r--r--r-- 1 root root 4096 May 14 16:06 total_trans 6262306a36Sopenharmony_ci -r--r--r-- 1 root root 4096 May 14 16:06 trans_table 6362306a36Sopenharmony_ci 6462306a36Sopenharmony_ci- **reset** 6562306a36Sopenharmony_ci 6662306a36Sopenharmony_ci只寫屬性,可用於重置統計計數器。這對於評估不同調節器下的系統行爲非常有用,且無需重啓。 6762306a36Sopenharmony_ci 6862306a36Sopenharmony_ci 6962306a36Sopenharmony_ci- **time_in_state** 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci此項給出了這個CPU所支持的每個頻率所花費的時間。cat輸出的每一行都會有"<frequency> 7262306a36Sopenharmony_ci<time>"對,表示這個CPU在<frequency>上花費了<time>個usertime單位的時間。這裡的 7362306a36Sopenharmony_ciusertime單位是10mS(類似於/proc中輸出的其他時間)。 7462306a36Sopenharmony_ci 7562306a36Sopenharmony_ci:: 7662306a36Sopenharmony_ci 7762306a36Sopenharmony_ci <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state 7862306a36Sopenharmony_ci 3600000 2089 7962306a36Sopenharmony_ci 3400000 136 8062306a36Sopenharmony_ci 3200000 34 8162306a36Sopenharmony_ci 3000000 67 8262306a36Sopenharmony_ci 2800000 172488 8362306a36Sopenharmony_ci 8462306a36Sopenharmony_ci 8562306a36Sopenharmony_ci- **total_trans** 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci給出了這個CPU上頻率轉換的總次數。cat的輸出將有一個單一的計數,這就是頻率轉換的總數。 8862306a36Sopenharmony_ci 8962306a36Sopenharmony_ci:: 9062306a36Sopenharmony_ci 9162306a36Sopenharmony_ci <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans 9262306a36Sopenharmony_ci 20 9362306a36Sopenharmony_ci 9462306a36Sopenharmony_ci- **trans_table** 9562306a36Sopenharmony_ci 9662306a36Sopenharmony_ci這將提供所有CPU頻率轉換的細粒度信息。這裡的cat輸出是一個二維矩陣,其中一個條目<i, j>(第 9762306a36Sopenharmony_cii行,第j列)代表從Freq_i到Freq_j的轉換次數。Freq_i行和Freq_j列遵循驅動最初提供給cpufreq 9862306a36Sopenharmony_ci核的頻率表的排序順序,因此可以排序(升序或降序)或不排序。 這裡的輸出也包含了每行每列的實際 9962306a36Sopenharmony_ci頻率值,以便更好地閱讀。 10062306a36Sopenharmony_ci 10162306a36Sopenharmony_ci如果轉換表大於PAGE_SIZE,讀取時將返回一個-EFBIG錯誤。 10262306a36Sopenharmony_ci 10362306a36Sopenharmony_ci:: 10462306a36Sopenharmony_ci 10562306a36Sopenharmony_ci <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table 10662306a36Sopenharmony_ci From : To 10762306a36Sopenharmony_ci : 3600000 3400000 3200000 3000000 2800000 10862306a36Sopenharmony_ci 3600000: 0 5 0 0 0 10962306a36Sopenharmony_ci 3400000: 4 0 2 0 0 11062306a36Sopenharmony_ci 3200000: 0 1 0 2 0 11162306a36Sopenharmony_ci 3000000: 0 0 1 0 3 11262306a36Sopenharmony_ci 2800000: 0 0 0 2 0 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci3. 配置cpufreq-stats 11562306a36Sopenharmony_ci============================ 11662306a36Sopenharmony_ci 11762306a36Sopenharmony_ci要在你的內核中配置cpufreq-stats:: 11862306a36Sopenharmony_ci 11962306a36Sopenharmony_ci Config Main Menu 12062306a36Sopenharmony_ci Power management options (ACPI, APM) ---> 12162306a36Sopenharmony_ci CPU Frequency scaling ---> 12262306a36Sopenharmony_ci [*] CPU Frequency scaling 12362306a36Sopenharmony_ci [*] CPU frequency translation statistics 12462306a36Sopenharmony_ci 12562306a36Sopenharmony_ci 12662306a36Sopenharmony_ci"CPU Frequency scaling" (CONFIG_CPU_FREQ) 應該被啓用以配置cpufreq-stats。 12762306a36Sopenharmony_ci 12862306a36Sopenharmony_ci"CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括 12962306a36Sopenharmony_citime_in_state、total_trans和trans_table的統計數據。 13062306a36Sopenharmony_ci 13162306a36Sopenharmony_ci一旦啓用了這個選項,並且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU頻率統計。 13262306a36Sopenharmony_ci 133