]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
platform/x86/intel/vbtn: Stop creating a platform device
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Mon, 15 Dec 2025 13:35:44 +0000 (14:35 +0100)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Tue, 16 Dec 2025 20:51:04 +0000 (21:51 +0100)
Now that "system" devices are represented as platform devices, they
are not claimed by the PNP ACPI scan handler any more and the Intel
virtual button array platform devices should be created by the ACPI
core, so the driver does not need to attempt to create a platform
device by itself.

Accordingly, make it stop doing so.

No intentional functional impact.

Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: Mario Limonciello (AMD) <superm1@kernel.org>
Link: https://patch.msgid.link/8661724.NyiUUSuA9g@rafael.j.wysocki
drivers/platform/x86/intel/vbtn.c

index 232cd12e3c9fabbd3f9e4f90b115b2440406a1f5..9ca87e7075822567f30ab0e8200f561a0be3ac00 100644 (file)
@@ -390,32 +390,4 @@ static struct platform_driver intel_vbtn_pl_driver = {
        .remove = intel_vbtn_remove,
 };
 
-static acpi_status __init
-check_acpi_dev(acpi_handle handle, u32 lvl, void *context, void **rv)
-{
-       const struct acpi_device_id *ids = context;
-       struct acpi_device *dev = acpi_fetch_acpi_dev(handle);
-
-       if (dev && acpi_match_device_ids(dev, ids) == 0)
-               if (!IS_ERR_OR_NULL(acpi_create_platform_device(dev, NULL)))
-                       dev_info(&dev->dev,
-                                "intel-vbtn: created platform device\n");
-
-       return AE_OK;
-}
-
-static int __init intel_vbtn_init(void)
-{
-       acpi_walk_namespace(ACPI_TYPE_DEVICE, ACPI_ROOT_OBJECT,
-                           ACPI_UINT32_MAX, check_acpi_dev, NULL,
-                           (void *)intel_vbtn_ids, NULL);
-
-       return platform_driver_register(&intel_vbtn_pl_driver);
-}
-module_init(intel_vbtn_init);
-
-static void __exit intel_vbtn_exit(void)
-{
-       platform_driver_unregister(&intel_vbtn_pl_driver);
-}
-module_exit(intel_vbtn_exit);
+module_platform_driver(intel_vbtn_pl_driver);