aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2016-04-07 10:22:36 -0400
committerMark Brown <broonie@kernel.org>2016-04-12 00:32:30 -0400
commitfef95019016ac10e250d2c67a3c97af5797e3938 (patch)
tree02f9349da183e2fdc4d38199d30ad120f89452bf
parentf55532a0c0b8bb6148f4e07853b876ef73bc69ca (diff)
regulator: core: Use parent voltage from the supply when bypassed
When a regulator is in bypass mode it is functioning as a switch returning the voltage set in the regulator will not give the voltage being output by the regulator as it's just passing through its supply. This means that when we are getting the voltage from a regulator we should check to see if it is in bypass mode and if it is we should report the voltage from the supply rather than that which is set on the regulator. Reported-by: Jon Hunter <jonathanh@nvidia.com> Signed-off-by: Mark Brown <broonie@kernel.org> [treding@nvidia.com: return early for bypass mode] Signed-off-by: Thierry Reding <treding@nvidia.com> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--drivers/regulator/core.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c
index e0b764284773..990fd7b3da7d 100644
--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -3109,6 +3109,20 @@ EXPORT_SYMBOL_GPL(regulator_sync_voltage);
3109static int _regulator_get_voltage(struct regulator_dev *rdev) 3109static int _regulator_get_voltage(struct regulator_dev *rdev)
3110{ 3110{
3111 int sel, ret; 3111 int sel, ret;
3112 bool bypassed;
3113
3114 if (rdev->desc->ops->get_bypass) {
3115 ret = rdev->desc->ops->get_bypass(rdev, &bypassed);
3116 if (ret < 0)
3117 return ret;
3118 if (bypassed) {
3119 /* if bypassed the regulator must have a supply */
3120 if (!rdev->supply)
3121 return -EINVAL;
3122
3123 return _regulator_get_voltage(rdev->supply->rdev);
3124 }
3125 }
3112 3126
3113 if (rdev->desc->ops->get_voltage_sel) { 3127 if (rdev->desc->ops->get_voltage_sel) {
3114 sel = rdev->desc->ops->get_voltage_sel(rdev); 3128 sel = rdev->desc->ops->get_voltage_sel(rdev);