summaryrefslogtreecommitdiff
path: root/sys/arch/i386/include
diff options
context:
space:
mode:
authorMatthew Dempsky <matthew@cvs.openbsd.org>2010-09-24 13:21:31 +0000
committerMatthew Dempsky <matthew@cvs.openbsd.org>2010-09-24 13:21:31 +0000
commit7d41d2d54ec72e7e87c510b37c88a79f246c565e (patch)
treea4491d0a119e7c1d9e0fe4280dc229f9e3033dc3 /sys/arch/i386/include
parentd2ebe13a412b859545811580c7b40e4f3c69544c (diff)
Add stricter asserts to DIAGNOSTIC kernels to help catch mutex and
rwlock misuse. In particular, this commit makes the following changes: 1. i386 and amd64 now count the number of active mutexes so that assertwaitok(9) can detect attempts to sleep while holding a mutex. 2. i386 and amd64 check that we actually hold mutexes when passed to mtx_leave(). 3. Calls to rw_exit*() now call rw_assert_{rd,wr}lock() as appropriate. ok krw@, oga@; "sounds good to me" deraadt@; assembly bits double checked by pirofti@
Diffstat (limited to 'sys/arch/i386/include')
-rw-r--r--sys/arch/i386/include/cpu.h6
1 files changed, 5 insertions, 1 deletions
diff --git a/sys/arch/i386/include/cpu.h b/sys/arch/i386/include/cpu.h
index 5896c7230b4..5fafaa0618a 100644
--- a/sys/arch/i386/include/cpu.h
+++ b/sys/arch/i386/include/cpu.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.h,v 1.114 2010/08/11 21:22:44 kettenis Exp $ */
+/* $OpenBSD: cpu.h,v 1.115 2010/09/24 13:21:30 matthew Exp $ */
/* $NetBSD: cpu.h,v 1.35 1996/05/05 19:29:26 christos Exp $ */
/*-
@@ -106,6 +106,10 @@ struct cpu_info {
int ci_idepth;
u_int32_t ci_imask[NIPL];
u_int32_t ci_iunmask[NIPL];
+#ifdef DIAGNOSTIC
+ int ci_mutex_level;
+#define __HAVE_CPU_MUTEX_LEVEL
+#endif
paddr_t ci_idle_pcb_paddr; /* PA of idle PCB */
u_long ci_flags; /* flags; see below */