Source-Changes-HG archive

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

[src/trunk]: src/sys/uvm Add uvm_pagewanted_p(): return true if someone is wa...



details:   https://anonhg.NetBSD.org/src/rev/4e57e24f87fa
branches:  trunk
changeset: 1010396:4e57e24f87fa
user:      ad <ad%NetBSD.org@localhost>
date:      Sun May 24 19:46:59 2020 +0000

description:
Add uvm_pagewanted_p(): return true if someone is waiting on the page and
assert caller has correct lock to observe that.

diffstat:

 sys/uvm/uvm_page.c |  21 ++++++++++++++++++---
 sys/uvm/uvm_page.h |   3 ++-
 2 files changed, 20 insertions(+), 4 deletions(-)

diffs (67 lines):

diff -r c7f766e879c2 -r 4e57e24f87fa sys/uvm/uvm_page.c
--- a/sys/uvm/uvm_page.c        Sun May 24 19:46:10 2020 +0000
+++ b/sys/uvm/uvm_page.c        Sun May 24 19:46:59 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_page.c,v 1.237 2020/05/19 20:46:39 ad Exp $        */
+/*     $NetBSD: uvm_page.c,v 1.238 2020/05/24 19:46:59 ad Exp $        */
 
 /*-
  * Copyright (c) 2019, 2020 The NetBSD Foundation, Inc.
@@ -95,7 +95,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_page.c,v 1.237 2020/05/19 20:46:39 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_page.c,v 1.238 2020/05/24 19:46:59 ad Exp $");
 
 #include "opt_ddb.h"
 #include "opt_uvm.h"
@@ -1718,8 +1718,8 @@
        KASSERT(uvm_page_owner_locked_p(pg, false));
 
        mutex_enter(&pg->interlock);
+       pg->pqflags |= PQ_WANTED;
        rw_exit(lock);
-       pg->pqflags |= PQ_WANTED;
        UVM_UNLOCK_AND_WAIT(pg, &pg->interlock, false, wmesg, 0);
 }
 
@@ -1744,6 +1744,21 @@
        }
 }
 
+/*
+ * uvm_pagewanted_p: return true if someone is waiting on the page
+ *
+ * => object must be write locked (lock out all concurrent access)
+ */
+
+bool
+uvm_pagewanted_p(struct vm_page *pg)
+{
+
+       KASSERT(uvm_page_owner_locked_p(pg, true));
+
+       return (atomic_load_relaxed(&pg->pqflags) & PQ_WANTED) != 0;
+}
+
 #if defined(UVM_PAGE_TRKOWN)
 /*
  * uvm_page_own: set or release page ownership
diff -r c7f766e879c2 -r 4e57e24f87fa sys/uvm/uvm_page.h
--- a/sys/uvm/uvm_page.h        Sun May 24 19:46:10 2020 +0000
+++ b/sys/uvm/uvm_page.h        Sun May 24 19:46:59 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_page.h,v 1.103 2020/05/17 19:38:17 ad Exp $        */
+/*     $NetBSD: uvm_page.h,v 1.104 2020/05/24 19:46:59 ad Exp $        */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -378,6 +378,7 @@
 bool uvm_pagereadonly_p(struct vm_page *);
 bool uvm_page_locked_p(struct vm_page *);
 void uvm_pagewakeup(struct vm_page *);
+bool uvm_pagewanted_p(struct vm_page *);
 void uvm_pagewait(struct vm_page *, krwlock_t *, const char *);
 
 int uvm_page_lookup_freelist(struct vm_page *);



Home | Main Index | Thread Index | Old Index