[PATCH v2 3/6] platform/chrome: chromeos_tbmc: Register ACPI notify handler
From: Rafael J. Wysocki
Date: Thu Mar 05 2026 - 14:48:30 EST
From: "Rafael J. Wysocki" <rafael.j.wysocki@xxxxxxxxx>
To facilitate subsequent conversion of the driver to a platform one,
make it install an ACPI notify handler directly instead of using
a .notify() callback in struct acpi_driver.
No intentional functional impact.
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@xxxxxxxxx>
---
v1 -> v2: No changes
---
drivers/platform/chrome/chromeos_tbmc.c | 16 ++++++++++++++--
1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/drivers/platform/chrome/chromeos_tbmc.c b/drivers/platform/chrome/chromeos_tbmc.c
index e248567c0a18..9c988e697d09 100644
--- a/drivers/platform/chrome/chromeos_tbmc.c
+++ b/drivers/platform/chrome/chromeos_tbmc.c
@@ -45,8 +45,10 @@ static __maybe_unused int chromeos_tbmc_resume(struct device *dev)
return chromeos_tbmc_query_switch(adev, adev->driver_data);
}
-static void chromeos_tbmc_notify(struct acpi_device *adev, u32 event)
+static void chromeos_tbmc_notify(acpi_handle handle, u32 event, void *data)
{
+ struct acpi_device *adev = data;
+
acpi_pm_wakeup_event(&adev->dev);
switch (event) {
case 0x80:
@@ -92,11 +94,22 @@ static int chromeos_tbmc_add(struct acpi_device *adev)
return ret;
}
device_init_wakeup(dev, true);
+
+ ret = acpi_dev_install_notify_handler(adev, ACPI_DEVICE_NOTIFY,
+ chromeos_tbmc_notify, adev);
+ if (ret) {
+ dev_err(dev, "cannot install ACPI notify handler\n");
+ device_init_wakeup(dev, false);
+ return ret;
+ }
+
return 0;
}
static void chromeos_tbmc_remove(struct acpi_device *adev)
{
+ acpi_dev_remove_notify_handler(adev, ACPI_DEVICE_NOTIFY,
+ chromeos_tbmc_notify);
device_init_wakeup(&adev->dev, false);
}
@@ -116,7 +129,6 @@ static struct acpi_driver chromeos_tbmc_driver = {
.ops = {
.add = chromeos_tbmc_add,
.remove = chromeos_tbmc_remove,
- .notify = chromeos_tbmc_notify,
},
.drv.pm = &chromeos_tbmc_pm_ops,
};
--
2.51.0