summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhb <jhb@FreeBSD.org>2006-06-03 21:11:33 +0000
committerjhb <jhb@FreeBSD.org>2006-06-03 21:11:33 +0000
commitbdcca9d25ab3e9b4623ec20485ddf89e16a616f7 (patch)
tree90c4315ce032709aa7289d88b5a9e68f10ada59e
parent4cc73bae0eced8efc1bf68c57030ace45a486294 (diff)
downloadFreeBSD-src-bdcca9d25ab3e9b4623ec20485ddf89e16a616f7.zip
FreeBSD-src-bdcca9d25ab3e9b4623ec20485ddf89e16a616f7.tar.gz
Bah, fix fat finger in last. Invert the ~ on MTX_FLAGMASK as it's
non-intuitive for the ~ to be built into the mask. All the users now explicitly ~ the mask. In addition, add MTX_UNOWNED to the mask even though it technically isn't a flag. This should unbreak mtx_owner(). Quickly spotted by: kris
-rw-r--r--sys/kern/kern_mutex.c4
-rw-r--r--sys/sys/mutex.h4
2 files changed, 4 insertions, 4 deletions
diff --git a/sys/kern/kern_mutex.c b/sys/kern/kern_mutex.c
index 65b8300..634fa9d 100644
--- a/sys/kern/kern_mutex.c
+++ b/sys/kern/kern_mutex.c
@@ -85,7 +85,7 @@ __FBSDID("$FreeBSD$");
*/
#define mtx_unowned(m) ((m)->mtx_lock == MTX_UNOWNED)
-#define mtx_owner(m) ((struct thread *)((m)->mtx_lock & (MTX_FLAGMASK|MTX_UNOWNED)))
+#define mtx_owner(m) ((struct thread *)((m)->mtx_lock & ~MTX_FLAGMASK))
#ifdef DDB
static void db_show_mtx(struct lock_object *lock);
@@ -527,7 +527,7 @@ _mtx_lock_sleep(struct mtx *m, uintptr_t tid, int opts, const char *file,
* If the current owner of the lock is executing on another
* CPU, spin instead of blocking.
*/
- owner = (struct thread *)(v & MTX_FLAGMASK);
+ owner = (struct thread *)(v & ~MTX_FLAGMASK);
#ifdef ADAPTIVE_GIANT
if (TD_IS_RUNNING(owner)) {
#else
diff --git a/sys/sys/mutex.h b/sys/sys/mutex.h
index 7984a25..a28ea31 100644
--- a/sys/sys/mutex.h
+++ b/sys/sys/mutex.h
@@ -71,7 +71,7 @@
#define MTX_RECURSED 0x00000001 /* lock recursed (for MTX_DEF only) */
#define MTX_CONTESTED 0x00000002 /* lock contested (for MTX_DEF only) */
#define MTX_UNOWNED 0x00000004 /* Cookie for free mutex */
-#define MTX_FLAGMASK ~(MTX_RECURSED | MTX_CONTESTED)
+#define MTX_FLAGMASK (MTX_RECURSED | MTX_CONTESTED | MTX_UNOWNED)
#endif /* _KERNEL */
@@ -322,7 +322,7 @@ extern struct mtx_pool *mtxpool_sleep;
#define mtx_initialized(m) lock_initalized(&(m)->mtx_object)
-#define mtx_owned(m) (((m)->mtx_lock & MTX_FLAGMASK) == (uintptr_t)curthread)
+#define mtx_owned(m) (((m)->mtx_lock & ~MTX_FLAGMASK) == (uintptr_t)curthread)
#define mtx_recursed(m) ((m)->mtx_recurse != 0)
OpenPOWER on IntegriCloud