public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH v2] regulator: gpio: check return value of of_get_named_gpio
@ 2016-03-16 15:21 Mihai Mihalache
  2016-03-17 11:45 ` Applied "regulator: gpio: check return value of of_get_named_gpio" to the regulator tree Mark Brown
  0 siblings, 1 reply; 2+ messages in thread
From: Mihai Mihalache @ 2016-03-16 15:21 UTC (permalink / raw)
  To: linux-kernel, broonie, lgirdwood
  Cc: yousaf.kaukab, hans.holmberg, mihai.d.mihalache

At boot time the regulator driver can be initialized before the
gpio, in which case the call to of_get_named_gpio will return
EPROBE_DEFER. This value is silently passed to regulator_register
which will return success, although the gpio is not registered
(regulator_ena_gpio_request not called) as the value passed is
detected as invalid. The gpio_regulator_probe will therefore
succeed win no gpio requested.

Signed-off-by: Mihai Mihalache <mihai.d.mihalache@intel.com>
Reviewed-by: Hans Holmberg <hans.holmberg@intel.com>
---

History:
	V1:
	- Fix comment from Mark Brown
	V2:
	- Explicit check for EPROBE_DEFER for optional property, 
	  Mark Brown's feedback.

 drivers/regulator/gpio-regulator.c | 2 ++
 1 file changed, 2 insertions(+)

diff --git a/drivers/regulator/gpio-regulator.c b/drivers/regulator/gpio-regulator.c
index 464018d..f3147ef 100644
--- a/drivers/regulator/gpio-regulator.c
+++ b/drivers/regulator/gpio-regulator.c
@@ -162,6 +162,8 @@ of_get_gpio_regulator_config(struct device *dev, struct device_node *np,
 	of_property_read_u32(np, "startup-delay-us", &config->startup_delay);
 
 	config->enable_gpio = of_get_named_gpio(np, "enable-gpio", 0);
+	if (config->enable_gpio == -EPROBE_DEFER)
+		return ERR_PTR(-EPROBE_DEFER);
 
 	/* Fetch GPIOs. - optional property*/
 	ret = of_gpio_count(np);
-- 
2.1.4

^ permalink raw reply related	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2016-03-17 11:45 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2016-03-16 15:21 [PATCH v2] regulator: gpio: check return value of of_get_named_gpio Mihai Mihalache
2016-03-17 11:45 ` Applied "regulator: gpio: check return value of of_get_named_gpio" to the regulator tree Mark Brown

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox