diff options
Diffstat (limited to 'arch/arm/mach-omap2/omap4-common.c')
-rw-r--r-- | arch/arm/mach-omap2/omap4-common.c | 86 |
1 files changed, 34 insertions, 52 deletions
diff --git a/arch/arm/mach-omap2/omap4-common.c b/arch/arm/mach-omap2/omap4-common.c index 95e171a055f3..c41ff8b638e1 100644 --- a/arch/arm/mach-omap2/omap4-common.c +++ b/arch/arm/mach-omap2/omap4-common.c | |||
@@ -167,75 +167,57 @@ void __iomem *omap4_get_l2cache_base(void) | |||
167 | return l2cache_base; | 167 | return l2cache_base; |
168 | } | 168 | } |
169 | 169 | ||
170 | static void omap4_l2x0_disable(void) | 170 | static void omap4_l2c310_write_sec(unsigned long val, unsigned reg) |
171 | { | 171 | { |
172 | outer_flush_all(); | 172 | unsigned smc_op; |
173 | /* Disable PL310 L2 Cache controller */ | ||
174 | omap_smc1(0x102, 0x0); | ||
175 | } | ||
176 | 173 | ||
177 | static void omap4_l2x0_set_debug(unsigned long val) | 174 | switch (reg) { |
178 | { | 175 | case L2X0_CTRL: |
179 | /* Program PL310 L2 Cache controller debug register */ | 176 | smc_op = OMAP4_MON_L2X0_CTRL_INDEX; |
180 | omap_smc1(0x100, val); | 177 | break; |
178 | |||
179 | case L2X0_AUX_CTRL: | ||
180 | smc_op = OMAP4_MON_L2X0_AUXCTRL_INDEX; | ||
181 | break; | ||
182 | |||
183 | case L2X0_DEBUG_CTRL: | ||
184 | smc_op = OMAP4_MON_L2X0_DBG_CTRL_INDEX; | ||
185 | break; | ||
186 | |||
187 | case L310_PREFETCH_CTRL: | ||
188 | smc_op = OMAP4_MON_L2X0_PREFETCH_INDEX; | ||
189 | break; | ||
190 | |||
191 | default: | ||
192 | WARN_ONCE(1, "OMAP L2C310: ignoring write to reg 0x%x\n", reg); | ||
193 | return; | ||
194 | } | ||
195 | |||
196 | omap_smc1(smc_op, val); | ||
181 | } | 197 | } |
182 | 198 | ||
183 | static int __init omap_l2_cache_init(void) | 199 | int __init omap_l2_cache_init(void) |
184 | { | 200 | { |
185 | u32 aux_ctrl = 0; | 201 | u32 aux_ctrl; |
186 | |||
187 | /* | ||
188 | * To avoid code running on other OMAPs in | ||
189 | * multi-omap builds | ||
190 | */ | ||
191 | if (!cpu_is_omap44xx()) | ||
192 | return -ENODEV; | ||
193 | 202 | ||
194 | /* Static mapping, never released */ | 203 | /* Static mapping, never released */ |
195 | l2cache_base = ioremap(OMAP44XX_L2CACHE_BASE, SZ_4K); | 204 | l2cache_base = ioremap(OMAP44XX_L2CACHE_BASE, SZ_4K); |
196 | if (WARN_ON(!l2cache_base)) | 205 | if (WARN_ON(!l2cache_base)) |
197 | return -ENOMEM; | 206 | return -ENOMEM; |
198 | 207 | ||
199 | /* | 208 | /* 16-way associativity, parity disabled, way size - 64KB (es2.0 +) */ |
200 | * 16-way associativity, parity disabled | 209 | aux_ctrl = L2C_AUX_CTRL_SHARED_OVERRIDE | |
201 | * Way size - 32KB (es1.0) | 210 | L310_AUX_CTRL_DATA_PREFETCH | |
202 | * Way size - 64KB (es2.0 +) | 211 | L310_AUX_CTRL_INSTR_PREFETCH; |
203 | */ | ||
204 | aux_ctrl = ((1 << L2X0_AUX_CTRL_ASSOCIATIVITY_SHIFT) | | ||
205 | (0x1 << 25) | | ||
206 | (0x1 << L2X0_AUX_CTRL_NS_LOCKDOWN_SHIFT) | | ||
207 | (0x1 << L2X0_AUX_CTRL_NS_INT_CTRL_SHIFT)); | ||
208 | |||
209 | if (omap_rev() == OMAP4430_REV_ES1_0) { | ||
210 | aux_ctrl |= 0x2 << L2X0_AUX_CTRL_WAY_SIZE_SHIFT; | ||
211 | } else { | ||
212 | aux_ctrl |= ((0x3 << L2X0_AUX_CTRL_WAY_SIZE_SHIFT) | | ||
213 | (1 << L2X0_AUX_CTRL_SHARE_OVERRIDE_SHIFT) | | ||
214 | (1 << L2X0_AUX_CTRL_DATA_PREFETCH_SHIFT) | | ||
215 | (1 << L2X0_AUX_CTRL_INSTR_PREFETCH_SHIFT) | | ||
216 | (1 << L2X0_AUX_CTRL_EARLY_BRESP_SHIFT)); | ||
217 | } | ||
218 | if (omap_rev() != OMAP4430_REV_ES1_0) | ||
219 | omap_smc1(0x109, aux_ctrl); | ||
220 | |||
221 | /* Enable PL310 L2 Cache controller */ | ||
222 | omap_smc1(0x102, 0x1); | ||
223 | 212 | ||
213 | outer_cache.write_sec = omap4_l2c310_write_sec; | ||
224 | if (of_have_populated_dt()) | 214 | if (of_have_populated_dt()) |
225 | l2x0_of_init(aux_ctrl, L2X0_AUX_CTRL_MASK); | 215 | l2x0_of_init(aux_ctrl, 0xcf9fffff); |
226 | else | 216 | else |
227 | l2x0_init(l2cache_base, aux_ctrl, L2X0_AUX_CTRL_MASK); | 217 | l2x0_init(l2cache_base, aux_ctrl, 0xcf9fffff); |
228 | |||
229 | /* | ||
230 | * Override default outer_cache.disable with a OMAP4 | ||
231 | * specific one | ||
232 | */ | ||
233 | outer_cache.disable = omap4_l2x0_disable; | ||
234 | outer_cache.set_debug = omap4_l2x0_set_debug; | ||
235 | 218 | ||
236 | return 0; | 219 | return 0; |
237 | } | 220 | } |
238 | omap_early_initcall(omap_l2_cache_init); | ||
239 | #endif | 221 | #endif |
240 | 222 | ||
241 | void __iomem *omap4_get_sar_ram_base(void) | 223 | void __iomem *omap4_get_sar_ram_base(void) |