};
MODULE_DEVICE_TABLE(acpi, processor_device_ids);
+int (*__acpi_processor_register_driver)(void) = acpi_processor_register_driver;
+void (*__acpi_processor_unregister_driver)(void) \
+ = acpi_processor_unregister_driver;
+
+
static struct acpi_driver acpi_processor_driver = {
.name = "processor",
.class = ACPI_PROCESSOR_CLASS,
unregister_hotcpu_notifier(&acpi_cpu_notifier);
}
+int acpi_processor_register_driver(void)
+{
+ int result = 0;
+ if (!cpuidle_register_driver(&acpi_idle_driver)) {
+ printk(KERN_DEBUG "ACPI: %s registered with cpuidle\n",
+ acpi_idle_driver.name);
+ } else {
+ printk(KERN_DEBUG "ACPI: acpi_idle yielding to %s\n",
+ cpuidle_get_driver()->name);
+ }
+
+ result = acpi_bus_register_driver(&acpi_processor_driver);
+ return result;
+}
+
+void acpi_processor_unregister_driver(void)
+{
+ acpi_bus_unregister_driver(&acpi_processor_driver);
+
+ cpuidle_unregister_driver(&acpi_idle_driver);
+
+ return;
+}
/*
* We keep the driver loaded even when ACPI is not running.
* This is needed for the powernow-k8 driver, that works even without
memset(&errata, 0, sizeof(errata));
- if (!cpuidle_register_driver(&acpi_idle_driver)) {
- printk(KERN_DEBUG "ACPI: %s registered with cpuidle\n",
- acpi_idle_driver.name);
- } else {
- printk(KERN_DEBUG "ACPI: acpi_idle yielding to %s\n",
- cpuidle_get_driver()->name);
+ if (__acpi_processor_register_driver) {
+ result = __acpi_processor_register_driver();
+ if (result < 0)
+ goto out_cpuidle;
}
- result = acpi_bus_register_driver(&acpi_processor_driver);
- if (result < 0)
- goto out_cpuidle;
-
acpi_processor_install_hotplug_notify();
acpi_thermal_cpufreq_init();
return result;
}
+
static void __exit acpi_processor_exit(void)
{
if (acpi_disabled)
acpi_processor_uninstall_hotplug_notify();
- acpi_bus_unregister_driver(&acpi_processor_driver);
-
- cpuidle_unregister_driver(&acpi_idle_driver);
+ if (__acpi_processor_unregister_driver)
+ __acpi_processor_unregister_driver();
return;
}
void acpi_processor_install_hotplug_notify(void);
void acpi_processor_uninstall_hotplug_notify(void);
-
+int acpi_processor_register_driver(void);
+void acpi_processor_unregister_driver(void);
int acpi_processor_add(struct acpi_device *device);
int acpi_processor_remove(struct acpi_device *device, int type);
void acpi_processor_notify(struct acpi_device *device, u32 event);