}
#ifdef CONFIG_ACPI
-static int sonypi_acpi_add(struct acpi_device *device)
+static int sonypi_acpi_probe(struct platform_device *pdev)
{
+ struct acpi_device *device = ACPI_COMPANION(&pdev->dev);
+
sonypi_acpi_device = device;
strcpy(acpi_device_name(device), "Sony laptop hotkeys");
strcpy(acpi_device_class(device), "sony/hotkey");
return 0;
}
-static void sonypi_acpi_remove(struct acpi_device *device)
+static void sonypi_acpi_remove(struct platform_device *pdev)
{
sonypi_acpi_device = NULL;
}
{"", 0},
};
-static struct acpi_driver sonypi_acpi_driver = {
- .name = "sonypi",
- .class = "hkey",
- .ids = sonypi_device_ids,
- .ops = {
- .add = sonypi_acpi_add,
- .remove = sonypi_acpi_remove,
+static struct platform_driver sonypi_acpi_driver = {
+ .probe = sonypi_acpi_probe,
+ .remove = sonypi_acpi_remove,
+ .driver = {
+ .name = "sonypi_acpi",
+ .acpi_match_table = sonypi_device_ids,
},
};
#endif
goto err_free_device;
#ifdef CONFIG_ACPI
- if (acpi_bus_register_driver(&sonypi_acpi_driver) >= 0)
- acpi_driver_registered = 1;
+ error = platform_driver_register(&sonypi_acpi_driver);
+ acpi_driver_registered = !error;
#endif
return 0;
{
#ifdef CONFIG_ACPI
if (acpi_driver_registered)
- acpi_bus_unregister_driver(&sonypi_acpi_driver);
+ platform_driver_unregister(&sonypi_acpi_driver);
#endif
platform_device_unregister(sonypi_platform_device);
platform_driver_unregister(&sonypi_driver);