[PATCH v2 1/2] regulator: core: Implement regulator_is_enabled() call
Alexander Shiyan
eagle.alexander923 at gmail.com
Tue Apr 1 22:41:08 PDT 2025
Signed-off-by: Alexander Shiyan <eagle.alexander923 at gmail.com>
---
drivers/regulator/core.c | 14 ++++++++++++++
include/regulator.h | 6 ++++++
2 files changed, 20 insertions(+)
diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c
index 2c3b009ea6..be98f4a279 100644
--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -610,6 +610,20 @@ int regulator_disable(struct regulator *r)
return regulator_disable_rdev(r->rdev);
}
+int regulator_is_enabled(struct regulator *r)
+{
+ if (!r)
+ return 0;
+
+ if (r->rdev->always_on)
+ return 1;
+
+ if (r->rdev->desc->ops->is_enabled)
+ return r->rdev->desc->ops->is_enabled(r->rdev);
+
+ return r->rdev->enable_count;
+}
+
int regulator_set_voltage(struct regulator *r, int min_uV, int max_uV)
{
if (!r)
diff --git a/include/regulator.h b/include/regulator.h
index 9785b8ac07..cb542b05c6 100644
--- a/include/regulator.h
+++ b/include/regulator.h
@@ -217,6 +217,7 @@ void regulator_put(struct regulator *r);
struct regulator *regulator_get_name(const char *name);
int regulator_enable(struct regulator *);
int regulator_disable(struct regulator *);
+int regulator_is_enabled(struct regulator *);
int regulator_is_enabled_regmap(struct regulator_dev *);
int regulator_enable_regmap(struct regulator_dev *);
int regulator_disable_regmap(struct regulator_dev *);
@@ -285,6 +286,11 @@ static inline int regulator_disable(struct regulator *r)
return 0;
}
+static inline int regulator_is_enabled(struct regulator *r)
+{
+ return 1;
+}
+
static inline int regulator_set_voltage(struct regulator *regulator,
int min_uV, int max_uV)
{
--
2.39.1
More information about the barebox
mailing list