diff options
-rw-r--r-- | sys/arch/sparc/sparc/pmap.c | 19 |
1 files changed, 7 insertions, 12 deletions
diff --git a/sys/arch/sparc/sparc/pmap.c b/sys/arch/sparc/sparc/pmap.c index 47cdde1d2b7..ad0b690889e 100644 --- a/sys/arch/sparc/sparc/pmap.c +++ b/sys/arch/sparc/sparc/pmap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pmap.c,v 1.68 2000/01/27 17:00:02 art Exp $ */ +/* $OpenBSD: pmap.c,v 1.69 2000/01/27 17:37:15 art Exp $ */ /* $NetBSD: pmap.c,v 1.118 1998/05/19 19:00:18 thorpej Exp $ */ /* @@ -254,7 +254,7 @@ pgt_page_alloc(sz, flags, mtype) if ((cpuinfo.flags & CPUFLG_CACHEPAGETABLES) == 0) { pcache_flush(p, (caddr_t)VA2PA(p), sz); - kvm_uncache(p, sz/NBPG); + kvm_uncache(p, atop(sz)); } return (p); } @@ -2822,7 +2822,7 @@ pmap_bootstrap4_4c(nctx, nregion, nsegment) * for pmap_zero_page and pmap_copy_page, and some pages * for dumpsys(), all with no associated physical memory. */ - p = (caddr_t)(((u_int)p + NBPG - 1) & ~PGOFSET); + p = (caddr_t)round_page((vaddr_t)p); avail_start = (paddr_t)p - KERNBASE; i = (int)p; @@ -3101,7 +3101,7 @@ pmap_bootstrap4m(void) * the next whole page) and continuing through the number * of available pages are free. */ - p = (caddr_t)(((u_int)p + NBPG - 1) & ~PGOFSET); + p = (caddr_t)round_page((vaddr_t)p); /* * Reserve memory for MMU pagetables. Some of these have severe @@ -3147,7 +3147,7 @@ pmap_bootstrap4m(void) p - (caddr_t) kernel_pagtable_store); /* Round to next page and mark end of stolen pages */ - p = (caddr_t)(((u_int)p + NBPG - 1) & ~PGOFSET); + p = (caddr_t)round_page((vaddr_t)p); pagetables_end = (vaddr_t)p; avail_start = (paddr_t)p - KERNBASE; @@ -3398,11 +3398,6 @@ pmap_init() vsize_t size; vaddr_t addr; -#ifdef DEBUG - if (PAGE_SIZE != NBPG) - panic("pmap_init: CLSIZE!=1"); -#endif - npages = 0; for (n = 0; n < vm_nphysseg; n++) npages += vm_physmem[n].end - vm_physmem[n].start; @@ -4571,7 +4566,7 @@ pmap_changeprot4_4c(pm, va, prot, wired) write_user_windows(); /* paranoia */ - va &= ~(NBPG-1); + va = trunc_page(va); if (pm == pmap_kernel()) newprot = prot & VM_PROT_WRITE ? PG_S|PG_W : PG_S; else @@ -4890,7 +4885,7 @@ pmap_changeprot4m(pm, va, prot, wired) write_user_windows(); /* paranoia */ - va &= ~(NBPG-1); + va = trunc_page(va); if (pm == pmap_kernel()) newprot = prot & VM_PROT_WRITE ? PPROT_N_RWX : PPROT_N_RX; else |