1.. SPDX-License-Identifier: GPL-2.0 2.. include:: ../disclaimer-zh_CN.rst 3 4:Original: Documentation/cpu-freq/core.rst 5 6:翻译: 7 8 司延腾 Yanteng Si <siyanteng@loongson.cn> 9 10.. _cn_core.rst: 11 12==================================== 13CPUFreq核心和CPUFreq通知器的通用说明 14==================================== 15 16作者: 17 - Dominik Brodowski <linux@brodo.de> 18 - David Kimdon <dwhedon@debian.org> 19 - Rafael J. Wysocki <rafael.j.wysocki@intel.com> 20 - Viresh Kumar <viresh.kumar@linaro.org> 21 22.. 目录: 23 24 1. CPUFreq核心和接口 25 2. CPUFreq通知器 26 3. 含有Operating Performance Point (OPP)的CPUFreq表的生成 27 281. CPUFreq核心和接口 29====================== 30 31cpufreq核心代码位于drivers/cpufreq/cpufreq.c中。这些cpufreq代码为CPUFreq架构的驱 32动程序(那些操作硬件切换频率的代码)以及 "通知器 "提供了一个标准化的接口。 33这些是设备驱动程序或需要了解策略变化的其它内核部分(如 ACPI 热量管理)或所有频率更改(除 34计时代码外),甚至需要强制确定速度限制的通知器(如 ARM 架构上的 LCD 驱动程序)。 35此外, 内核 "常数" loops_per_jiffy会根据频率变化而更新。 36 37cpufreq策略的引用计数由 cpufreq_cpu_get 和 cpufreq_cpu_put 来完成,以确保 cpufreq 驱 38动程序被正确地注册到核心中,并且驱动程序在 cpufreq_put_cpu 被调用之前不会被卸载。这也保证 39了每个CPU核的cpufreq 策略在使用期间不会被释放。 40 412. CPUFreq 通知器 42==================== 43 44CPUFreq通知器符合标准的内核通知器接口。 45关于通知器的细节请参阅 linux/include/linux/notifier.h。 46 47这里有两个不同的CPUfreq通知器 - 策略通知器和转换通知器。 48 49 502.1 CPUFreq策略通知器 51---------------------------- 52 53当创建或移除策略时,这些都会被通知。 54 55阶段是在通知器的第二个参数中指定的。当第一次创建策略时,阶段是CPUFREQ_CREATE_POLICY,当 56策略被移除时,阶段是CPUFREQ_REMOVE_POLICY。 57 58第三个参数 ``void *pointer`` 指向一个结构体cpufreq_policy,其包括min,max(新策略的下限和 59上限(单位为kHz))这几个值。 60 61 622.2 CPUFreq转换通知器 63-------------------------------- 64 65当CPUfreq驱动切换CPU核心频率时,策略中的每个在线CPU都会收到两次通知,这些变化没有任何外部干 66预。 67 68第二个参数指定阶段 - CPUFREQ_PRECHANGE or CPUFREQ_POSTCHANGE. 69 70第三个参数是一个包含如下值的结构体cpufreq_freqs: 71 72===== ==================== 73cpu 受影响cpu的编号 74old 旧频率 75new 新频率 76flags cpufreq驱动的标志 77===== ==================== 78 793. 含有Operating Performance Point (OPP)的CPUFreq表的生成 80================================================================== 81关于OPP的细节请参阅 Documentation/power/opp.rst 82 83dev_pm_opp_init_cpufreq_table - 84 这个功能提供了一个随时可用的转换程序,用来将OPP层关于可用频率的内部信息翻译成一种容易提供给 85 cpufreq的格式。 86 87 .. Warning:: 88 89 不要在中断上下文中使用此函数。 90 91 例如:: 92 93 soc_pm_init() 94 { 95 /* Do things */ 96 r = dev_pm_opp_init_cpufreq_table(dev, &freq_table); 97 if (!r) 98 policy->freq_table = freq_table; 99 /* Do other things */ 100 } 101 102 .. note:: 103 104 该函数只有在CONFIG_PM_OPP之外还启用了CONFIG_CPU_FREQ时才可用。 105 106dev_pm_opp_free_cpufreq_table 107 释放dev_pm_opp_init_cpufreq_table分配的表。 108