shithub: riscv

Download patch

ref: 1b44caa0c40d7b722a7d9edd0a6eaefe1616c4b0
parent: a597496b19993379ad2cde4d7dd11e20b2122c00
author: cinap_lenrek <[email protected]>
date: Sat Apr 6 12:42:27 EDT 2024

kernel: print warning in rlock() and wlock() when we hold spinlocks

Just like for qlock(), print a warning when
the process calls rlock() and wlock() while
holding a spinlock.

--- a/sys/src/9/port/qlock.c
+++ b/sys/src/9/port/qlock.c
@@ -153,6 +153,11 @@
 {
 	Proc *p;
 
+	if(m->ilockdepth != 0)
+		print("rlock: %#p: ilockdepth %d\n", getcallerpc(&q), m->ilockdepth);
+	if(up != nil && up->nlocks)
+		print("rlock: %#p: nlocks %d\n", getcallerpc(&q), up->nlocks);
+
 	lock(&q->use);
 	rwstats.rlock++;
 	if(q->writer == 0 && q->head == nil){
@@ -208,6 +213,11 @@
 	uintptr pc;
 
 	pc = getcallerpc(&q);
+
+	if(m->ilockdepth != 0)
+		print("wlock: %#p: ilockdepth %d\n", pc, m->ilockdepth);
+	if(up != nil && up->nlocks)
+		print("wlock: %#p: nlocks %d\n", pc, up->nlocks);
 
 	lock(&q->use);
 	rwstats.wlock++;