Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/arm Adjust for UVM locking changes



details:   https://anonhg.NetBSD.org/src/rev/f18dfdeffb40
branches:  trunk
changeset: 1007649:f18dfdeffb40
user:      ad <ad%NetBSD.org@localhost>
date:      Mon Feb 24 20:31:56 2020 +0000

description:
Adjust for UVM locking changes

diffstat:

 sys/arch/arm/arm32/pmap.c         |  37 ++++++++++++++-----------------------
 sys/arch/arm/include/arm32/pmap.h |   7 +++----
 2 files changed, 17 insertions(+), 27 deletions(-)

diffs (128 lines):

diff -r 7af967538035 -r f18dfdeffb40 sys/arch/arm/arm32/pmap.c
--- a/sys/arch/arm/arm32/pmap.c Mon Feb 24 20:11:45 2020 +0000
+++ b/sys/arch/arm/arm32/pmap.c Mon Feb 24 20:31:56 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.c,v 1.393 2020/02/23 10:22:07 skrll Exp $ */
+/*     $NetBSD: pmap.c,v 1.394 2020/02/24 20:31:56 ad Exp $    */
 
 /*
  * Copyright 2003 Wasabi Systems, Inc.
@@ -198,8 +198,9 @@
 #endif
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.393 2020/02/23 10:22:07 skrll Exp $");
-
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.394 2020/02/24 20:31:56 ad Exp $");
+
+#include <sys/atomic.h>
 #include <sys/param.h>
 #include <sys/types.h>
 #include <sys/atomic.h>
@@ -548,7 +549,7 @@
                return;
 #endif
 
-       mutex_enter(pm->pm_lock);
+       mutex_enter(&pm->pm_lock);
 }
 
 static inline void
@@ -558,7 +559,7 @@
        if (__predict_false(db_onproc != NULL))
                return;
 #endif
-       mutex_exit(pm->pm_lock);
+       mutex_exit(&pm->pm_lock);
 }
 
 static inline void
@@ -3026,10 +3027,9 @@
 
        pm = pool_cache_get(&pmap_cache, PR_WAITOK);
 
-       mutex_init(&pm->pm_obj_lock, MUTEX_DEFAULT, IPL_NONE);
-       uvm_obj_init(&pm->pm_obj, NULL, false, 1);
-       uvm_obj_setlock(&pm->pm_obj, &pm->pm_obj_lock);
-
+       mutex_init(&pm->pm_lock, MUTEX_DEFAULT, IPL_NONE);
+
+       pm->pm_refs = 1;
        pm->pm_stats.wired_count = 0;
        pm->pm_stats.resident_count = 1;
 #ifdef ARM_MMU_EXTENDED
@@ -5219,8 +5219,6 @@
 {
        UVMHIST_FUNC(__func__); UVMHIST_CALLED(maphist);
 
-       u_int count;
-
        if (pm == NULL)
                return;
 
@@ -5239,10 +5237,7 @@
        /*
         * Drop reference count
         */
-       mutex_enter(pm->pm_lock);
-       count = --pm->pm_obj.uo_refs;
-       mutex_exit(pm->pm_lock);
-       if (count > 0) {
+       if (atomic_dec_uint_nv(&pm->pm_refs) > 0) {
 #ifndef ARM_MMU_EXTENDED
                if (pmap_is_current(pm)) {
                        if (pm != pmap_kernel())
@@ -5280,8 +5275,7 @@
                ci->ci_pmap_lastuser = NULL;
 #endif
 
-       uvm_obj_destroy(&pm->pm_obj, false);
-       mutex_destroy(&pm->pm_obj_lock);
+       mutex_destroy(&pm->pm_lock);
        pool_cache_put(&pmap_cache, pm);
        UVMHIST_LOG(maphist, "  <-- done", 0, 0, 0, 0);
 }
@@ -5303,9 +5297,7 @@
        pmap_use_l1(pm);
 #endif
 
-       mutex_enter(pm->pm_lock);
-       pm->pm_obj.uo_refs++;
-       mutex_exit(pm->pm_lock);
+       atomic_inc_uint(&pm->pm_refs);
 }
 
 #if (ARM_MMU_V6 + ARM_MMU_V7) > 0
@@ -6209,9 +6201,8 @@
         */
        mutex_init(&pmap_lock, MUTEX_DEFAULT, IPL_VM);
        mutex_init(&kpm_lock, MUTEX_DEFAULT, IPL_NONE);
-       mutex_init(&pm->pm_obj_lock, MUTEX_DEFAULT, IPL_VM);
-       uvm_obj_init(&pm->pm_obj, NULL, false, 1);
-       uvm_obj_setlock(&pm->pm_obj, &pm->pm_obj_lock);
+       mutex_init(&pm->pm_lock, MUTEX_DEFAULT, IPL_VM);
+       pm->pm_refs = 1;
 
        VPRINTF("l1pt ");
        /*
diff -r 7af967538035 -r f18dfdeffb40 sys/arch/arm/include/arm32/pmap.h
--- a/sys/arch/arm/include/arm32/pmap.h Mon Feb 24 20:11:45 2020 +0000
+++ b/sys/arch/arm/include/arm32/pmap.h Mon Feb 24 20:31:56 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.h,v 1.162 2020/02/23 15:12:18 skrll Exp $ */
+/*     $NetBSD: pmap.h,v 1.163 2020/02/24 20:31:56 ad Exp $    */
 
 /*
  * Copyright (c) 2002, 2003 Wasabi Systems, Inc.
@@ -229,9 +229,8 @@
  * The pmap structure itself
  */
 struct pmap {
-       struct uvm_object       pm_obj;
-       kmutex_t                pm_obj_lock;
-#define        pm_lock pm_obj.vmobjlock
+       kmutex_t                pm_lock;
+       u_int                   pm_refs;
 #ifndef ARM_HAS_VBAR
        pd_entry_t              *pm_pl1vec;
        pd_entry_t              pm_l1vec;



Home | Main Index | Thread Index | Old Index