Module Name: src Committed By: pooka Date: Wed Dec 1 17:22:52 UTC 2010
Modified Files: src/lib/librumpuser: rumpuser_pth.c src/sys/rump/include/rump: rumpuser.h src/sys/rump/librump/rumpkern: locks.c locks_up.c Log Message: implement mutex_owner() To generate a diff of this commit: cvs rdiff -u -r1.5 -r1.6 src/lib/librumpuser/rumpuser_pth.c cvs rdiff -u -r1.56 -r1.57 src/sys/rump/include/rump/rumpuser.h cvs rdiff -u -r1.43 -r1.44 src/sys/rump/librump/rumpkern/locks.c cvs rdiff -u -r1.4 -r1.5 src/sys/rump/librump/rumpkern/locks_up.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/lib/librumpuser/rumpuser_pth.c diff -u src/lib/librumpuser/rumpuser_pth.c:1.5 src/lib/librumpuser/rumpuser_pth.c:1.6 --- src/lib/librumpuser/rumpuser_pth.c:1.5 Wed Dec 1 15:01:52 2010 +++ src/lib/librumpuser/rumpuser_pth.c Wed Dec 1 17:22:51 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: rumpuser_pth.c,v 1.5 2010/12/01 15:01:52 pooka Exp $ */ +/* $NetBSD: rumpuser_pth.c,v 1.6 2010/12/01 17:22:51 pooka Exp $ */ /* * Copyright (c) 2007-2010 Antti Kantee. All Rights Reserved. @@ -27,7 +27,7 @@ #include <sys/cdefs.h> #if !defined(lint) -__RCSID("$NetBSD: rumpuser_pth.c,v 1.5 2010/12/01 15:01:52 pooka Exp $"); +__RCSID("$NetBSD: rumpuser_pth.c,v 1.6 2010/12/01 17:22:51 pooka Exp $"); #endif /* !lint */ #ifdef __linux__ @@ -354,8 +354,8 @@ free(mtx); } -int -rumpuser_mutex_held(struct rumpuser_mtx *mtx) +struct lwp * +rumpuser_mutex_owner(struct rumpuser_mtx *mtx) { if (__predict_false(!mtx->iskmutex)) { @@ -363,7 +363,7 @@ abort(); } - return mtx->owner == rumpuser_get_curlwp(); + return mtx->owner; } void Index: src/sys/rump/include/rump/rumpuser.h diff -u src/sys/rump/include/rump/rumpuser.h:1.56 src/sys/rump/include/rump/rumpuser.h:1.57 --- src/sys/rump/include/rump/rumpuser.h:1.56 Wed Dec 1 15:02:04 2010 +++ src/sys/rump/include/rump/rumpuser.h Wed Dec 1 17:22:51 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: rumpuser.h,v 1.56 2010/12/01 15:02:04 pooka Exp $ */ +/* $NetBSD: rumpuser.h,v 1.57 2010/12/01 17:22:51 pooka Exp $ */ /* * Copyright (c) 2007 Antti Kantee. All Rights Reserved. @@ -132,7 +132,7 @@ int rumpuser_mutex_tryenter(struct rumpuser_mtx *); void rumpuser_mutex_exit(struct rumpuser_mtx *); void rumpuser_mutex_destroy(struct rumpuser_mtx *); -int rumpuser_mutex_held(struct rumpuser_mtx *); +struct lwp *rumpuser_mutex_owner(struct rumpuser_mtx *); struct rumpuser_rw; Index: src/sys/rump/librump/rumpkern/locks.c diff -u src/sys/rump/librump/rumpkern/locks.c:1.43 src/sys/rump/librump/rumpkern/locks.c:1.44 --- src/sys/rump/librump/rumpkern/locks.c:1.43 Wed Dec 1 14:59:38 2010 +++ src/sys/rump/librump/rumpkern/locks.c Wed Dec 1 17:22:51 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: locks.c,v 1.43 2010/12/01 14:59:38 pooka Exp $ */ +/* $NetBSD: locks.c,v 1.44 2010/12/01 17:22:51 pooka Exp $ */ /* * Copyright (c) 2007, 2008 Antti Kantee. All Rights Reserved. @@ -29,7 +29,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: locks.c,v 1.43 2010/12/01 14:59:38 pooka Exp $"); +__KERNEL_RCSID(0, "$NetBSD: locks.c,v 1.44 2010/12/01 17:22:51 pooka Exp $"); #include <sys/param.h> #include <sys/kmem.h> @@ -109,7 +109,14 @@ mutex_owned(kmutex_t *mtx) { - return rumpuser_mutex_held(RUMPMTX(mtx)); + return mutex_owner(mtx) == curlwp; +} + +struct lwp * +mutex_owner(kmutex_t *mtx) +{ + + return rumpuser_mutex_owner(RUMPMTX(mtx)); } #define RUMPRW(rw) (*(struct rumpuser_rw **)(rw)) Index: src/sys/rump/librump/rumpkern/locks_up.c diff -u src/sys/rump/librump/rumpkern/locks_up.c:1.4 src/sys/rump/librump/rumpkern/locks_up.c:1.5 --- src/sys/rump/librump/rumpkern/locks_up.c:1.4 Mon Jun 14 21:04:56 2010 +++ src/sys/rump/librump/rumpkern/locks_up.c Wed Dec 1 17:22:51 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: locks_up.c,v 1.4 2010/06/14 21:04:56 pooka Exp $ */ +/* $NetBSD: locks_up.c,v 1.5 2010/12/01 17:22:51 pooka Exp $ */ /* * Copyright (c) 2010 Antti Kantee. All Rights Reserved. @@ -35,7 +35,7 @@ */ #include <sys/cdefs.h> -__KERNEL_RCSID(0, "$NetBSD: locks_up.c,v 1.4 2010/06/14 21:04:56 pooka Exp $"); +__KERNEL_RCSID(0, "$NetBSD: locks_up.c,v 1.5 2010/12/01 17:22:51 pooka Exp $"); #include <sys/param.h> #include <sys/kernel.h> @@ -157,6 +157,13 @@ return upm->upm_owner == curlwp; } +struct lwp * +mutex_owner(kmutex_t *mtx) +{ + + return upm->upm_owner; +} + struct uprw { struct lwp *uprw_owner; int uprw_readers;