1.. SPDX-License-Identifier: GPL-2.0 2 3.. include:: ../disclaimer-zh_CN.rst 4 5:Original: Documentation/cpu-freq/cpufreq-stats.rst 6 7:翻译: 8 9 司延腾 Yanteng Si <siyanteng@loongson.cn> 10 11.. _cn_cpufreq-stats.rst: 12 13========================================== 14sysfs CPUFreq Stats的一般说明 15========================================== 16 17用户信息 18 19 20作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> 21 22.. Contents 23 24 1. 简介 25 2. 提供的统计数据(举例说明) 26 3. 配置cpufreq-stats 27 28 291. 简介 30=============== 31 32cpufreq-stats是一个为每个CPU提供CPU频率统计的驱动。 33这些统计数据在/sysfs中以一堆只读接口的形式提供。这个接口(在配置好后)将出现在 34/sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq下的一个单 35独的目录中,提供给每个CPU。 36各种统计数据将在此目录下形成只读文件。 37 38此驱动是独立于任何可能运行在你所用CPU上的特定cpufreq_driver而设计的。因此,它将与所有 39cpufreq_driver一起工作。 40 41 422. 提供的统计数据(举例说明) 43===================================== 44 45cpufreq stats提供了以下统计数据(在下面详细解释)。 46 47- time_in_state 48- total_trans 49- trans_table 50 51所有的统计数据将从统计驱动被载入的时间(或统计被重置的时间)开始,到某一统计数据被读取的时间为止。 52显然,统计驱动不会有任何关于统计驱动载入之前的频率转换信息。 53 54:: 55 56 <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l 57 total 0 58 drwxr-xr-x 2 root root 0 May 14 16:06 . 59 drwxr-xr-x 3 root root 0 May 14 15:58 .. 60 --w------- 1 root root 4096 May 14 16:06 reset 61 -r--r--r-- 1 root root 4096 May 14 16:06 time_in_state 62 -r--r--r-- 1 root root 4096 May 14 16:06 total_trans 63 -r--r--r-- 1 root root 4096 May 14 16:06 trans_table 64 65- **reset** 66 67只写属性,可用于重置统计计数器。这对于评估不同调节器下的系统行为非常有用,且无需重启。 68 69 70- **time_in_state** 71 72此项给出了这个CPU所支持的每个频率所花费的时间。cat输出的每一行都会有"<frequency> 73<time>"对,表示这个CPU在<frequency>上花费了<time>个usertime单位的时间。这里的 74usertime单位是10mS(类似于/proc中输出的其他时间)。 75 76:: 77 78 <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state 79 3600000 2089 80 3400000 136 81 3200000 34 82 3000000 67 83 2800000 172488 84 85 86- **total_trans** 87 88给出了这个CPU上频率转换的总次数。cat的输出将有一个单一的计数,这就是频率转换的总数。 89 90:: 91 92 <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans 93 20 94 95- **trans_table** 96 97这将提供所有CPU频率转换的细粒度信息。这里的cat输出是一个二维矩阵,其中一个条目<i, j>(第 98i行,第j列)代表从Freq_i到Freq_j的转换次数。Freq_i行和Freq_j列遵循驱动最初提供给cpufreq 99核的频率表的排序顺序,因此可以排序(升序或降序)或不排序。 这里的输出也包含了每行每列的实际 100频率值,以便更好地阅读。 101 102如果转换表大于PAGE_SIZE,读取时将返回一个-EFBIG错误。 103 104:: 105 106 <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table 107 From : To 108 : 3600000 3400000 3200000 3000000 2800000 109 3600000: 0 5 0 0 0 110 3400000: 4 0 2 0 0 111 3200000: 0 1 0 2 0 112 3000000: 0 0 1 0 3 113 2800000: 0 0 0 2 0 114 1153. 配置cpufreq-stats 116============================ 117 118要在你的内核中配置cpufreq-stats:: 119 120 Config Main Menu 121 Power management options (ACPI, APM) ---> 122 CPU Frequency scaling ---> 123 [*] CPU Frequency scaling 124 [*] CPU frequency translation statistics 125 126 127"CPU Frequency scaling" (CONFIG_CPU_FREQ) 应该被启用以配置cpufreq-stats。 128 129"CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括 130time_in_state、total_trans和trans_table的统计数据。 131 132一旦启用了这个选项,并且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU频率统计。 133