diff options
author | Artur Grabowski <art@cvs.openbsd.org> | 2000-02-04 15:46:10 +0000 |
---|---|---|
committer | Artur Grabowski <art@cvs.openbsd.org> | 2000-02-04 15:46:10 +0000 |
commit | 3323eab82674296128ce7d45afdf944779211473 (patch) | |
tree | 9b813d228ed8653d5d793f09e0e9bd323451f38f /sys/arch | |
parent | 679f0ba6e5753d68baf9086bcec78d8dd09c9d2a (diff) |
Some cpus might have the cache running even before we enable it.
Uncache the pagetables in pmap_bootstrap4m and recache them again
in pmap_cache_enable if we can. This fixes the problems seen on SM30.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/sparc/sparc/pmap.c | 36 |
1 files changed, 26 insertions, 10 deletions
diff --git a/sys/arch/sparc/sparc/pmap.c b/sys/arch/sparc/sparc/pmap.c index af1a9d82a56..9ef0111d7cc 100644 --- a/sys/arch/sparc/sparc/pmap.c +++ b/sys/arch/sparc/sparc/pmap.c @@ -1,4 +1,4 @@ -/* $OpenBSD: pmap.c,v 1.73 2000/02/01 16:16:36 art Exp $ */ +/* $OpenBSD: pmap.c,v 1.74 2000/02/04 15:46:09 art Exp $ */ /* $NetBSD: pmap.c,v 1.118 1998/05/19 19:00:18 thorpej Exp $ */ /* @@ -3301,7 +3301,13 @@ pmap_bootstrap4m(void) sp->sg_npte++; pte = ((int)q - KERNBASE) >> SRMMU_PPNPASHIFT; - pte |= PPROT_N_RX | SRMMU_PG_C | SRMMU_TEPTE; + pte |= PPROT_N_RX | SRMMU_TEPTE; + + if ((cpuinfo.flags & CPUFLG_CACHEPAGETABLES) != 0 || + q < (caddr_t)pagetables_start || + q >= (caddr_t)pagetables_end) + pte |= SRMMU_PG_C; + /* write-protect kernel text */ if (q < (caddr_t) trapbase || q >= etext) pte |= PPROT_WRITE; @@ -3323,6 +3329,12 @@ pmap_bootstrap4m(void) cpuinfo.ctx_tbl[i] = cpuinfo.ctx_tbl[0]; #endif + if ((cpuinfo.flags & CPUFLG_CACHEPAGETABLES) == 0) + /* Flush page tables from cache */ + pcache_flush((caddr_t)pagetables_start, + (caddr_t)VA2PA((caddr_t)pagetables_start), + pagetables_end - pagetables_start); + /* * Now switch to kernel pagetables (finally!) */ @@ -3474,7 +3486,7 @@ pmap_init() } /* - * Called just after enabling cache (so that we CPUFLG_CACHEPAGETABLES is + * Called just after enabling cache (so that CPUFLG_CACHEPAGETABLES is * set correctly). */ void @@ -3482,16 +3494,20 @@ pmap_cache_enable() { #ifdef SUN4M if (CPU_ISSUN4M) { + int pte; + /* - * Mark all pagetables uncacheable, if required + * Deal with changed CPUFLG_CACHEPAGETABLES. * - * We assume that we have not allocated any tables except - * the kernel pagetables. It's safe to assume because - * only userland can alloc extra pagetables and we're - * still in autoconfiguration. + * If the tables were uncached during the initial mapping + * and cache_enable set the flag we recache the tables. */ - if ((cpuinfo.flags & CPUFLG_CACHEPAGETABLES) == 0) - kvm_uncache((caddr_t)pagetables_start, + + pte = getpte4m(pagetables_start); + + if ((cpuinfo.flags & CPUFLG_CACHEPAGETABLES) != 0 && + (pte & SRMMU_PG_C) == 0) + kvm_recache((caddr_t)pagetables_start, atop(pagetables_end - pagetables_start)); } #endif |