summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/arch/sparc/sparc/cpu.c20
1 files changed, 14 insertions, 6 deletions
diff --git a/sys/arch/sparc/sparc/cpu.c b/sys/arch/sparc/sparc/cpu.c
index dca23ed5eef..ae45a93ded0 100644
--- a/sys/arch/sparc/sparc/cpu.c
+++ b/sys/arch/sparc/sparc/cpu.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cpu.c,v 1.16 1998/10/09 13:12:43 deraadt Exp $ */
+/* $OpenBSD: cpu.c,v 1.17 1999/03/03 21:58:28 jason Exp $ */
/* $NetBSD: cpu.c,v 1.56 1997/09/15 20:52:36 pk Exp $ */
/*
@@ -785,7 +785,7 @@ struct module_info module_viking = { /* UNTESTED */
noop_vcache_flush_segment,
noop_vcache_flush_region,
noop_vcache_flush_context,
- noop_pcache_flush_line
+ viking_pcache_flush_line
};
void
@@ -802,15 +802,20 @@ void
viking_hotfix(sc)
struct cpu_softc *sc;
{
+ int pcr = lda(SRMMU_PCR, ASI_SRMMU);
+
/* Test if we're directly on the MBus */
- if (!(lda(SRMMU_PCR, ASI_SRMMU) & VIKING_PCR_MB)) {
+ if ((pcr & VIKING_PCR_MB) == 0) {
sc->mxcc = 1;
sc->flags |= CPUFLG_CACHE_MANDATORY;
/*
* Ok to cache PTEs; set the flag here, so we don't
* uncache in pmap_bootstrap().
*/
- sc->flags |= CPUFLG_CACHEPAGETABLES;
+ if ((pcr & VIKING_PCR_TC) == 0)
+ printf("[viking: PCR_TC is off]");
+ else
+ sc->flags |= CPUFLG_CACHEPAGETABLES;
} else {
sc->cache_flush = viking_cache_flush;
sc->pcache_flush_line = viking_pcache_flush_line;
@@ -830,9 +835,12 @@ viking_mmu_enable()
pcr = lda(SRMMU_PCR, ASI_SRMMU);
- if (cpuinfo.mxcc)
+ if (cpuinfo.mxcc) {
+ if ((pcr & VIKING_PCR_TC) == 0) {
+ printf("[viking: turn on PCR_TC]");
+ }
pcr |= VIKING_PCR_TC;
- else
+ } else
pcr &= ~VIKING_PCR_TC;
sta(SRMMU_PCR, ASI_SRMMU, pcr);
}