summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorMiod Vallat <miod@cvs.openbsd.org>2010-06-29 21:24:42 +0000
committerMiod Vallat <miod@cvs.openbsd.org>2010-06-29 21:24:42 +0000
commit11c21200e99f29de88929b19ad069fccc2f4fc02 (patch)
treea45e20caf23d3db281d7af9478c4e388af93e2b3 /sys/arch
parent85fde2d3c567d81843d489d89dc56de80875dbf5 (diff)
Rework cypress cpu cache setup, and enable writeback mode. Adapted from
NetBSD; tested on SM100.
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/sparc/sparc/cache.c25
1 files changed, 10 insertions, 15 deletions
diff --git a/sys/arch/sparc/sparc/cache.c b/sys/arch/sparc/sparc/cache.c
index 5c366cba19b..9fb0a2599cf 100644
--- a/sys/arch/sparc/sparc/cache.c
+++ b/sys/arch/sparc/sparc/cache.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cache.c,v 1.18 2007/01/22 19:39:33 miod Exp $ */
+/* $OpenBSD: cache.c,v 1.19 2010/06/29 21:24:41 miod Exp $ */
/* $NetBSD: cache.c,v 1.34 1997/09/26 22:17:23 pk Exp $ */
/*
@@ -289,32 +289,27 @@ cypress_cache_enable()
{
int i, ls, ts;
u_int pcr;
+ extern u_long dvma_cachealign;
cache_alias_dist = CACHEINFO.c_totalsize;
cache_alias_bits = (cache_alias_dist - 1) & ~PGOFSET;
+ dvma_cachealign = cache_alias_dist;
pcr = lda(SRMMU_PCR, ASI_SRMMU);
- pcr &= ~(CYPRESS_PCR_CE | CYPRESS_PCR_CM);
+ pcr &= ~CYPRESS_PCR_CM;
/* Now reset cache tag memory if cache not yet enabled */
- ls = CACHEINFO.c_linesize;
- ts = CACHEINFO.c_totalsize;
- if ((pcr & CYPRESS_PCR_CE) == 0)
- for (i = 0; i < ts; i += ls) {
+ if ((pcr & CYPRESS_PCR_CE) == 0) {
+ ls = CACHEINFO.c_linesize;
+ ts = CACHEINFO.c_totalsize;
+ for (i = 0; i < ts; i += ls)
sta(i, ASI_DCACHETAG, 0);
- while (lda(i, ASI_DCACHETAG))
- sta(i, ASI_DCACHETAG, 0);
- }
-
- pcr |= CYPRESS_PCR_CE;
+ pcr |= CYPRESS_PCR_CE;
+ }
-#if 1
- pcr &= ~CYPRESS_PCR_CM; /* XXX Disable write-back mode */
-#else
/* If put in write-back mode, turn it on */
if (CACHEINFO.c_vactype == VAC_WRITEBACK)
pcr |= CYPRESS_PCR_CM;
-#endif
sta(SRMMU_PCR, ASI_SRMMU, pcr);
CACHEINFO.c_enabled = 1;