Module Name:    src
Committed By:   riastradh
Date:           Sun Dec 19 11:08:03 UTC 2021

Modified Files:
        src/sys/external/bsd/drm2/dist/drm: drm_vblank.c

Log Message:
drm: Fix vblank locking.


To generate a diff of this commit:
cvs rdiff -u -r1.5 -r1.6 src/sys/external/bsd/drm2/dist/drm/drm_vblank.c

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.

Modified files:

Index: src/sys/external/bsd/drm2/dist/drm/drm_vblank.c
diff -u src/sys/external/bsd/drm2/dist/drm/drm_vblank.c:1.5 src/sys/external/bsd/drm2/dist/drm/drm_vblank.c:1.6
--- src/sys/external/bsd/drm2/dist/drm/drm_vblank.c:1.5	Sun Dec 19 09:52:34 2021
+++ src/sys/external/bsd/drm2/dist/drm/drm_vblank.c	Sun Dec 19 11:08:02 2021
@@ -1,4 +1,4 @@
-/*	$NetBSD: drm_vblank.c,v 1.5 2021/12/19 09:52:34 riastradh Exp $	*/
+/*	$NetBSD: drm_vblank.c,v 1.6 2021/12/19 11:08:02 riastradh Exp $	*/
 
 /*
  * drm_irq.c IRQ and vblank support
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: drm_vblank.c,v 1.5 2021/12/19 09:52:34 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: drm_vblank.c,v 1.6 2021/12/19 11:08:02 riastradh Exp $");
 
 #include <linux/export.h>
 #include <linux/moduleparam.h>
@@ -167,6 +167,8 @@ static void drm_reset_vblank_timestamp(s
 	ktime_t t_vblank;
 	int count = DRM_TIMESTAMP_MAXRETRIES;
 
+	assert_spin_locked(&dev->vbl_lock);
+
 	spin_lock(&dev->vblank_time_lock);
 
 	/*
@@ -218,6 +220,8 @@ static void drm_update_vblank_count(stru
 	int framedur_ns = vblank->framedur_ns;
 	u32 max_vblank_count = drm_max_vblank_count(dev, pipe);
 
+	assert_spin_locked(&dev->vbl_lock);
+
 	/*
 	 * Interrupts were disabled prior to this call, so deal with counter
 	 * wrap if needed.
@@ -1832,8 +1836,11 @@ bool drm_handle_vblank(struct drm_device
 	 */
 	spin_lock(&dev->vblank_time_lock);
 
+	spin_lock(&dev->vbl_lock);
+
 	/* Vblank irq handling disabled. Nothing to do. */
 	if (!vblank->enabled) {
+		spin_unlock(&dev->vbl_lock);
 		spin_unlock(&dev->vblank_time_lock);
 		spin_unlock_irqrestore(&dev->event_lock, irqflags);
 		return false;
@@ -1858,6 +1865,8 @@ bool drm_handle_vblank(struct drm_device
 		       drm_vblank_offdelay > 0 &&
 		       !atomic_read(&vblank->refcount));
 
+	spin_unlock(&dev->vbl_lock);
+
 	drm_handle_vblank_events(dev, pipe);
 
 	spin_unlock_irqrestore(&dev->event_lock, irqflags);

Reply via email to