diff options
author | Dave Airlie <airlied@redhat.com> | 2019-07-05 04:54:48 +0200 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2019-07-05 06:51:03 +0200 |
commit | a0b2cf792ac9db7bb73e599e516adfb9dca8e60b (patch) | |
tree | dcef458326e76c68bcf5e66853e478d173b01a3e | |
parent | Merge branch 'etnaviv/fixes' of https://git.pengutronix.de/git/lst/linux into... (diff) | |
parent | drm/imx: only send event on crtc disable if kept disabled (diff) | |
download | linux-a0b2cf792ac9db7bb73e599e516adfb9dca8e60b.tar.xz linux-a0b2cf792ac9db7bb73e599e516adfb9dca8e60b.zip |
Merge tag 'imx-drm-fixes-2019-07-04' of git://git.pengutronix.de/git/pza/linux into drm-fixes
drm/imx: fix stale vblank timestamp after a modeset
This series fixes stale vblank timestamps in the first event sent after
a crtc was disabled. The core now is notified via drm_crtc_vblank_off
before sending the last pending event in atomic_disable. If the crtc is
reenabled right away during to a modeset, the event is not sent at all,
as the next vblank will take care of it.
Signed-off-by: Dave Airlie <airlied@redhat.com>
From: Philipp Zabel <p.zabel@pengutronix.de>
Link: https://patchwork.freedesktop.org/patch/msgid/1562237119.6641.16.camel@pengutronix.de
-rw-r--r-- | drivers/gpu/drm/imx/ipuv3-crtc.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/gpu/drm/imx/ipuv3-crtc.c b/drivers/gpu/drm/imx/ipuv3-crtc.c index 9cc1d678674f..c436a28d50e4 100644 --- a/drivers/gpu/drm/imx/ipuv3-crtc.c +++ b/drivers/gpu/drm/imx/ipuv3-crtc.c @@ -91,14 +91,14 @@ static void ipu_crtc_atomic_disable(struct drm_crtc *crtc, ipu_dc_disable(ipu); ipu_prg_disable(ipu); + drm_crtc_vblank_off(crtc); + spin_lock_irq(&crtc->dev->event_lock); - if (crtc->state->event) { + if (crtc->state->event && !crtc->state->active) { drm_crtc_send_vblank_event(crtc, crtc->state->event); crtc->state->event = NULL; } spin_unlock_irq(&crtc->dev->event_lock); - - drm_crtc_vblank_off(crtc); } static void imx_drm_crtc_reset(struct drm_crtc *crtc) |