diff options
author | Jesse Barnes <jbarnes@virtuousgeek.org> | 2010-03-26 19:07:15 +0100 |
---|---|---|
committer | Dave Airlie <airlied@redhat.com> | 2010-04-27 01:37:39 +0200 |
commit | e32ee7fa54e3172e6413cefaaee9222a3f521617 (patch) | |
tree | 9bc7ec6a5d6d2dadd3a38265f4b1ed01a57886af /drivers | |
parent | drm/radeon/kms/evergreen: No EnableYUV table (diff) | |
download | linux-e32ee7fa54e3172e6413cefaaee9222a3f521617.tar.xz linux-e32ee7fa54e3172e6413cefaaee9222a3f521617.zip |
drm: make sure vblank interrupts are disabled at DPMS time
When we call drm_vblank_off() at DPMS off time (to wake any clients so
they don't hang) we need to make sure interrupts are actually disabled.
If drm_vblank_off() gets called before the vblank usage timer expires,
it'll prevent the timer from disabling interrupts since it also clears
the vblank_enabled flag for the pipe.
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/drm_irq.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c index b98384dbd9a7..99ce7dcb28e0 100644 --- a/drivers/gpu/drm/drm_irq.c +++ b/drivers/gpu/drm/drm_irq.c @@ -475,6 +475,7 @@ void drm_vblank_off(struct drm_device *dev, int crtc) unsigned long irqflags; spin_lock_irqsave(&dev->vbl_lock, irqflags); + dev->driver->disable_vblank(dev, crtc); DRM_WAKEUP(&dev->vbl_queue[crtc]); dev->vblank_enabled[crtc] = 0; dev->last_vblank[crtc] = dev->driver->get_vblank_counter(dev, crtc); |