Back to home page

OSCL-LXR

 
 

    


0001 .. SPDX-License-Identifier: GPL-2.0
0002 
0003 .. include:: ../disclaimer-zh_CN.rst
0004 
0005 :Original: Documentation/cpu-freq/cpufreq-stats.rst
0006 
0007 :翻译:
0008 
0009  司延腾 Yanteng Si <siyanteng@loongson.cn>
0010 
0011 :校译:
0012 
0013  唐艺舟 Tang Yizhou <tangyeechou@gmail.com>
0014 
0015 ==========================================
0016 sysfs CPUFreq Stats的一般说明
0017 ==========================================
0018 
0019 为使用者准备的信息
0020 
0021 
0022 作者: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
0023 
0024 .. Contents
0025 
0026    1. 简介
0027    2. 提供的统计数据(举例说明)
0028    3. 配置cpufreq-stats
0029 
0030 
0031 1. 简介
0032 ===============
0033 
0034 cpufreq-stats是一种为每个CPU提供CPU频率统计的驱动。
0035 这些统计数据以/sysfs中一系列只读接口的形式呈现。cpufreq-stats接口(若已配置)将为每个CPU生成
0036 /sysfs(<sysfs root>/devices/system/cpu/cpuX/cpufreq/stats/)中cpufreq目录下的stats目录。
0037 各项统计数据将在stats目录下形成对应的只读文件。
0038 
0039 此驱动是以独立于任何可能运行在你所用CPU上的特定cpufreq_driver的方式设计的。因此,它将能和任何
0040 cpufreq_driver协同工作。
0041 
0042 
0043 2. 已提供的统计数据(有例子)
0044 =====================================
0045 
0046 cpufreq stats提供了以下统计数据(在下面详细解释)。
0047 
0048 -  time_in_state
0049 -  total_trans
0050 -  trans_table
0051 
0052 所有统计数据来自以下时间范围:从统计驱动被加载的时间(或统计数据被重置的时间)开始,到某一统计数据被读取的时间为止。
0053 显然,统计驱动不会保存它被加载之前的任何频率转换信息。
0054 
0055 ::
0056 
0057     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # ls -l
0058     total 0
0059     drwxr-xr-x  2 root root    0 May 14 16:06 .
0060     drwxr-xr-x  3 root root    0 May 14 15:58 ..
0061     --w-------  1 root root 4096 May 14 16:06 reset
0062     -r--r--r--  1 root root 4096 May 14 16:06 time_in_state
0063     -r--r--r--  1 root root 4096 May 14 16:06 total_trans
0064     -r--r--r--  1 root root 4096 May 14 16:06 trans_table
0065 
0066 - **reset**
0067 
0068 只写属性,可用于重置统计计数器。这对于评估不同调节器的系统行为非常有用,且无需重启。
0069 
0070 
0071 - **time_in_state**
0072 
0073 此文件给出了在本CPU支持的每个频率上分别花费的时间。cat输出的每一行都是一个"<frequency>
0074 <time>"对,表示这个CPU在<frequency>上花费了<time>个usertime单位的时间。输出的每一行对应
0075 一个CPU支持的频率。这里usertime单位是10mS(类似于/proc导出的其它时间)。
0076 
0077 ::
0078 
0079     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat time_in_state
0080     3600000 2089
0081     3400000 136
0082     3200000 34
0083     3000000 67
0084     2800000 172488
0085 
0086 
0087 - **total_trans**
0088 
0089 此文件给出了这个CPU频率转换的总次数。cat的输出是一个计数值,它就是频率转换的总次数。
0090 
0091 ::
0092 
0093     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat total_trans
0094     20
0095 
0096 - **trans_table**
0097 
0098 本文件提供所有CPU频率转换的细粒度信息。这里的cat输出是一个二维矩阵,其中一个条目<i, j>(第
0099 i行,第j列)代表从Freq_i到Freq_j的转换次数。Freq_i行和Freq_j列遵循驱动最初提供给cpufreq
0100 核心的频率表的排列顺序,因此可以已排序(升序或降序)或未排序。这里的输出也包含了实际
0101 频率值,分别按行和按列显示,以便更好地阅读。
0102 
0103 如果转换表大于PAGE_SIZE,读取时将返回一个-EFBIG错误。
0104 
0105 ::
0106 
0107     <mysystem>:/sys/devices/system/cpu/cpu0/cpufreq/stats # cat trans_table
0108     From  :    To
0109             :   3600000   3400000   3200000   3000000   2800000
0110     3600000:         0         5         0         0         0
0111     3400000:         4         0         2         0         0
0112     3200000:         0         1         0         2         0
0113     3000000:         0         0         1         0         3
0114     2800000:         0         0         0         2         0
0115 
0116 3. 配置cpufreq-stats
0117 ============================
0118 
0119 按以下方式在你的内核中配置cpufreq-stats::
0120 
0121         Config Main Menu
0122                 Power management options (ACPI, APM)  --->
0123                         CPU Frequency scaling  --->
0124                                 [*] CPU Frequency scaling
0125                                 [*]   CPU frequency translation statistics
0126 
0127 
0128 "CPU Frequency scaling" (CONFIG_CPU_FREQ) 应该被启用,以支持配置cpufreq-stats。
0129 
0130 "CPU frequency translation statistics" (CONFIG_CPU_FREQ_STAT)提供了包括
0131 time_in_state、total_trans和trans_table的统计数据。
0132 
0133 一旦启用了这个选项,并且你的CPU支持cpufrequency,你就可以在/sysfs中看到CPU频率统计。