Solve a problem that causes CPUs Setup AMU FIE failed in a corner case,
even though they're eligible.
Changelog:
v3:
- add a patch to optimize amu_fie_setup()
- add a patch to add a function to get cpufreq policy without checking if
the CPU is online
- discard the reuse of amu_fie_setup() in cpuhp_topology_online() and keep
all the new logic in cpuhp_topology_online()
- test only the CPU which is going online in cpuhp_topology_online()
- when the freq_counters_valid() check fails, not only clear the scale
freq source but also clear all the related CPUs from amu_fie_cpus mask
- add some comments
v2:
- keep init_amu_fie_notifier for setting up AMU FIE when the cpufreq
policy is being created
- set up AMU FIE only for online CPUs instead of related_cpus in
init_amu_fie_callback()
- check and set all the online CPUs in the same policy when hotplug one
- clear scale freq source for all the online CPUs in the same policy to
avoid using different source of the freq scale
---
Discussions of previous version:
v1: https://lore.kernel.org/all/20250607094533.416368-1-zhenglifeng1@huawei.com/
v2: https://lore.kernel.org/all/20250725102813.1404322-1-zhenglifeng1@huawei.com/
Lifeng Zheng (3):
arm64: topology: Set scale freq source only for the CPUs that have not
been set before
cpufreq: Add a new function to get cpufreq policy without checking if
the CPU is online
arm64: topology: Setup AMU FIE for online CPUs only
arch/arm64/kernel/topology.c | 56 ++++++++++++++++++++++++++++++++++--
drivers/cpufreq/cpufreq.c | 11 +++++++
include/linux/cpufreq.h | 1 +
3 files changed, 65 insertions(+), 3 deletions(-)
--
2.33.0