Commit 39a9ad8f authored by Sean Paul's avatar Sean Paul

drm/rockchip: Don't continue trying to enable crtc on failure

If vop_enable fails, don't continue on, it causes system hangs.
Reviewed-by: default avatarYakir Yank <ykk@rock-chips.com>
Tested-by: default avatarYakir Yank <ykk@rock-chips.com>
Signed-off-by: default avatarSean Paul <seanpaul@chromium.org>
Link: http://patchwork.freedesktop.org/patch/msgid/1471302749-2811-1-git-send-email-seanpaul@chromium.org
parent cfe63423
...@@ -428,7 +428,7 @@ static void vop_dsp_hold_valid_irq_disable(struct vop *vop) ...@@ -428,7 +428,7 @@ static void vop_dsp_hold_valid_irq_disable(struct vop *vop)
spin_unlock_irqrestore(&vop->irq_lock, flags); spin_unlock_irqrestore(&vop->irq_lock, flags);
} }
static void vop_enable(struct drm_crtc *crtc) static int vop_enable(struct drm_crtc *crtc)
{ {
struct vop *vop = to_vop(crtc); struct vop *vop = to_vop(crtc);
int ret; int ret;
...@@ -436,26 +436,20 @@ static void vop_enable(struct drm_crtc *crtc) ...@@ -436,26 +436,20 @@ static void vop_enable(struct drm_crtc *crtc)
ret = pm_runtime_get_sync(vop->dev); ret = pm_runtime_get_sync(vop->dev);
if (ret < 0) { if (ret < 0) {
dev_err(vop->dev, "failed to get pm runtime: %d\n", ret); dev_err(vop->dev, "failed to get pm runtime: %d\n", ret);
return; goto err_put_pm_runtime;
} }
ret = clk_enable(vop->hclk); ret = clk_enable(vop->hclk);
if (ret < 0) { if (WARN_ON(ret < 0))
dev_err(vop->dev, "failed to enable hclk - %d\n", ret); goto err_put_pm_runtime;
return;
}
ret = clk_enable(vop->dclk); ret = clk_enable(vop->dclk);
if (ret < 0) { if (WARN_ON(ret < 0))
dev_err(vop->dev, "failed to enable dclk - %d\n", ret);
goto err_disable_hclk; goto err_disable_hclk;
}
ret = clk_enable(vop->aclk); ret = clk_enable(vop->aclk);
if (ret < 0) { if (WARN_ON(ret < 0))
dev_err(vop->dev, "failed to enable aclk - %d\n", ret);
goto err_disable_dclk; goto err_disable_dclk;
}
/* /*
* Slave iommu shares power, irq and clock with vop. It was associated * Slave iommu shares power, irq and clock with vop. It was associated
...@@ -485,7 +479,7 @@ static void vop_enable(struct drm_crtc *crtc) ...@@ -485,7 +479,7 @@ static void vop_enable(struct drm_crtc *crtc)
drm_crtc_vblank_on(crtc); drm_crtc_vblank_on(crtc);
return; return 0;
err_disable_aclk: err_disable_aclk:
clk_disable(vop->aclk); clk_disable(vop->aclk);
...@@ -493,6 +487,9 @@ static void vop_enable(struct drm_crtc *crtc) ...@@ -493,6 +487,9 @@ static void vop_enable(struct drm_crtc *crtc)
clk_disable(vop->dclk); clk_disable(vop->dclk);
err_disable_hclk: err_disable_hclk:
clk_disable(vop->hclk); clk_disable(vop->hclk);
err_put_pm_runtime:
pm_runtime_put_sync(vop->dev);
return ret;
} }
static void vop_crtc_disable(struct drm_crtc *crtc) static void vop_crtc_disable(struct drm_crtc *crtc)
...@@ -912,10 +909,16 @@ static void vop_crtc_enable(struct drm_crtc *crtc) ...@@ -912,10 +909,16 @@ static void vop_crtc_enable(struct drm_crtc *crtc)
u16 vact_st = adjusted_mode->vtotal - adjusted_mode->vsync_start; u16 vact_st = adjusted_mode->vtotal - adjusted_mode->vsync_start;
u16 vact_end = vact_st + vdisplay; u16 vact_end = vact_st + vdisplay;
uint32_t val; uint32_t val;
int ret;
WARN_ON(vop->event); WARN_ON(vop->event);
vop_enable(crtc); ret = vop_enable(crtc);
if (ret) {
DRM_DEV_ERROR(vop->dev, "Failed to enable vop (%d)\n", ret);
return;
}
/* /*
* If dclk rate is zero, mean that scanout is stop, * If dclk rate is zero, mean that scanout is stop,
* we don't need wait any more. * we don't need wait any more.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment