Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/aarch64/aarch64 use pmapboot_enter_range()



details:   https://anonhg.NetBSD.org/src/rev/bc22055c875c
branches:  trunk
changeset: 1007786:bc22055c875c
user:      ryo <ryo%NetBSD.org@localhost>
date:      Sat Feb 29 21:10:09 2020 +0000

description:
use pmapboot_enter_range()

diffstat:

 sys/arch/aarch64/aarch64/pmap.c |  54 +++++++---------------------------------
 1 files changed, 10 insertions(+), 44 deletions(-)

diffs (81 lines):

diff -r 5aa114065c3c -r bc22055c875c sys/arch/aarch64/aarch64/pmap.c
--- a/sys/arch/aarch64/aarch64/pmap.c   Sat Feb 29 21:09:11 2020 +0000
+++ b/sys/arch/aarch64/aarch64/pmap.c   Sat Feb 29 21:10:09 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: pmap.c,v 1.64 2020/02/10 19:04:01 ryo Exp $    */
+/*     $NetBSD: pmap.c,v 1.65 2020/02/29 21:10:09 ryo Exp $    */
 
 /*
  * Copyright (c) 2017 Ryo Shimizu <ryo%nerv.org@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.64 2020/02/10 19:04:01 ryo Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.65 2020/02/29 21:10:09 ryo Exp $");
 
 #include "opt_arm_debug.h"
 #include "opt_ddb.h"
@@ -301,54 +301,20 @@
 
 static const struct pmap_devmap *pmap_devmap_table;
 
-#define        L1_BLK_MAPPABLE_P(va, pa, size)                                 \
-    ((((va) | (pa)) & L1_OFFSET) == 0 && (size) >= L1_SIZE)
-
-#define        L2_BLK_MAPPABLE_P(va, pa, size)                                 \
-    ((((va) | (pa)) & L2_OFFSET) == 0 && (size) >= L2_SIZE)
-
 static vsize_t
 pmap_map_chunk(vaddr_t va, paddr_t pa, vsize_t size,
     vm_prot_t prot, u_int flags)
 {
        pt_entry_t attr;
-       psize_t blocksize;
-       int rc;
-
        vsize_t resid = round_page(size);
-       vsize_t mapped = 0;
-
-       while (resid > 0) {
-               if (L1_BLK_MAPPABLE_P(va, pa, resid)) {
-                       blocksize = L1_SIZE;
-                       attr = L1_BLOCK;
-               } else if (L2_BLK_MAPPABLE_P(va, pa, resid)) {
-                       blocksize = L2_SIZE;
-                       attr = L2_BLOCK;
-               } else {
-                       blocksize = L3_SIZE;
-                       attr = L3_PAGE;
-               }
-
-               attr = _pmap_pte_adjust_prot(attr, prot, VM_PROT_ALL, false);
-               attr = _pmap_pte_adjust_cacheflags(attr, flags);
-
-               rc = pmapboot_enter(va, pa, blocksize, blocksize, attr,
-                   PMAPBOOT_ENTER_NOOVERWRITE, bootpage_alloc, NULL);
-               if (rc != 0) {
-                       panic("%s: pmapboot_enter failed. %lx is already mapped?\n",
-                           __func__, va);
-               }
-
-               va += blocksize;
-               pa += blocksize;
-               resid -= blocksize;
-               mapped += blocksize;
-
-               aarch64_tlbi_by_va(va);
-       }
-
-       return mapped;
+
+       attr = _pmap_pte_adjust_prot(0, prot, VM_PROT_ALL, false);
+       attr = _pmap_pte_adjust_cacheflags(attr, flags);
+       pmapboot_enter_range(va, pa, resid, attr,
+           PMAPBOOT_ENTER_NOOVERWRITE, bootpage_alloc, printf);
+       aarch64_tlbi_all();
+
+       return resid;
 }
 
 void



Home | Main Index | Thread Index | Old Index