Skip to content

Commit cf1ad55

Browse files
osctobebroonie
authored andcommitted
regulator: defer probe when trying to get voltage from unresolved supply
regulator_get_voltage_rdev() is called in regulator probe() when applying machine constraints. The "fixed" commit exposed the problem that non-bypassed regulators can forward the request to its parent (like bypassed ones) supply. Return -EPROBE_DEFER when the supply is expected but not resolved yet. Fixes: aea6cb9 ("regulator: resolve supply after creating regulator") Cc: stable@vger.kernel.org Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl> Reported-by: Ondřej Jirman <megous@megous.com> Reported-by: Corentin Labbe <clabbe.montjoie@gmail.com> Tested-by: Ondřej Jirman <megous@megous.com> Link: https://lore.kernel.org/r/a9041d68b4d35e4a2dd71629c8a6422662acb5ee.1604351936.git.mirq-linux@rere.qmqm.pl Signed-off-by: Mark Brown <broonie@kernel.org>
1 parent f59cddd commit cf1ad55

1 file changed

Lines changed: 2 additions & 0 deletions

File tree

drivers/regulator/core.c

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -4165,6 +4165,8 @@ int regulator_get_voltage_rdev(struct regulator_dev *rdev)
41654165
ret = rdev->desc->fixed_uV;
41664166
} else if (rdev->supply) {
41674167
ret = regulator_get_voltage_rdev(rdev->supply->rdev);
4168+
} else if (rdev->supply_name) {
4169+
return -EPROBE_DEFER;
41684170
} else {
41694171
return -EINVAL;
41704172
}

0 commit comments

Comments
 (0)