Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/powerpc/oea Split pmap_bootstrap() into 2 functions:



details:   https://anonhg.NetBSD.org/src/rev/6fd91154b1ea
branches:  trunk
changeset: 1019180:6fd91154b1ea
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Mon Mar 01 01:53:46 2021 +0000

description:
Split pmap_bootstrap() into 2 functions:
- pmap_bootstrap1(), which sets up the low-level pmap data structures.
- pmap_bootstrap2(), which actually programs the MMU hardware based on
  pmap_bootstrap1()'s work.

pmap_bootstrap() is still provided as a wrapper around the two, but this
provides flexibility to platforms that might need to do additional work
between these two phases.

diffstat:

 sys/arch/powerpc/include/oea/pmap.h |   4 +-
 sys/arch/powerpc/oea/pmap.c         |  71 +++++++++++++++++++++++++-----------
 2 files changed, 51 insertions(+), 24 deletions(-)

diffs (145 lines):

diff -r 723edf520152 -r 6fd91154b1ea sys/arch/powerpc/include/oea/pmap.h
--- a/sys/arch/powerpc/include/oea/pmap.h       Mon Mar 01 01:43:15 2021 +0000
+++ b/sys/arch/powerpc/include/oea/pmap.h       Mon Mar 01 01:53:46 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.h,v 1.32 2020/07/06 10:57:03 rin Exp $    */
+/*     $NetBSD: pmap.h,v 1.33 2021/03/01 01:53:46 thorpej Exp $        */
 
 /*-
  * Copyright (C) 1995, 1996 Wolfgang Solfrank.
@@ -145,6 +145,8 @@
 extern unsigned int pmap_pteg_mask;
 
 void pmap_bootstrap(vaddr_t, vaddr_t);
+void pmap_bootstrap1(vaddr_t, vaddr_t);
+void pmap_bootstrap2(void);
 bool pmap_extract(pmap_t, vaddr_t, paddr_t *);
 bool pmap_query_bit(struct vm_page *, int);
 bool pmap_clear_bit(struct vm_page *, int);
diff -r 723edf520152 -r 6fd91154b1ea sys/arch/powerpc/oea/pmap.c
--- a/sys/arch/powerpc/oea/pmap.c       Mon Mar 01 01:43:15 2021 +0000
+++ b/sys/arch/powerpc/oea/pmap.c       Mon Mar 01 01:53:46 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.c,v 1.98 2020/07/06 09:34:17 rin Exp $    */
+/*     $NetBSD: pmap.c,v 1.99 2021/03/01 01:53:46 thorpej Exp $        */
 /*-
  * Copyright (c) 2001 The NetBSD Foundation, Inc.
  * All rights reserved.
@@ -63,7 +63,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.98 2020/07/06 09:34:17 rin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.99 2021/03/01 01:53:46 thorpej Exp $");
 
 #define        PMAP_NOOPNAMES
 
@@ -3145,12 +3145,11 @@
 #endif /* PMAP_OEA64_BRIDGE */
 
 /*
- * This is not part of the defined PMAP interface and is specific to the
- * PowerPC architecture.  This is called during initppc, before the system
- * is really initialized.
+ * Set up the bottom level of the data structures necessary for the kernel
+ * to manage memory.  MMU hardware is programmed in pmap_bootstrap2().
  */
 void
-pmap_bootstrap(paddr_t kernelstart, paddr_t kernelend)
+pmap_bootstrap1(paddr_t kernelstart, paddr_t kernelend)
 {
        struct mem_region *mp, tmp;
        paddr_t s, e;
@@ -3413,34 +3412,20 @@
                    continue;
 #endif
                pmap_kernel()->pm_sr[i] = KERNELN_SEGMENT(i)|SR_PRKEY;
-               __asm volatile ("mtsrin %0,%1"
-                             :: "r"(KERNELN_SEGMENT(i)|SR_PRKEY), "r"(i << ADDR_SR_SHFT));
        }
 
        pmap_kernel()->pm_sr[KERNEL_SR] = KERNEL_SEGMENT|SR_SUKEY|SR_PRKEY;
