docs/zh_CN: Update the translation of energy-model to 6.1-rc8

Update to commit c5d39fae89 ("Documentation: EM: Switch to
micro-Watts scale")

commit f48a0c475c ("Documentation: EM: Describe new registration
method using DT")
commit 75a3a99a5a ("PM: EM: Change the order of arguments in the
.active_power() callback")
commit 015f569c46 ("Documentation: EM: Add artificial EM
registration description")

Signed-off-by: Yanteng Si <siyanteng@loongson.cn>
Reviewed-by: Wu XiangCheng <bobwxc@email.cn>
Link: https://lore.kernel.org/r/06df12357d64d602a4dfb10a025a7520daeb3ba0.1670642548.git.siyanteng@loongson.cn
Signed-off-by: Jonathan Corbet <corbet@lwn.net>
This commit is contained in:
Yanteng Si 2022-12-10 11:27:05 +08:00 committed by Jonathan Corbet
parent 03474d581d
commit 7df047be43

View File

@ -23,15 +23,15 @@
实现支持EM框架作为一个抽象层介入它在内核中对功率成本表的格式进行标准化 实现支持EM框架作为一个抽象层介入它在内核中对功率成本表的格式进行标准化
因此能够避免多余的工作。 因此能够避免多余的工作。
功率值可以用瓦或“抽象刻度”表示。多个子系统可能使用EM由系统集成商来检查 功率值可以用瓦或“抽象刻度”表示。多个子系统可能使用EM由系统集成商来检查
功率值刻度类型的要求是否满足。可以在能量感知调度器的文档中找到一个例子 功率值刻度类型的要求是否满足。可以在能量感知调度器的文档中找到一个例子
Documentation/scheduler/sched-energy.rst。对于一些子系统比如热能或 Documentation/scheduler/sched-energy.rst。对于一些子系统比如热能或
powercap用“抽象刻度”描述功率值可能会导致问题。这些子系统对过去使用的功率的 powercap用“抽象刻度”描述功率值可能会导致问题。这些子系统对过去使用的功率的
估算值更感兴趣,因此可能需要真实的瓦。这些要求的一个例子可以在智能功率分配 估算值更感兴趣,因此可能需要真实的瓦。这些要求的一个例子可以在智能功率分配
Documentation/driver-api/thermal/power_allocator.rst文档中找到。 Documentation/driver-api/thermal/power_allocator.rst文档中找到。
内核子系统可能基于EM内部标志位实现了对EM注册设备是否具有不一致刻度的自动 内核子系统可能基于EM内部标志位实现了对EM注册设备是否具有不一致刻度的自动
检查。要记住的重要事情是,当功率值以“抽象刻度”表示时,从中推导以焦耳为单位 检查。要记住的重要事情是,当功率值以“抽象刻度”表示时,从中推导以焦耳为单位
的真实能量消耗是不可能的。 的真实能量消耗是不可能的。
下图描述了一个驱动的例子这里是针对Arm的但该方法适用于任何体系结构 下图描述了一个驱动的例子这里是针对Arm的但该方法适用于任何体系结构
@ -89,20 +89,40 @@ Documentation/driver-api/thermal/power_allocator.rst文档中找到。
驱动程序应通过以下API将性能域注册到EM框架中:: 驱动程序应通过以下API将性能域注册到EM框架中::
int em_dev_register_perf_domain(struct device *dev, unsigned int nr_states, int em_dev_register_perf_domain(struct device *dev, unsigned int nr_states,
struct em_data_callback *cb, cpumask_t *cpus, bool milliwatts); struct em_data_callback *cb, cpumask_t *cpus, bool microwatts);
驱动程序必须提供一个回调函数,为每个性能状态返回<频率,功率>元组。驱动程序 驱动程序必须提供一个回调函数,为每个性能状态返回<频率,功率>元组。驱动程序
提供的回调函数可以自由地从任何相关位置DT、固件......)以及以任何被认为是 提供的回调函数可以自由地从任何相关位置DT、固件......)以及以任何被认为是
必要的方式获取数据。只有对于CPU设备驱动程序必须使用cpumask指定性能域的CPU。 必要的方式获取数据。只有对于CPU设备驱动程序必须使用cpumask指定性能域的CPU。
对于CPU以外的其他设备最后一个参数必须被设置为NULL。 对于CPU以外的其他设备最后一个参数必须被设置为NULL。
最后一个参数“milliwatts”设置成正确的值是很重要的使用EM的内核 最后一个参数“microwatts”设置成正确的值是很重要的使用EM的内核
子系统可能会依赖这个标志来检查所有的EM设备是否使用相同的刻度。如果有不同的 子系统可能会依赖这个标志来检查所有的EM设备是否使用相同的刻度。如果有不同的
刻度,这些子系统可能决定返回警告/错误停止工作或崩溃panic 刻度,这些子系统可能决定返回警告/错误停止工作或崩溃panic
关于实现这个回调函数的驱动程序的例子参见第3节。或者在第2.4节阅读这个API 关于实现这个回调函数的驱动程序的例子参见第3节。或者在第2.4节阅读这个API
的更多文档。 的更多文档。
使用DT的EM注册
==============
EM也可以使用OPP框架和DT "操作点-v2 "中的信息注册。DT中的每个OPP条目都可
以用一个包含微瓦特功率值的属性 "op-microwatt "来扩展。这个OPP DT属性允
许平台注册反映总功率(静态+动态的EM功率值。这些功率值可能直接来自实验和
测量。
“人工”EM的注册
==============
有一个选项可以为缺少关于每个性能状态的功率值的详细知识的驱动程序提供一个自
定义回调。回调.get_cost()是可选的它提供EAS使用的“成本”值。这对那些只提
供CPU类型之间相对效率信息的平台很有用人们可以利用这些信息来创建一个抽象的
功率模型。但是,考虑到输入功率值的大小限制,即使是抽象的功率模型有时也很难装
进去。.get_cost()允许提供反映CPU效率的“成本”值。这将允许提供EAS信息
与EM内部计算'成本'值的公式有不同的关系。要为这样的平台注册EM驱动程序必须
将标志“microwatts”设置为0提供.get_power()回调和.get_cost()回调。EM
框架会在注册过程中正确处理这样的平台。这种平台会被设置EM_PERF_DOMAIN_ARTIFICIAL
标志。其他使用EM的框架应该特别注意测试和正确对待这个标志。
“简单”EM的注册 “简单”EM的注册
~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~
@ -147,8 +167,8 @@ cpufreq_driver::register_em()。这个回调必须为每个特定的驱动程序
-> drivers/cpufreq/foo_cpufreq.c -> drivers/cpufreq/foo_cpufreq.c
01 static int est_power(unsigned long *mW, unsigned long *KHz, 01 static int est_power(struct device *dev, unsigned long *mW,
02 struct device *dev) 02 unsigned long *KHz)
03 { 03 {
04 long freq, power; 04 long freq, power;
05 05