[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[XENVBD PATCH 1/3] ring: Remove LockThread tracking from release builds


  • To: win-pv-devel@xxxxxxxxxxxxxxxxxxxx
  • From: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>
  • Date: Mon, 18 May 2026 12:25:24 +0200
  • Authentication-results: eu.smtp.expurgate.cloud; dkim=pass header.s=selector1 header.d=vates.tech header.i="@vates.tech" header.h="From:Subject:Date:Message-ID:To:Cc:MIME-Version:Content-Type:In-Reply-To:References:Feedback-ID"
  • Cc: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>
  • Delivery-date: Mon, 18 May 2026 10:25:42 +0000
  • Feedback-id: default:8631fc262581453bbf619ec5b2062170:Sweego
  • List-id: Developer list for the Windows PV Drivers subproject <win-pv-devel.lists.xenproject.org>

LockThread is not used for anything besides debugging. Move the current
code managing LockThread into a debug-only #ifdef.

Signed-off-by: Tu Dinh <ngoc-tu.dinh@xxxxxxxxxx>
---
 src/xenvbd/ring.c | 12 ++++++++++++
 1 file changed, 12 insertions(+)

diff --git a/src/xenvbd/ring.c b/src/xenvbd/ring.c
index 625675d..5a8f236 100644
--- a/src/xenvbd/ring.c
+++ b/src/xenvbd/ring.c
@@ -79,7 +79,9 @@ typedef struct _XENVBD_BLKIF_RING {
     BOOLEAN                         Enabled;
     BOOLEAN                         Stopped;
     PVOID                           Lock;
+#if DBG
     PKTHREAD                        LockThread;
+#endif
     LIST_ENTRY                      SrbQueue;
     LIST_ENTRY                      PreparedQueue;
     LIST_ENTRY                      SubmittedList;
@@ -1322,7 +1324,9 @@ BlkifRingSwizzle(
     LIST_ENTRY              List;
     ULONG                   Count;
 
+#if DBG
     ASSERT3P(BlkifRing->LockThread, == , KeGetCurrentThread());
+#endif
 
     InitializeListHead(&List);
 
@@ -1465,11 +1469,13 @@ __BlkifRingTryAcquireLock(
 
     KeMemoryBarrier();
 
+#if DBG
     if (Acquired) {
         ASSERT3P(BlkifRing->LockThread, == , NULL);
         BlkifRing->LockThread = KeGetCurrentThread();
         KeMemoryBarrier();
     }
+#endif
 
     return Acquired;
 }
@@ -1508,13 +1514,17 @@ __BlkifRingTryReleaseLock(
     ULONG_PTR               New;
     BOOLEAN                 Released;
 
+#if DBG
     ASSERT3U(KeGetCurrentIrql(), == , DISPATCH_LEVEL);
     ASSERT3P(KeGetCurrentThread(), == , BlkifRing->LockThread);
+#endif
 
     Old = XENVBD_LOCK_BIT;
     New = 0;
 
+#if DBG
     BlkifRing->LockThread = NULL;
+#endif
 
     KeMemoryBarrier();
 
@@ -1524,11 +1534,13 @@ __BlkifRingTryReleaseLock(
 
     KeMemoryBarrier();
 
+#if DBG
     if (!Released) {
         ASSERT3P(BlkifRing->LockThread, == , NULL);
         BlkifRing->LockThread = KeGetCurrentThread();
         KeMemoryBarrier();
     }
+#endif
 
     return Released;
 }
-- 
2.54.0.windows.1



--
Ngoc Tu Dinh | Vates XCP-ng Developer

XCP-ng & Xen Orchestra - Vates solutions

web: https://vates.tech

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.