diff options
| author | Jie Zhan <zhanjie9@hisilicon.com> | 2024-09-29 11:32:13 +0800 | 
|---|---|---|
| committer | Viresh Kumar <viresh.kumar@linaro.org> | 2024-10-03 11:07:53 +0530 | 
| commit | c47195631960b626058c335aec31f186fa854f97 (patch) | |
| tree | f4d8e6f0b9c2353bba211e3c36320c4f138cf6fb /drivers/usb/cdns3/cdns3-imx.c | |
| parent | dfb6e2f51beeaa77b2c07aabe58b833eb02ace81 (diff) | |
cppc_cpufreq: Use desired perf if feedback ctrs are 0 or unchanged
The CPPC performance feedback counters could be 0 or unchanged when the
target cpu is in a low-power idle state, e.g. power-gated or clock-gated.
When the counters are 0, cppc_cpufreq_get_rate() returns 0 KHz, which makes
cpufreq_online() get a false error and fail to generate a cpufreq policy.
When the counters are unchanged, the existing cppc_perf_from_fbctrs()
returns a cached desired perf, but some platforms may update the real
frequency back to the desired perf reg.
For the above cases in cppc_cpufreq_get_rate(), get the latest desired perf
from the CPPC reg to reflect the frequency because some platforms may
update the actual frequency back there; if failed, use the cached desired
perf.
Fixes: 6a4fec4f6d30 ("cpufreq: cppc: cppc_cpufreq_get_rate() returns zero in all error cases.")
Signed-off-by: Jie Zhan <zhanjie9@hisilicon.com>
Reviewed-by: Zeng Heng <zengheng4@huawei.com>
Reviewed-by: Ionela Voinescu <ionela.voinescu@arm.com>
Reviewed-by: Huisong Li <lihuisong@huawei.com>
Signed-off-by: Viresh Kumar <viresh.kumar@linaro.org>
Diffstat (limited to 'drivers/usb/cdns3/cdns3-imx.c')
0 files changed, 0 insertions, 0 deletions
