Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/usermode/usermode Fix physical memory size issue. I...



details:   https://anonhg.NetBSD.org/src/rev/e7acdadf0594
branches:  trunk
changeset: 991864:e7acdadf0594
user:      reinoud <reinoud%NetBSD.org@localhost>
date:      Fri Aug 03 06:52:50 2018 +0000

description:
Fix physical memory size issue. It will now happily run on more than one gb.

diffstat:

 sys/arch/usermode/usermode/pmap.c |  35 +++++++++++++++++++++++------------
 1 files changed, 23 insertions(+), 12 deletions(-)

diffs (125 lines):

diff -r c7744ee61acf -r e7acdadf0594 sys/arch/usermode/usermode/pmap.c
--- a/sys/arch/usermode/usermode/pmap.c Fri Aug 03 06:07:02 2018 +0000
+++ b/sys/arch/usermode/usermode/pmap.c Fri Aug 03 06:52:50 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: pmap.c,v 1.110 2018/08/01 12:09:01 reinoud Exp $ */
+/* $NetBSD: pmap.c,v 1.111 2018/08/03 06:52:50 reinoud Exp $ */
 
 /*-
  * Copyright (c) 2011 Reinoud Zandijk <reinoud%NetBSD.org@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.110 2018/08/01 12:09:01 reinoud Exp $");
+__KERNEL_RCSID(0, "$NetBSD: pmap.c,v 1.111 2018/08/03 06:52:50 reinoud Exp $");
 
 #include "opt_memsize.h"
 #include "opt_kmempages.h"
@@ -76,6 +76,14 @@
        struct  pmap_l2 **pm_l1;
 };
 
+/*
+ * pv_table is list of pv_entry structs completely spanning the total memory.
+ * It is indexed on physical page number. Each entry will be daisy chained
+ * with pv_entry records for each usage in all the pmaps.
+ *
+ * kernel_pm_entries contains all kernel L2 pages for its complete map.
+ *
+ */
 
 static struct pv_entry **kernel_pm_entries;
 static struct pv_entry  *pv_table;     /* physical pages info (direct mapped) */
@@ -95,7 +103,6 @@
 static uint64_t pm_entries_size = 0;
 
 static struct pool pmap_pool;
-static struct pool pmap_l1_pool;
 static struct pool pmap_pventry_pool;
 
 /* forwards */
@@ -139,6 +146,7 @@
        vaddr_t free_start, free_end;
        paddr_t pa;
        vaddr_t va;
+       size_t  kmem_k_length, written;
        uintptr_t pg, l1;
        void *addr;
        int err;
@@ -165,6 +173,7 @@
        /* calculate kernel section (R-X) */
        kmem_k_start = (vaddr_t) PAGE_SIZE * (atop(_start)    );
        kmem_k_end   = (vaddr_t) PAGE_SIZE * (atop(&etext) + 1);
+       kmem_k_length = kmem_k_end - kmem_k_start;
 
        /* calculate total available memory space & available pages */
        DRAM_cfg = (vaddr_t) TEXTADDR;
@@ -260,7 +269,7 @@
 #endif
 
        /* protect the current kernel section */
-       err = thunk_mprotect((void *) kmem_k_start, kmem_k_end - kmem_k_start,
+       err = thunk_mprotect((void *) kmem_k_start, kmem_k_length,
                THUNK_PROT_READ | THUNK_PROT_EXEC);
        assert(err == 0);
 
@@ -271,14 +280,18 @@
                THUNK_MADV_WILLNEED | THUNK_MADV_RANDOM);
        assert(err == 0);
 
+       /* map the kernel at the start of the 'memory' file */
+       written = thunk_pwrite(mem_fh, (void *) kmem_k_start, kmem_k_length, 0);
+       assert(written == kmem_k_length);
+       fpos = kmem_k_length;
+
        /* initialize counters */
-       fpos = 0;
        free_start = fpos;     /* in physical space ! */
        free_end   = file_len; /* in physical space ! */
        kmem_kvm_cur_start = kmem_kvm_start;
 
        /* calculate pv table size */
-       phys_npages = (free_end - free_start) / PAGE_SIZE;
+       phys_npages = file_len / PAGE_SIZE;
        pv_table_size = round_page(phys_npages * sizeof(struct pv_entry));
        thunk_printf_debug("claiming %"PRIu64" KB of pv_table for "
                "%"PRIdPTR" pages of physical memory\n",
@@ -292,7 +305,7 @@
 
        /* calculate how big the l1 tables are going to be */
        pm_nl1 = pm_nentries / PMAP_L2_NENTRY;
-       pm_l1_size = pm_nl1 * sizeof(struct pmap_l1 *);
+       pm_l1_size = round_page(pm_nl1 * sizeof(struct pmap_l1 *));
 
        /* claim pv table */
        pv_fpos = fpos;
@@ -449,8 +462,6 @@
        /* create pmap pool */
        pool_init(&pmap_pool, sizeof(struct pmap), 0, 0, 0,
            "pmappool", NULL, IPL_NONE);
-       pool_init(&pmap_l1_pool, pm_l1_size, 0, 0, 0,
-           "pmapl1pool", NULL, IPL_NONE);
        pool_init(&pmap_pventry_pool, sizeof(struct pv_entry), 0, 0, 0,
            "pventry", NULL, IPL_HIGH);
 }
@@ -484,8 +495,8 @@
        pmap->pm_flags = 0;
 
        /* claim l1 table */
-       pmap->pm_l1 = pool_get(&pmap_l1_pool, PR_WAITOK);
-       memset(pmap->pm_l1, 0, pm_l1_size);
+       pmap->pm_l1 = kmem_zalloc(pm_l1_size, KM_SLEEP);
+       assert(pmap->pm_l1);
 
        thunk_printf_debug("\tpmap %p\n", pmap);
 
@@ -527,7 +538,7 @@
                        continue;
                kmem_free(l2tbl, PMAP_L2_SIZE);
        }
-       pool_put(&pmap_l1_pool, pmap->pm_l1);
+       kmem_free(pmap->pm_l1, pm_l1_size);
        pool_put(&pmap_pool, pmap);
 }
 



Home | Main Index | Thread Index | Old Index