|
@@ -1320,6 +1320,40 @@ struct regulator *regulator_get(struct device *dev, const char *id)
|
|
|
}
|
|
|
EXPORT_SYMBOL_GPL(regulator_get);
|
|
|
|
|
|
+static void devm_regulator_release(struct device *dev, void *res)
|
|
|
+{
|
|
|
+ regulator_put(*(struct regulator **)res);
|
|
|
+}
|
|
|
+
|
|
|
+/**
|
|
|
+ * devm_regulator_get - Resource managed regulator_get()
|
|
|
+ * @dev: device for regulator "consumer"
|
|
|
+ * @id: Supply name or regulator ID.
|
|
|
+ *
|
|
|
+ * Managed regulator_get(). Regulators returned from this function are
|
|
|
+ * automatically regulator_put() on driver detach. See regulator_get() for more
|
|
|
+ * information.
|
|
|
+ */
|
|
|
+struct regulator *devm_regulator_get(struct device *dev, const char *id)
|
|
|
+{
|
|
|
+ struct regulator **ptr, *regulator;
|
|
|
+
|
|
|
+ ptr = devres_alloc(devm_regulator_release, sizeof(*ptr), GFP_KERNEL);
|
|
|
+ if (!ptr)
|
|
|
+ return ERR_PTR(-ENOMEM);
|
|
|
+
|
|
|
+ regulator = regulator_get(dev, id);
|
|
|
+ if (!IS_ERR(regulator)) {
|
|
|
+ *ptr = regulator;
|
|
|
+ devres_add(dev, ptr);
|
|
|
+ } else {
|
|
|
+ devres_free(ptr);
|
|
|
+ }
|
|
|
+
|
|
|
+ return regulator;
|
|
|
+}
|
|
|
+EXPORT_SYMBOL_GPL(devm_regulator_get);
|
|
|
+
|
|
|
/**
|
|
|
* regulator_get_exclusive - obtain exclusive access to a regulator.
|
|
|
* @dev: device for regulator "consumer"
|