summaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/drm_irq.c
diff options
context:
space:
mode:
authorDaniel Vetter2014-09-10 17:36:08 +0200
committerDaniel Vetter2014-09-11 13:31:57 +0200
commitab8905f1c6a74d695c6096791ec4b349bc985b8a (patch)
treeed9ba95e827e77ce07cb46c0081a13b77def7827 /drivers/gpu/drm/drm_irq.c
parentdrm: Use vblank_disable_and_save in drm_vblank_cleanup() (diff)
downloadkernel-qcow2-linux-ab8905f1c6a74d695c6096791ec4b349bc985b8a.tar.gz
kernel-qcow2-linux-ab8905f1c6a74d695c6096791ec4b349bc985b8a.tar.xz
kernel-qcow2-linux-ab8905f1c6a74d695c6096791ec4b349bc985b8a.zip
drm: Really never disable vblank irqs for offdelay==0
With the new support for immediate vblank disabling we always disabled the vblank interrupt right away, irrespective of the vblank offdelay setting. But being able to let vblanks run forever is fairly useful for debugging, so restore that behaviour. Suggested-by: Mario Kleiner <mario.kleiner.de@gmail.com> Cc: Mario Kleiner <mario.kleiner.de@gmail.com> Cc: Matt Roper <matthew.d.roper@intel.com> Cc: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Matt Roper <matthew.d.roper@intel.com> Reviewed-by: Mario Kleiner <mario.kleiner.de@gmail.com> Signed-off-by: Daniel Vetter <daniel.vetter@intel.com>
Diffstat (limited to 'drivers/gpu/drm/drm_irq.c')
-rw-r--r--drivers/gpu/drm/drm_irq.c6
1 files changed, 4 insertions, 2 deletions
diff --git a/drivers/gpu/drm/drm_irq.c b/drivers/gpu/drm/drm_irq.c
index 9be760145cb7..87d148cec877 100644
--- a/drivers/gpu/drm/drm_irq.c
+++ b/drivers/gpu/drm/drm_irq.c
@@ -1005,9 +1005,11 @@ void drm_vblank_put(struct drm_device *dev, int crtc)
/* Last user schedules interrupt disable */
if (atomic_dec_and_test(&vblank->refcount)) {
- if (dev->vblank_disable_immediate || drm_vblank_offdelay < 0)
+ if (drm_vblank_offdelay == 0)
+ return;
+ else if (dev->vblank_disable_immediate || drm_vblank_offdelay < 0)
vblank_disable_fn((unsigned long)vblank);
- else if (drm_vblank_offdelay > 0)
+ else
mod_timer(&vblank->disable_timer,
jiffies + ((drm_vblank_offdelay * HZ)/1000));
}