diff options
-rw-r--r-- | drivers/gpu/drm/exynos/exynos_hdmi.c | 20 |
1 files changed, 8 insertions, 12 deletions
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) |