-
- Downloads
ACPI: processor: Move arch_init_invariance_cppc() call later
arch_init_invariance_cppc() is called at the end of acpi_cppc_processor_probe() in order to configure frequency invariance based upon the values from _CPC. This however doesn't work on AMD CPPC shared memory designs that have AMD preferred cores enabled because _CPC needs to be analyzed from all cores to judge if preferred cores are enabled. This issue manifests to users as a warning since commit 21fb59ab ("ACPI: CPPC: Adjust debug messages in amd_set_max_freq_ratio() to warn"): ``` Could not retrieve highest performance (-19) ``` However the warning isn't the cause of this, it was actually commit 279f838a ("x86/amd: Detect preferred cores in amd_get_boost_ratio_numerator()") which exposed the issue. To fix this problem, change arch_init_invariance_cppc() into a new weak symbol that is called at the end of acpi_processor_driver_init(). Each architecture that supports it can declare the symbol to override the weak one. Define it for x86, in arch/x86/kernel/acpi/cppc.c, and for all of the architectures using the generic arch_topology.c code. Fixes: 279f838a ("x86/amd: Detect preferred cores in amd_get_boost_ratio_numerator()") Reported-by:Ivan Shapovalov <intelfx@intelfx.name> Closes: https://bugzilla.kernel.org/show_bug.cgi?id=219431 Tested-by:
Oleksandr Natalenko <oleksandr@natalenko.name> Signed-off-by:
Mario Limonciello <mario.limonciello@amd.com> Link: https://patch.msgid.link/20241104222855.3959267-1-superm1@kernel.org [ rjw: Changelog edit ] Signed-off-by:
Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Showing
- arch/arm64/include/asm/topology.h 0 additions, 4 deletionsarch/arm64/include/asm/topology.h
- arch/x86/include/asm/topology.h 0 additions, 5 deletionsarch/x86/include/asm/topology.h
- arch/x86/kernel/acpi/cppc.c 6 additions, 1 deletionarch/x86/kernel/acpi/cppc.c
- drivers/acpi/cppc_acpi.c 0 additions, 6 deletionsdrivers/acpi/cppc_acpi.c
- drivers/acpi/processor_driver.c 9 additions, 0 deletionsdrivers/acpi/processor_driver.c
- drivers/base/arch_topology.c 5 additions, 1 deletiondrivers/base/arch_topology.c
- include/acpi/processor.h 2 additions, 0 deletionsinclude/acpi/processor.h
- include/linux/arch_topology.h 0 additions, 4 deletionsinclude/linux/arch_topology.h
Loading
Please register or sign in to comment