diff options
author | Mike Larkin <mlarkin@cvs.openbsd.org> | 2014-07-10 12:14:49 +0000 |
---|---|---|
committer | Mike Larkin <mlarkin@cvs.openbsd.org> | 2014-07-10 12:14:49 +0000 |
commit | ad6731aec6a359c2c2ad68a6399d92cecad155cc (patch) | |
tree | 402049e22e91863b5f9400d37a8e58cbcbe38663 /sys/arch/amd64 | |
parent | da0925a2447e3b1ffedb2aedd8eb0f96659af9df (diff) |
fix some errors in lockdebug code. not enabled by default.
ok dlg@
Diffstat (limited to 'sys/arch/amd64')
-rw-r--r-- | sys/arch/amd64/amd64/lock_machdep.c | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/sys/arch/amd64/amd64/lock_machdep.c b/sys/arch/amd64/amd64/lock_machdep.c index 3afdf49e8f5..1f1d847fccd 100644 --- a/sys/arch/amd64/amd64/lock_machdep.c +++ b/sys/arch/amd64/amd64/lock_machdep.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lock_machdep.c,v 1.5 2014/03/14 02:08:57 dlg Exp $ */ +/* $OpenBSD: lock_machdep.c,v 1.6 2014/07/10 12:14:48 mlarkin Exp $ */ /* * Copyright (c) 2007 Artur Grabowski <art@openbsd.org> @@ -57,7 +57,7 @@ __mp_lock_spin(struct __mp_lock *mpl, u_int me) SPINLOCK_SPIN_HOOK; if (ticks == 0) { - db_printf("__mp_lock(0x%x): lock spun out", mpl); + db_printf("__mp_lock(%p): lock spun out", mpl); Debugger(); } #endif @@ -95,7 +95,7 @@ __mp_unlock(struct __mp_lock *mpl) long rf = read_rflags(); #ifdef MP_LOCKDEBUG - if (mpl->mpl_cpu != curcpu()) { + if (!__mp_lock_held(mpl)) { db_printf("__mp_unlock(%p): not held lock\n", mpl); Debugger(); } @@ -130,7 +130,7 @@ __mp_release_all_but_one(struct __mp_lock *mpl) int rv = cpu->mplc_depth - 1; #ifdef MP_LOCKDEBUG - if (mpl->mpl_cpu != curcpu()) { + if (!__mp_lock_held(mpl)) { db_printf("__mp_release_all_but_one(%p): not held lock\n", mpl); Debugger(); } @@ -155,4 +155,3 @@ __mp_lock_held(struct __mp_lock *mpl) return (cpu->mplc_ticket == mpl->mpl_ticket && cpu->mplc_depth > 0); } - |