Source-Changes-HG archive

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

[src/trunk]: src/sys/uvm uvm_fault_upper_lookup(): don't call pmap_extract() ...



details:   https://anonhg.NetBSD.org/src/rev/4f7f93975c53
branches:  trunk
changeset: 1008359:4f7f93975c53
user:      ad <ad%NetBSD.org@localhost>
date:      Fri Mar 20 18:50:09 2020 +0000

description:
uvm_fault_upper_lookup(): don't call pmap_extract() and pmap_update() more
often than needed.

diffstat:

 sys/uvm/uvm_fault.c |  31 +++++++++++++++----------------
 1 files changed, 15 insertions(+), 16 deletions(-)

diffs (79 lines):

diff -r d5ce35a2a6d7 -r 4f7f93975c53 sys/uvm/uvm_fault.c
--- a/sys/uvm/uvm_fault.c       Fri Mar 20 17:20:30 2020 +0000
+++ b/sys/uvm/uvm_fault.c       Fri Mar 20 18:50:09 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_fault.c,v 1.219 2020/03/17 18:31:39 ad Exp $       */
+/*     $NetBSD: uvm_fault.c,v 1.220 2020/03/20 18:50:09 ad Exp $       */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_fault.c,v 1.219 2020/03/17 18:31:39 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_fault.c,v 1.220 2020/03/20 18:50:09 ad Exp $");
 
 #include "opt_uvmhist.h"
 
@@ -1166,6 +1166,7 @@
        int lcv;
        vaddr_t currva;
        bool shadowed __unused;
+       bool entered;
        UVMHIST_FUNC("uvm_fault_upper_lookup"); UVMHIST_CALLED(maphist);
 
        /* locked: maps(read), amap(if there) */
@@ -1179,18 +1180,9 @@
 
        currva = flt->startva;
        shadowed = false;
+       entered = false;
        for (lcv = 0; lcv < flt->npages; lcv++, currva += PAGE_SIZE) {
                /*
-                * don't play with VAs that are already mapped
-                * (except for center)
-                */
-               if (lcv != flt->centeridx &&
-                   pmap_extract(ufi->orig_map->pmap, currva, NULL)) {
-                       pages[lcv] = PGO_DONTCARE;
-                       continue;
-               }
-
-               /*
                 * unmapped or center page.   check if any anon at this level.
                 */
                if (amap == NULL || anons[lcv] == NULL) {
@@ -1213,12 +1205,21 @@
 
                KASSERT(anon->an_lock == amap->am_lock);
 
-               /* Ignore loaned and busy pages. */
-               if (pg && pg->loan_count == 0 && (pg->flags & PG_BUSY) == 0) {
+               /*
+                * ignore loaned and busy pages.
+                * don't play with VAs that are already mapped.
+                */
+
+               if (pg && pg->loan_count == 0 && (pg->flags & PG_BUSY) == 0 &&
+                   !pmap_extract(ufi->orig_map->pmap, currva, NULL)) {
                        uvm_fault_upper_neighbor(ufi, flt, currva,
                            pg, anon->an_ref > 1);
+                       entered = true;
                }
        }
+       if (entered) {
+               pmap_update(ufi->orig_map->pmap);
+       }
 
        /* locked: maps(read), amap(if there) */
        KASSERT(amap == NULL || rw_write_held(amap->am_lock));
@@ -1276,8 +1277,6 @@
            readonly ? (flt->enter_prot & ~VM_PROT_WRITE) :
            flt->enter_prot,
            PMAP_CANFAIL | (flt->wire_mapping ? PMAP_WIRED : 0));
-
-       pmap_update(ufi->orig_map->pmap);
 }
 
 /*



Home | Main Index | Thread Index | Old Index