Merge tag 'pidfd.v5.16' of git://git.kernel.org/pub/scm/linux/kernel/git/brauner...
[linux-2.6-microblaze.git] / drivers / devfreq / devfreq.c
index 06333d4..7906220 100644 (file)
@@ -1301,6 +1301,32 @@ err_out:
 }
 EXPORT_SYMBOL(devfreq_add_governor);
 
+static void devm_devfreq_remove_governor(void *governor)
+{
+       WARN_ON(devfreq_remove_governor(governor));
+}
+
+/**
+ * devm_devfreq_add_governor() - Add devfreq governor
+ * @dev:       device which adds devfreq governor
+ * @governor:  the devfreq governor to be added
+ *
+ * This is a resource-managed variant of devfreq_add_governor().
+ */
+int devm_devfreq_add_governor(struct device *dev,
+                             struct devfreq_governor *governor)
+{
+       int err;
+
+       err = devfreq_add_governor(governor);
+       if (err)
+               return err;
+
+       return devm_add_action_or_reset(dev, devm_devfreq_remove_governor,
+                                       governor);
+}
+EXPORT_SYMBOL(devm_devfreq_add_governor);
+
 /**
  * devfreq_remove_governor() - Remove devfreq feature from a device.
  * @governor:  the devfreq governor to be removed