mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
regulator: tps65090: Hand over GPIO to regulator core
The GPIO descriptors used by the TPS65090 driver are retrieved during probe() and it is really helpful to have those under devres management because of all the errorpaths in the intialization. Using the new dev_gpiod_unhinge() call we can remove the devres management of the descriptor right before handing it over to the regulators core. Signed-off-by: Linus Walleij <linus.walleij@linaro.org> Reviewed-by: Marek Szyprowski <m.szyprowski@samsung.com> Tested-by: Marek Szyprowski <m.szyprowski@samsung.com> Reviewed-by: Charles Keepax <ckeepax@opensource.cirrus.com> Signed-off-by: Mark Brown <broonie@kernel.org>
This commit is contained in:
parent
1f5163fcf1
commit
870311e52b
@ -480,6 +480,12 @@ static int tps65090_regulator_probe(struct platform_device *pdev)
|
|||||||
else
|
else
|
||||||
config.of_node = NULL;
|
config.of_node = NULL;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Hand the GPIO descriptor management over to the regulator
|
||||||
|
* core, remove it from devres management.
|
||||||
|
*/
|
||||||
|
if (config.ena_gpiod)
|
||||||
|
devm_gpiod_unhinge(&pdev->dev, config.ena_gpiod);
|
||||||
rdev = devm_regulator_register(&pdev->dev, ri->desc, &config);
|
rdev = devm_regulator_register(&pdev->dev, ri->desc, &config);
|
||||||
if (IS_ERR(rdev)) {
|
if (IS_ERR(rdev)) {
|
||||||
dev_err(&pdev->dev, "failed to register regulator %s\n",
|
dev_err(&pdev->dev, "failed to register regulator %s\n",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user