-       __asm volatile ("mtsr %0,%1"
-                     :: "n"(KERNEL_SR), "r"(KERNEL_SEGMENT));
 #ifdef KERNEL2_SR
        pmap_kernel()->pm_sr[KERNEL2_SR] = KERNEL2_SEGMENT|SR_SUKEY|SR_PRKEY;
-       __asm volatile ("mtsr %0,%1"
-                     :: "n"(KERNEL2_SR), "r"(KERNEL2_SEGMENT));
 #endif
 #endif /* PMAP_OEA || PMAP_OEA64_BRIDGE */
 #if defined (PMAP_OEA)
        for (i = 0; i < 16; i++) {
                if (iosrtable[i] & SR601_T) {
                        pmap_kernel()->pm_sr[i] = iosrtable[i];
-                       __asm volatile ("mtsrin %0,%1"
-                           :: "r"(iosrtable[i]), "r"(i << ADDR_SR_SHFT));
                }
        }
-       __asm volatile ("sync; mtsdr1 %0; isync"
-                     :: "r"((uintptr_t)pmap_pteg_table | (pmap_pteg_mask >> 10)));
-#elif defined (PMAP_OEA64) || defined (PMAP_OEA64_BRIDGE)
-       __asm __volatile ("sync; mtsdr1 %0; isync"
-                     :: "r"((uintptr_t)pmap_pteg_table | (32 - __builtin_clz(pmap_pteg_mask >> 11))));
 #endif
-       tlbia();
 
 #ifdef ALTIVEC
        pmap_use_altivec = cpu_altivec;
@@ -3537,14 +3522,54 @@
                        pmap_pte_insert(ptegidx, &pt);
                }
 #endif
-
-               __asm volatile ("mtsrin %0,%1"
-                             :: "r"(sr), "r"(kernelstart));
        }
 #endif
+}
+
+/*
+ * Using the data structures prepared in pmap_bootstrap1(), program
+ * the MMU hardware.
+ */
+void
+pmap_bootstrap2(void)
+{
+/* PMAP_OEA64_BRIDGE does support these instructions */
+#if defined (PMAP_OEA) || defined (PMAP_OEA64_BRIDGE)
+       for (int i = 0; i < 16; i++) {
+#if defined(PPC_OEA601)
+               /* XXX wedges for segment register 0xf , so set later */
+               if ((iosrtable[i] & SR601_T) && ((MFPVR() >> 16) == MPC601))
+                       continue;
+#endif /* PPC_OEA601 */
+               __asm volatile("mtsrin %0,%1"
+                       :: "r"(pmap_kernel()->pm_sr[i]),
+                          "r"(i << ADDR_SR_SHFT));
+       }
+#endif /* PMAP_OEA || PMAP_OEA64_BRIDGE */
+#if defined (PMAP_OEA)
+        __asm volatile("sync; mtsdr1 %0; isync"
+               :: "r"((uintptr_t)pmap_pteg_table | (pmap_pteg_mask >> 10)));
+#elif defined (PMAP_OEA64) || defined (PMAP_OEA64_BRIDGE)
+       __asm __volatile("sync; mtsdr1 %0; isync"
+               :: "r"((uintptr_t)pmap_pteg_table |
+                      (32 - __builtin_clz(pmap_pteg_mask >> 11))));
+#endif
+       tlbia();
 
 #if defined(PMAPDEBUG)
        if ( pmapdebug )
            pmap_print_mmuregs();
 #endif
 }
+
+/*
+ * This is not part of the defined PMAP interface and is specific to the
+ * PowerPC architecture.  This is called during initppc, before the system
+ * is really initialized.
+ */
+void
+pmap_bootstrap(paddr_t kernelstart, paddr_t kernelend)
+{
+       pmap_bootstrap1(kernelstart, kernelend);
+       pmap_bootstrap2();
+}



Home | Main Index | Thread Index | Old Index