]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
PM: wakeup: implement devm_device_init_wakeup() helper
authorJoe Hattori <joe@pf.is.s.u-tokyo.ac.jp>
Wed, 18 Dec 2024 04:09:35 +0000 (13:09 +0900)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Wed, 18 Dec 2024 19:47:23 +0000 (20:47 +0100)
Some drivers that enable device wakeup fail to properly disable it
during their cleanup, which results in a memory leak.

To address this, introduce devm_device_init_wakeup(), a managed variant
of device_init_wakeup(dev, true).

With this managed helper, wakeup functionality will be automatically
disabled when the device is released, ensuring a more reliable cleanup
process.

This need for this addition arose during a previous discussion [1].

Link: https://lore.kernel.org/linux-rtc/20241212100403.3799667-1-joe@pf.is.s.u-tokyo.ac.jp/
Suggested-by: Alexandre Belloni <alexandre.belloni@bootlin.com>
Signed-off-by: Joe Hattori <joe@pf.is.s.u-tokyo.ac.jp>
Link: https://patch.msgid.link/20241218040935.1921416-1-joe@pf.is.s.u-tokyo.ac.jp
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
include/linux/pm_wakeup.h

index 222f7530806c5cb7101ef0b3729aa9e1e161ca59..d501c09c60cd2de3d7aca5c46761c0321220d412 100644 (file)
@@ -240,4 +240,21 @@ static inline int device_init_wakeup(struct device *dev, bool enable)
        return 0;
 }
 
+static void device_disable_wakeup(void *dev)
+{
+       device_init_wakeup(dev, false);
+}
+
+/**
+ * devm_device_init_wakeup - Resource managed device wakeup initialization.
+ * @dev: Device to handle.
+ *
+ * This function is the devm managed version of device_init_wakeup(dev, true).
+ */
+static inline int devm_device_init_wakeup(struct device *dev)
+{
+       device_init_wakeup(dev, true);
+       return devm_add_action_or_reset(dev, device_disable_wakeup, dev);
+}
+
 #endif /* _LINUX_PM_WAKEUP_H */