[PATCH 4.19 209/239] regulator: core: Let boot-on regulators be powered off

From: Greg Kroah-Hartman
Date: Mon Jan 24 2022 - 15:07:09 EST


From: Pascal Paillet <p.paillet@xxxxxx>

commit 089b3f61ecfc43ca4ea26d595e1d31ead6de3f7b upstream.

Boot-on regulators are always kept on because their use_count value
is now incremented at boot time and never cleaned.

Only increment count value for alway-on regulators.
regulator_late_cleanup() is now able to power off boot-on regulators
when unused.

Fixes: 05f224ca6693 ("regulator: core: Clean enabling always-on regulators + their supplies")
Signed-off-by: Pascal Paillet <p.paillet@xxxxxx>
Link: https://lore.kernel.org/r/20191113102737.27831-1-p.paillet@xxxxxx
Signed-off-by: Mark Brown <broonie@xxxxxxxxxx>
Acked-by: Andre Kalb <andre.kalb@xxxxxx>
Signed-off-by: Greg Kroah-Hartman <gregkh@xxxxxxxxxxxxxxxxxxx>
---
drivers/regulator/core.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)

--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -1211,7 +1211,9 @@ static int set_machine_constraints(struc
rdev_err(rdev, "failed to enable\n");
return ret;
}
- rdev->use_count++;
+
+ if (rdev->constraints->always_on)
+ rdev->use_count++;
}

print_constraints(rdev);