From: Andrzej Hajda Date: Mon, 24 Oct 2016 09:40:48 +0000 (+0200) Subject: drm/exynos/hdmi: use optional regulator_get for hdmi-en X-Git-Tag: submit/tizen/20161216.052309~65 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=243f7d05260cb1f6dc7abf009f3004a0ebfd10ff;p=platform%2Fkernel%2Flinux-exynos.git drm/exynos/hdmi: use optional regulator_get for hdmi-en hdmi-en is an optional regulator so it should be better handled by devm_regulator_get_optional call. Change-Id: I2cbb12c54c43b10ebac76a00a5ef954c2ae627f6 Signed-off-by: Andrzej Hajda Signed-off-by: Inki Dae --- diff --git a/drivers/gpu/drm/exynos/exynos_hdmi.c b/drivers/gpu/drm/exynos/exynos_hdmi.c index 96cd9e5e3c0d..91b7a305e75b 100644 --- a/drivers/gpu/drm/exynos/exynos_hdmi.c +++ b/drivers/gpu/drm/exynos/exynos_hdmi.c @@ -2150,19 +2150,15 @@ static int hdmi_resources_init(struct hdmi_context *hdata) return ret; } - hdata->reg_hdmi_en = devm_regulator_get(dev, "hdmi-en"); - if (IS_ERR(hdata->reg_hdmi_en) && PTR_ERR(hdata->reg_hdmi_en) != -ENOENT) { - DRM_ERROR("failed to get hdmi-en regulator\n"); - return PTR_ERR(hdata->reg_hdmi_en); - } - if (!IS_ERR(hdata->reg_hdmi_en)) { + hdata->reg_hdmi_en = devm_regulator_get_optional(dev, "hdmi-en"); + if (PTR_ERR(hdata->reg_hdmi_en) != -ENODEV) { + if (IS_ERR(hdata->reg_hdmi_en)) + return PTR_ERR(hdata->reg_hdmi_en); + ret = regulator_enable(hdata->reg_hdmi_en); - if (ret) { + if (ret) DRM_ERROR("failed to enable hdmi-en regulator\n"); - return ret; - } - } else - hdata->reg_hdmi_en = NULL; + } return hdmi_bridge_init(hdata); } @@ -2417,7 +2413,7 @@ static int hdmi_remove(struct platform_device *pdev) pm_runtime_disable(&pdev->dev); - if (hdata->reg_hdmi_en) + if (!IS_ERR(hdata->reg_hdmi_en)) regulator_disable(hdata->reg_hdmi_en); if (hdata->hdmiphy_port)