aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/mips/mm/sc-rm7k.c18
-rw-r--r--include/asm-mips/mipsregs.h9
2 files changed, 16 insertions, 11 deletions
diff --git a/arch/mips/mm/sc-rm7k.c b/arch/mips/mm/sc-rm7k.c
index 1df5aab82c13..9e8ff8badb19 100644
--- a/arch/mips/mm/sc-rm7k.c
+++ b/arch/mips/mm/sc-rm7k.c
@@ -103,7 +103,7 @@ static __init void __rm7k_sc_enable(void)
103{ 103{
104 int i; 104 int i;
105 105
106 set_c0_config(R7K_CONF_SE); 106 set_c0_config(RM7K_CONF_SE);
107 107
108 write_c0_taglo(0); 108 write_c0_taglo(0);
109 write_c0_taghi(0); 109 write_c0_taghi(0);
@@ -122,16 +122,16 @@ static __init void __rm7k_sc_enable(void)
122 122
123static __init void rm7k_sc_enable(void) 123static __init void rm7k_sc_enable(void)
124{ 124{
125 if (read_c0_config() & R7K_CONF_SE) 125 if (read_c0_config() & RM7K_CONF_SE)
126 return; 126 return;
127 127
128 printk(KERN_INFO "Enabling secondary cache..."); 128 printk(KERN_INFO "Enabling secondary cache...\n");
129 run_uncached(__rm7k_sc_enable); 129 run_uncached(__rm7k_sc_enable);
130} 130}
131 131
132static void rm7k_sc_disable(void) 132static void rm7k_sc_disable(void)
133{ 133{
134 clear_c0_config(R7K_CONF_SE); 134 clear_c0_config(RM7K_CONF_SE);
135} 135}
136 136
137struct bcache_ops rm7k_sc_ops = { 137struct bcache_ops rm7k_sc_ops = {
@@ -145,19 +145,19 @@ void __init rm7k_sc_init(void)
145{ 145{
146 unsigned int config = read_c0_config(); 146 unsigned int config = read_c0_config();
147 147
148 if ((config >> 31) & 1) /* Bit 31 set -> no S-Cache */ 148 if ((config & RM7K_CONF_SC))
149 return; 149 return;
150 150
151 printk(KERN_INFO "Secondary cache size %dK, linesize %d bytes.\n", 151 printk(KERN_INFO "Secondary cache size %dK, linesize %d bytes.\n",
152 (scache_size >> 10), sc_lsize); 152 (scache_size >> 10), sc_lsize);
153 153
154 if (!(config & R7K_CONF_SE)) 154 if (!(config & RM7K_CONF_SE))
155 rm7k_sc_enable(); 155 rm7k_sc_enable();
156 156
157 /* 157 /*
158 * While we're at it let's deal with the tertiary cache. 158 * While we're at it let's deal with the tertiary cache.
159 */ 159 */
160 if (!((config >> 17) & 1)) { 160 if (!(config & RM7K_CONF_TC)) {
161 161
162 /* 162 /*
163 * We can't enable the L3 cache yet. There may be board-specific 163 * We can't enable the L3 cache yet. There may be board-specific
@@ -170,9 +170,9 @@ void __init rm7k_sc_init(void)
170 * to probe it. 170 * to probe it.
171 */ 171 */
172 printk(KERN_INFO "Tertiary cache present, %s enabled\n", 172 printk(KERN_INFO "Tertiary cache present, %s enabled\n",
173 config&(1<<12) ? "already" : "not (yet)"); 173 (config & RM7K_CONF_TE) ? "already" : "not (yet)");
174 174
175 if ((config >> 12) & 1) 175 if ((config & RM7K_CONF_TE))
176 rm7k_tcache_enabled = 1; 176 rm7k_tcache_enabled = 1;
177 } 177 }
178 178
diff --git a/include/asm-mips/mipsregs.h b/include/asm-mips/mipsregs.h
index 870717391a93..dd494cae4a44 100644
--- a/include/asm-mips/mipsregs.h
+++ b/include/asm-mips/mipsregs.h
@@ -425,6 +425,7 @@
425#define CONF_SM (_ULCAST_(1) << 16) 425#define CONF_SM (_ULCAST_(1) << 16)
426#define CONF_SC (_ULCAST_(1) << 17) 426#define CONF_SC (_ULCAST_(1) << 17)
427#define CONF_EW (_ULCAST_(3) << 18) 427#define CONF_EW (_ULCAST_(3) << 18)
428#define CONF_SB (_ULCAST_(3) << 22)
428#define CONF_EP (_ULCAST_(15)<< 24) 429#define CONF_EP (_ULCAST_(15)<< 24)
429#define CONF_EC (_ULCAST_(7) << 28) 430#define CONF_EC (_ULCAST_(7) << 28)
430#define CONF_CM (_ULCAST_(1) << 31) 431#define CONF_CM (_ULCAST_(1) << 31)
@@ -432,14 +433,18 @@
432/* Bits specific to the R4xx0. */ 433/* Bits specific to the R4xx0. */
433#define R4K_CONF_SW (_ULCAST_(1) << 20) 434#define R4K_CONF_SW (_ULCAST_(1) << 20)
434#define R4K_CONF_SS (_ULCAST_(1) << 21) 435#define R4K_CONF_SS (_ULCAST_(1) << 21)
435#define R4K_CONF_SB (_ULCAST_(3) << 22)
436 436
437/* Bits specific to the R5000. */ 437/* Bits specific to the R5000. */
438#define R5K_CONF_SE (_ULCAST_(1) << 12) 438#define R5K_CONF_SE (_ULCAST_(1) << 12)
439#define R5K_CONF_SS (_ULCAST_(3) << 20) 439#define R5K_CONF_SS (_ULCAST_(3) << 20)
440 440
441/* Bits specific to the RM7000. */ 441/* Bits specific to the RM7000. */
442#define R7K_CONF_SE (_ULCAST_(1) << 3) 442#define RM7K_CONF_SE (_ULCAST_(1) << 3)
443#define RM7K_CONF_TE (_ULCAST_(1) << 12)
444#define RM7K_CONF_CLK (_ULCAST_(1) << 16)
445#define RM7K_CONF_TC (_ULCAST_(1) << 17)
446#define RM7K_CONF_SI (_ULCAST_(3) << 20)
447#define RM7K_CONF_SC (_ULCAST_(1) << 31)
443 448
444/* Bits specific to the R10000. */ 449/* Bits specific to the R10000. */
445#define R10K_CONF_DN (_ULCAST_(3) << 3) 450#define R10K_CONF_DN (_ULCAST_(3) << 3)