The Energy Model (EM) framework feeds interested subsystems (the scheduler/EAS as of now) with power costs provided by drivers. Yet, no driver is actually doing that upstream yet. This series updates a set of CPUFreq drivers in order to register power costs in the EM framework for some of the Arm reference platforms for EAS: Hikey960, Juno and TC2.
The series is split as follows: - Patch 01 introduces in PM_OPP a helper function which estimates the CPU power using the P=CV²f equation also used by IPA. It should be noted that this introduces duplicate code with IPA, which will eventually be fixed by migrating IPA to using PM_EM. The ideal plan would be to do so later, in a separate patch series. I would indeed prefer to keep the thermal and CPUFreq discussion separate at this stage, if deemed acceptable. - Patches 02-04 make use of that PM_OPP helper function from the following CPUFreq drivers: cpufreq-dt, scpi-cpufreq and arm_big_little. - Patch 05 modifies the SCMI cpufreq driver to pass the power costs obtained from firmware to PM_EM. This patch is independent from the rest of the series. Changes since v1 (20190128165522.31749-1-quentin.per...@arm.com): - Dropped the DT patches that have been queued by Sudeep - Introduced dev_pm_opp_of_register_em() helper to check the presence of the DT coeff before calling PM_EM (Viresh, Matthias) - Coding-style improvements (Viresh, Matthias) Thanks, Quentin Dietmar Eggemann (1): cpufreq: arm_big_little: Register an Energy Model Quentin Perret (4): PM / OPP: Introduce a power estimation helper cpufreq: dt: Register an Energy Model cpufreq: scpi: Register an Energy Model cpufreq: scmi: Register an Energy Model drivers/cpufreq/arm_big_little.c | 8 +++ drivers/cpufreq/cpufreq-dt.c | 8 +-- drivers/cpufreq/scmi-cpufreq.c | 39 ++++++++++++-- drivers/cpufreq/scpi-cpufreq.c | 9 ++-- drivers/opp/of.c | 88 ++++++++++++++++++++++++++++++++ include/linux/pm_opp.h | 6 +++ 6 files changed, 149 insertions(+), 9 deletions(-) -- 2.20.1