summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/mvme88k/mvme88k/pmap.c29
1 files changed, 17 insertions, 12 deletions
diff --git a/sys/arch/mvme88k/mvme88k/pmap.c b/sys/arch/mvme88k/mvme88k/pmap.c
index 9fc3bbc93de..489e76010f3 100644
--- a/sys/arch/mvme88k/mvme88k/pmap.c
+++ b/sys/arch/mvme88k/mvme88k/pmap.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: pmap.c,v 1.78 2003/09/27 13:05:30 miod Exp $ */
+/* $OpenBSD: pmap.c,v 1.79 2003/09/29 13:05:56 miod Exp $ */
/*
* Copyright (c) 2001, 2002, 2003 Miodrag Vallat
* Copyright (c) 1998-2001 Steve Murphree, Jr.
@@ -179,10 +179,10 @@ kpdt_entry_t kpdt_free;
#define MAX_KERNEL_PDT_SIZE (KERNEL_PDT_SIZE + OBIO_PDT_SIZE)
/*
- * Two pages of scratch space.
+ * Two pages of scratch space per cpu.
* Used in pmap_copy_page() and pmap_zero_page().
*/
-vaddr_t phys_map_vaddr1, phys_map_vaddr2;
+vaddr_t phys_map_vaddr1, phys_map_vaddr2, phys_map_vaddr_end;
#define PV_ENTRY_NULL ((pv_entry_t) 0)
@@ -932,7 +932,8 @@ pmap_bootstrap(vaddr_t load_start, paddr_t *phys_start, paddr_t *phys_end,
*/
phys_map_vaddr1 = round_page(*virt_start);
- phys_map_vaddr2 = phys_map_vaddr1 + PAGE_SIZE * max_cpus;
+ phys_map_vaddr2 = phys_map_vaddr1 + (max_cpus << PAGE_SHIFT);
+ phys_map_vaddr_end = phys_map_vaddr2 + 2 * (max_cpus << PAGE_SHIFT);
/*
* To make 1:1 mapping of virt:phys, throw away a few phys pages.
@@ -1038,9 +1039,11 @@ pmap_bootstrap(vaddr_t load_start, paddr_t *phys_start, paddr_t *phys_end,
* pmap_enter() on these won't barf in
* pmap_remove_range().
*/
- pte = pmap_pte(kernel_pmap, phys_map_vaddr1);
+ pte = pmap_pte(kernel_pmap,
+ phys_map_vaddr1 + (i << PAGE_SHIFT));
*pte = PG_NV;
- pte = pmap_pte(kernel_pmap, phys_map_vaddr2);
+ pte = pmap_pte(kernel_pmap,
+ phys_map_vaddr2 + (i << PAGE_SHIFT));
*pte = PG_NV;
/* Load supervisor pointer to segment table. */
cmmu_remote_set_sapr(i, apr_data);
@@ -1126,7 +1129,7 @@ pmap_zero_page(struct vm_page *pg)
pt_entry_t *srcpte;
cpu = cpu_number();
- srcva = (vaddr_t)(phys_map_vaddr1 + (cpu * PAGE_SIZE));
+ srcva = (vaddr_t)(phys_map_vaddr1 + (cpu << PAGE_SHIFT));
srcpte = pmap_pte(kernel_pmap, srcva);
SPLVM(spl);
@@ -2065,7 +2068,7 @@ pmap_enter(pmap_t pmap, vaddr_t va, paddr_t pa, vm_prot_t prot, int flags)
* Remove old mapping from the PV list if necessary.
*/
- if (va == phys_map_vaddr1 || va == phys_map_vaddr2) {
+ if (va >= phys_map_vaddr1 && va < phys_map_vaddr_end) {
flush_atc_entry(users, va, TRUE);
} else {
pmap_remove_range(pmap, va, va + PAGE_SIZE);
@@ -2074,7 +2077,7 @@ pmap_enter(pmap_t pmap, vaddr_t va, paddr_t pa, vm_prot_t prot, int flags)
pg = PHYS_TO_VM_PAGE(pa);
#ifdef DEBUG
if ((pmap_con_dbg & (CD_ENT | CD_NORM)) == (CD_ENT | CD_NORM)) {
- if (va == phys_map_vaddr1 || va == phys_map_vaddr2) {
+ if (va >= phys_map_vaddr1 && va < phys_map_vaddr_end) {
printf("vaddr1 0x%x vaddr2 0x%x va 0x%x pa 0x%x managed %x\n",
phys_map_vaddr1, phys_map_vaddr2, va, old_pa,
pg != NULL ? 1 : 0);
@@ -2087,7 +2090,7 @@ pmap_enter(pmap_t pmap, vaddr_t va, paddr_t pa, vm_prot_t prot, int flags)
if (pg != NULL) {
#ifdef DEBUG
if ((pmap_con_dbg & (CD_ENT | CD_NORM)) == (CD_ENT | CD_NORM)) {
- if (va == phys_map_vaddr1 || va == phys_map_vaddr2) {
+ if (va >= phys_map_vaddr1 && va < phys_map_vaddr_end) {
printf("va 0x%x and managed pa 0x%x\n", va, pa);
}
}
@@ -2646,9 +2649,11 @@ changebit_Retry:
if (pte == PT_ENTRY_NULL)
panic("pmap_changebit: bad pv list entry.");
if (!PDT_VALID(pte))
- panic("pmap_changebit: invalid pte");
+ printf("pmap_changebit: invalid pte %x pg %x %x\n",
+ *pte, pg, VM_PAGE_TO_PHYS(pg));
if (ptoa(PG_PFNUM(*pte)) != VM_PAGE_TO_PHYS(pg))
- panic("pmap_changebit: pte doesn't point to page");
+ panic("pmap_changebit: pte %x doesn't point to page %x %x\n",
+ *pte, pg, VM_PAGE_TO_PHYS(pg));
#endif
/*