[PATCH 1/2] regulator: core: Implement regulator_is_enabled() call
Alexander Shiyan
eagle.alexander923 at gmail.com
Thu Mar 27 23:31:21 PDT 2025
Signed-off-by: Alexander Shiyan <eagle.alexander923 at gmail.com>
---
drivers/regulator/core.c | 11 +++++++++++
include/regulator.h | 6 ++++++
2 files changed, 17 insertions(+)
diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c
index 2c3b009ea6..c9e30ab3fd 100644
--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -610,6 +610,17 @@ 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;
+
+ 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..5fdf1602dd 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 0;
+}
+
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