162306a36Sopenharmony_ci.. SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci.. include:: ../disclaimer-zh_CN.rst
462306a36Sopenharmony_ci
562306a36Sopenharmony_ci:Original: Documentation/cpu-freq/cpufreq-stats.rst
662306a36Sopenharmony_ci
762306a36Sopenharmony_ci:翻译:
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci 司延腾 Yanteng Si <siyanteng@loongson.cn>
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci:校译:
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci 唐艺舟 Tang Yizhou <tangyeechou@gmail.com>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci==========================================
1662306a36Sopenharmony_cisysfs CPUFreq Stats的一般说明
1762306a36Sopenharmony_ci==========================================
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci为使用者准备的信息
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_ci.. Contents
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci   1. 简介
2762306a36Sopenharmony_ci   2. 提供的统计数据(举例说明)
2862306a36Sopenharmony_ci   3. 配置cpufreq-stats
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci1. 简介
3262306a36Sopenharmony_ci===============
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_cicpufreq-stats是一种为每个CPU提供CPU频率统计的驱动。
3562306a36Sopenharmony_ci这些统计数据以/sysfs中一系列只读接口的形式呈现。cpufreq-stats接口(若已配置)将为每个CPU生成
3662306a36Sopenharmony_ci/sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq目录下的stats目录。
3762306a36Sopenharmony_ci各项统计数据将在stats目录下形成对应的只读文件。
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci此驱动是以独立于任何可能运行在你所用CPU上的特定cpufreq_driver的方式设计的。因此,它将能和任何
4062306a36Sopenharmony_cicpufreq_driver协同工作。
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci2. 已提供的统计数据(有例子)
4462306a36Sopenharmony_ci=====================================
4562306a36Sopenharmony_ci
4662306a36Sopenharmony_cicpufreq stats提供了以下统计数据(在下面详细解释)。
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci-  time_in_state
4962306a36Sopenharmony_ci-  total_trans
5062306a36Sopenharmony_ci-  trans_table
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_ci所有统计数据来自以下时间范围:从统计驱动被加载的时间(或统计数据被重置的时间)开始,到某一统计数据被读取的时间为止。
5362306a36Sopenharmony_ci显然,统计驱动不会保存它被加载之前的任何频率转换信息。
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_ci::
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_ci    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l
5862306a36Sopenharmony_ci    total 0
5962306a36Sopenharmony_ci    drwxr-xr-x  2 root root    0 May 14 16:06 .
6062306a36Sopenharmony_ci    drwxr-xr-x  3 root root    0 May 14 15:58 ..
6162306a36Sopenharmony_ci    --w-------  1 root root 4096 May 14 16:06 reset
6262306a36Sopenharmony_ci    -r--r--r--  1 root root 4096 May 14 16:06 time_in_state
6362306a36Sopenharmony_ci    -r--r--r--  1 root root 4096 May 14 16:06 total_trans
6462306a36Sopenharmony_ci    -r--r--r--  1 root root 4096 May 14 16:06 trans_table
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ci- **reset**
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci只写属性,可用于重置统计计数器。这对于评估不同调节器的系统行为非常有用,且无需重启。
6962306a36Sopenharmony_ci
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ci- **time_in_state**
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ci此文件给出了在本CPU支持的每个频率上分别花费的时间。cat输出的每一行都是一个"<frequency>
7462306a36Sopenharmony_ci<time>"对,表示这个CPU在<frequency>上花费了<time>个usertime单位的时间。输出的每一行对应
7562306a36Sopenharmony_ci一个CPU支持的频率。这里usertime单位是10mS(类似于/proc导出的其它时间)。
7662306a36Sopenharmony_ci
7762306a36Sopenharmony_ci::
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state
8062306a36Sopenharmony_ci    3600000 2089
8162306a36Sopenharmony_ci    3400000 136
8262306a36Sopenharmony_ci    3200000 34
8362306a36Sopenharmony_ci    3000000 67
8462306a36Sopenharmony_ci    2800000 172488
8562306a36Sopenharmony_ci
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci- **total_trans**
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci此文件给出了这个CPU频率转换的总次数。cat的输出是一个计数值,它就是频率转换的总次数。
9062306a36Sopenharmony_ci
9162306a36Sopenharmony_ci::
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans
9462306a36Sopenharmony_ci    20
9562306a36Sopenharmony_ci
9662306a36Sopenharmony_ci- **trans_table**
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci本文件提供所有CPU频率转换的细粒度信息。这里的cat输出是一个二维矩阵,其中一个条目<i, j>(第
9962306a36Sopenharmony_cii行,第j列)代表从Freq_i到Freq_j的转换次数。Freq_i行和Freq_j列遵循驱动最初提供给cpufreq
10062306a36Sopenharmony_ci核心的频率表的排列顺序,因此可以已排序(升序或降序)或未排序。这里的输出也包含了实际
10162306a36Sopenharmony_ci频率值,分别按行和按列显示,以便更好地阅读。
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ci如果转换表大于PAGE_SIZE,读取时将返回一个-EFBIG错误。
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ci::
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_ci    <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table
10862306a36Sopenharmony_ci    From  :    To
10962306a36Sopenharmony_ci	    :   3600000   3400000   3200000   3000000   2800000
11062306a36Sopenharmony_ci    3600000:         0         5         0         0         0
11162306a36Sopenharmony_ci    3400000:         4         0         2         0         0
11262306a36Sopenharmony_ci    3200000:         0         1         0         2         0
11362306a36Sopenharmony_ci    3000000:         0         0         1         0         3
11462306a36Sopenharmony_ci    2800000:         0         0         0         2         0
11562306a36Sopenharmony_ci
11662306a36Sopenharmony_ci3. 配置cpufreq-stats
11762306a36Sopenharmony_ci============================
11862306a36Sopenharmony_ci
11962306a36Sopenharmony_ci按以下方式在你的内核中配置cpufreq-stats::
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci	Config Main Menu
12262306a36Sopenharmony_ci		Power management options (ACPI, APM)  --->
12362306a36Sopenharmony_ci			CPU Frequency scaling  --->
12462306a36Sopenharmony_ci				[*] CPU Frequency scaling
12562306a36Sopenharmony_ci				[*]   CPU frequency translation statistics
12662306a36Sopenharmony_ci
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_ci"CPU Frequency scaling" (CONFIG_CPU_FREQ) 应该被启用,以支持配置cpufreq-stats。
12962306a36Sopenharmony_ci
13062306a36Sopenharmony_ci"CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括
13162306a36Sopenharmony_citime_in_state、total_trans和trans_table的统计数据。
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci一旦启用了这个选项,并且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU频率统计。
134