]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
ACPI: processor: Do not expose global variable acpi_idle_driver
authorHuisong Li <lihuisong@huawei.com>
Tue, 23 Dec 2025 10:09:14 +0000 (18:09 +0800)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Fri, 9 Jan 2026 21:38:22 +0000 (22:38 +0100)
Move the cpuidle driver check from __acpi_processor_start() to
acpi_processor_power_init() which allows variable acpi_idle_driver to
become static.

No intentional functional impact.

Signed-off-by: Huisong Li <lihuisong@huawei.com>
Tested-by: Borislav Petkov (AMD) <bp@alien8.de>
Link: https://patch.msgid.link/20251223100914.2407069-7-lihuisong@huawei.com
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/acpi/processor_driver.c
drivers/acpi/processor_idle.c
include/acpi/processor.h

index f5b4f6a291436343027a34d528e1809f70fa5b31..882709796b4f722536fdc0ab07b4da64169250c1 100644 (file)
@@ -166,8 +166,7 @@ static int __acpi_processor_start(struct acpi_device *device)
        if (result && !IS_ENABLED(CONFIG_ACPI_CPU_FREQ_PSS))
                dev_dbg(&device->dev, "CPPC data invalid or not present\n");
 
-       if (cpuidle_get_driver() == &acpi_idle_driver)
-               acpi_processor_power_init(pr);
+       acpi_processor_power_init(pr);
 
        acpi_pss_perf_init(pr);
 
index 8704bc7ad91d5de1b6635ea651f4398c287d29f9..4ba45440d4c44fcba068ff2aff22250af75d2263 100644 (file)
@@ -51,7 +51,7 @@ module_param(latency_factor, uint, 0644);
 
 static DEFINE_PER_CPU(struct cpuidle_device *, acpi_cpuidle_device);
 
-struct cpuidle_driver acpi_idle_driver = {
+static struct cpuidle_driver acpi_idle_driver = {
        .name =         "acpi_idle",
        .owner =        THIS_MODULE,
 };
@@ -1395,6 +1395,13 @@ void acpi_processor_power_init(struct acpi_processor *pr)
 {
        struct cpuidle_device *dev;
 
+       /*
+        * The code below only works if the current cpuidle driver is the ACPI
+        * idle driver.
+        */
+       if (cpuidle_get_driver() != &acpi_idle_driver)
+               return;
+
        if (disabled_by_idle_boot_param())
                return;
 
index 24fdaa3c28992e547f2e67b16d98f8441e07540e..7146a8e9e9c25bfb757c90ff43ccbf89886d42d8 100644 (file)
@@ -417,7 +417,6 @@ static inline void acpi_processor_throttling_init(void) {}
 #endif /* CONFIG_ACPI_CPU_FREQ_PSS */
 
 /* in processor_idle.c */
-extern struct cpuidle_driver acpi_idle_driver;
 #ifdef CONFIG_ACPI_PROCESSOR_IDLE
 void acpi_processor_power_init(struct acpi_processor *pr);
 void acpi_processor_power_exit(struct acpi_processor *pr);