mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-18 02:46:06 +00:00
drm/panel: lvds: Handle the optional regulator case properly
The devm_regulator_get_optional function, unlike it was assumed in the commit a1c55bccf600 ("drm/panel: lvds: Add support for the power-supply property"), is actually returning an error pointer with -ENODEV instead of NULL when there's no regulator to find. Make sure we handle that case properly. Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Tested-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com> Fixes: a1c55bccf600 ("drm/panel: lvds: Add support for the power-supply property") Signed-off-by: Maxime Ripard <maxime.ripard@free-electrons.com> Link: https://patchwork.freedesktop.org/patch/msgid/20180110155941.16109-1-maxime.ripard@free-electrons.com
This commit is contained in:
parent
86a3ae5879
commit
a0d605372a
@ -215,10 +215,17 @@ static int panel_lvds_probe(struct platform_device *pdev)
|
|||||||
lvds->supply = devm_regulator_get_optional(lvds->dev, "power");
|
lvds->supply = devm_regulator_get_optional(lvds->dev, "power");
|
||||||
if (IS_ERR(lvds->supply)) {
|
if (IS_ERR(lvds->supply)) {
|
||||||
ret = PTR_ERR(lvds->supply);
|
ret = PTR_ERR(lvds->supply);
|
||||||
dev_err(lvds->dev, "failed to request regulator: %d\n", ret);
|
|
||||||
|
if (ret != -ENODEV) {
|
||||||
|
if (ret != -EPROBE_DEFER)
|
||||||
|
dev_err(lvds->dev, "failed to request regulator: %d\n",
|
||||||
|
ret);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
lvds->supply = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
/* Get GPIOs and backlight controller. */
|
/* Get GPIOs and backlight controller. */
|
||||||
lvds->enable_gpio = devm_gpiod_get_optional(lvds->dev, "enable",
|
lvds->enable_gpio = devm_gpiod_get_optional(lvds->dev, "enable",
|
||||||
GPIOD_OUT_LOW);
|
GPIOD_OUT_LOW);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user