Source-Changes-HG archive

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

[src/trunk]: src/sys/uvm - uvm_unmap_remove(): need to call pmap_update() wit...



details:   https://anonhg.NetBSD.org/src/rev/5070cac0fcb5
branches:  trunk
changeset: 1006357:5070cac0fcb5
user:      ad <ad%NetBSD.org@localhost>
date:      Sun Jan 12 17:46:55 2020 +0000

description:
- uvm_unmap_remove(): need to call pmap_update() with the object still
  locked, otherwise the page could gain a new identity and still be visible
  via a stale mapping.

- Adjust reference counts with atomics.

diffstat:

 sys/uvm/uvm_map.c |  51 ++++++++++++++++++++++-----------------------------
 sys/uvm/uvm_map.h |   4 ++--
 2 files changed, 24 insertions(+), 31 deletions(-)

diffs (136 lines):

diff -r b172ff8bdd23 -r 5070cac0fcb5 sys/uvm/uvm_map.c
--- a/sys/uvm/uvm_map.c Sun Jan 12 16:11:51 2020 +0000
+++ b/sys/uvm/uvm_map.c Sun Jan 12 17:46:55 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_map.c,v 1.370 2020/01/05 15:57:15 para Exp $       */
+/*     $NetBSD: uvm_map.c,v 1.371 2020/01/12 17:46:55 ad Exp $ */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -66,7 +66,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uvm_map.c,v 1.370 2020/01/05 15:57:15 para Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uvm_map.c,v 1.371 2020/01/12 17:46:55 ad Exp $");
 
 #include "opt_ddb.h"
 #include "opt_pax.h"
@@ -2240,7 +2240,7 @@
        }
 
        /*
-        * Save the free space hint
+        * save the free space hint
         */
 
        if (map->first_free != &map->header && map->first_free->start >= start)
@@ -2314,6 +2314,18 @@
 
                        uvm_map_lock_entry(entry);
                        pmap_remove(map->pmap, entry->start, entry->end);
+
+                       /*
+                        * note: if map is dying, leave pmap_update() for
+                        * pmap_destroy(), which will be called later.
+                        */
+
+                       if ((map->flags & VM_MAP_DYING) == 0) {
+                               pmap_update(vm_map_pmap(map));
+                       } else {
+                               KASSERT(vm_map_pmap(map) != pmap_kernel());
+                       }
+
                        uvm_map_unlock_entry(entry);
                }
 
@@ -2358,16 +2370,6 @@
                entry = next;
        }
 
-       /*
-        * Note: if map is dying, leave pmap_update() for pmap_destroy(),
-        * which will be called later.
-        */
-       if ((map->flags & VM_MAP_DYING) == 0) {
-               pmap_update(vm_map_pmap(map));
-       } else {
-               KASSERT(vm_map_pmap(map) != pmap_kernel());
-       }
-
        uvm_map_check(map, "unmap_remove leave");
 
        /*
@@ -4254,14 +4256,10 @@
 void
 uvmspace_addref(struct vmspace *vm)
 {
-       struct vm_map *map = &vm->vm_map;
-
-       KASSERT((map->flags & VM_MAP_DYING) == 0);
-
-       mutex_enter(&map->misc_lock);
+
+       KASSERT((vm->vm_map.flags & VM_MAP_DYING) == 0);
        KASSERT(vm->vm_refcnt > 0);
-       vm->vm_refcnt++;
-       mutex_exit(&map->misc_lock);
+       atomic_inc_uint(&vm->vm_refcnt);
 }
 
 /*
@@ -4273,16 +4271,12 @@
 {
        struct vm_map_entry *dead_entries;
        struct vm_map *map = &vm->vm_map;
-       int n;
 
        UVMHIST_FUNC("uvmspace_free"); UVMHIST_CALLED(maphist);
 
        UVMHIST_LOG(maphist,"(vm=%#jx) ref=%jd", (uintptr_t)vm, vm->vm_refcnt,
            0, 0);
-       mutex_enter(&map->misc_lock);
-       n = --vm->vm_refcnt;
-       mutex_exit(&map->misc_lock);
-       if (n > 0)
+       if (atomic_dec_uint_nv(&vm->vm_refcnt) > 0)
                return;
 
        /*
@@ -4777,15 +4771,14 @@
 /*
  * uvm_map_reference: add reference to a map
  *
- * => map need not be locked (we use misc_lock).
+ * => map need not be locked
  */
 
 void
 uvm_map_reference(struct vm_map *map)
 {
-       mutex_enter(&map->misc_lock);
-       map->ref_count++;
-       mutex_exit(&map->misc_lock);
+
+       atomic_inc_uint(&map->ref_count);
 }
 
 void
diff -r b172ff8bdd23 -r 5070cac0fcb5 sys/uvm/uvm_map.h
--- a/sys/uvm/uvm_map.h Sun Jan 12 16:11:51 2020 +0000
+++ b/sys/uvm/uvm_map.h Sun Jan 12 17:46:55 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: uvm_map.h,v 1.76 2020/01/05 15:57:15 para Exp $        */
+/*     $NetBSD: uvm_map.h,v 1.77 2020/01/12 17:46:55 ad Exp $  */
 
 /*
  * Copyright (c) 1997 Charles D. Cranor and Washington University.
@@ -209,7 +209,7 @@
        struct pmap *           pmap;           /* Physical map */
        krwlock_t               lock;           /* Non-intrsafe lock */
        struct lwp *            busy;           /* LWP holding map busy */
-       kmutex_t                misc_lock;      /* Lock for ref_count, cv */
+       kmutex_t                misc_lock;      /* Lock for cv, busy */
        kcondvar_t              cv;             /* For signalling */
        int                     flags;          /* flags */
        struct rb_tree          rb_tree;        /* Tree for entries */



Home | Main Index | Thread Index | Old Index