Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys Add a rw_owner_running() for the pagedaemon.



details:   https://anonhg.NetBSD.org/src/rev/59e96cd85128
branches:  trunk
changeset: 1006636:59e96cd85128
user:      ad <ad%NetBSD.org@localhost>
date:      Tue Jan 21 20:29:51 2020 +0000

description:
Add a rw_owner_running() for the pagedaemon.

diffstat:

 sys/kern/kern_rwlock.c |  27 +++++++++++++++++++++++++--
 sys/sys/rwlock.h       |   3 ++-
 2 files changed, 27 insertions(+), 3 deletions(-)

diffs (62 lines):

diff -r 48fd4cff7f35 -r 59e96cd85128 sys/kern/kern_rwlock.c
--- a/sys/kern/kern_rwlock.c    Tue Jan 21 20:04:30 2020 +0000
+++ b/sys/kern/kern_rwlock.c    Tue Jan 21 20:29:51 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: kern_rwlock.c,v 1.62 2020/01/20 18:48:15 ad Exp $      */
+/*     $NetBSD: kern_rwlock.c,v 1.63 2020/01/21 20:29:51 ad Exp $      */
 
 /*-
  * Copyright (c) 2002, 2006, 2007, 2008, 2009, 2019, 2020
@@ -39,7 +39,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: kern_rwlock.c,v 1.62 2020/01/20 18:48:15 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: kern_rwlock.c,v 1.63 2020/01/21 20:29:51 ad Exp $");
 
 #include "opt_lockdebug.h"
 
@@ -792,3 +792,26 @@
 
        return (void *)(owner & RW_THREAD);
 }
+
+/*
+ * rw_owner_running:
+ *
+ *     Return true if a RW lock is unheld, or write held and the owner is
+ *     running on a CPU.  For the pagedaemon.
+ */
+bool
+rw_owner_running(const krwlock_t *rw)
+{
+#ifdef MULTIPROCESSOR
+       uintptr_t owner;
+       bool rv;
+
+       kpreempt_disable();
+       owner = rw->rw_owner;
+       rv = (owner & RW_THREAD) == 0 || rw_oncpu(owner);
+       kpreempt_enable();
+       return rv;
+#else
+       return rw_owner(rw) == curlwp;
+#endif
+}
diff -r 48fd4cff7f35 -r 59e96cd85128 sys/sys/rwlock.h
--- a/sys/sys/rwlock.h  Tue Jan 21 20:04:30 2020 +0000
+++ b/sys/sys/rwlock.h  Tue Jan 21 20:29:51 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: rwlock.h,v 1.14 2020/01/21 04:09:10 thorpej Exp $      */
+/*     $NetBSD: rwlock.h,v 1.15 2020/01/21 20:29:51 ad Exp $   */
 
 /*-
  * Copyright (c) 2002, 2006, 2007, 2008, 2019, 2020 The NetBSD Foundation, Inc.
@@ -84,6 +84,7 @@
 void   rw_vector_exit(krwlock_t *);
 int    rw_vector_tryenter(krwlock_t *, const krw_t);
 void   _rw_init(krwlock_t *, uintptr_t);
+bool   rw_owner_running(const krwlock_t *);
 #endif /* __RWLOCK_PRIVATE */
 
 struct krwlock {



Home | Main Index | Thread Index | Old Index