diff options
Diffstat (limited to 'arch/arm/mm/proc-v7.S')
-rw-r--r-- | arch/arm/mm/proc-v7.S | 59 |
1 files changed, 48 insertions, 11 deletions
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S index a08d9d2380d3..180a08d03a03 100644 --- a/arch/arm/mm/proc-v7.S +++ b/arch/arm/mm/proc-v7.S | |||
@@ -19,17 +19,23 @@ | |||
19 | 19 | ||
20 | #include "proc-macros.S" | 20 | #include "proc-macros.S" |
21 | 21 | ||
22 | #define TTB_C (1 << 0) | ||
23 | #define TTB_S (1 << 1) | 22 | #define TTB_S (1 << 1) |
24 | #define TTB_RGN_NC (0 << 3) | 23 | #define TTB_RGN_NC (0 << 3) |
25 | #define TTB_RGN_OC_WBWA (1 << 3) | 24 | #define TTB_RGN_OC_WBWA (1 << 3) |
26 | #define TTB_RGN_OC_WT (2 << 3) | 25 | #define TTB_RGN_OC_WT (2 << 3) |
27 | #define TTB_RGN_OC_WB (3 << 3) | 26 | #define TTB_RGN_OC_WB (3 << 3) |
27 | #define TTB_NOS (1 << 5) | ||
28 | #define TTB_IRGN_NC ((0 << 0) | (0 << 6)) | ||
29 | #define TTB_IRGN_WBWA ((0 << 0) | (1 << 6)) | ||
30 | #define TTB_IRGN_WT ((1 << 0) | (0 << 6)) | ||
31 | #define TTB_IRGN_WB ((1 << 0) | (1 << 6)) | ||
28 | 32 | ||
29 | #ifndef CONFIG_SMP | 33 | #ifndef CONFIG_SMP |
30 | #define TTB_FLAGS TTB_C|TTB_RGN_OC_WB @ mark PTWs cacheable, outer WB | 34 | /* PTWs cacheable, inner WB not shareable, outer WB not shareable */ |
35 | #define TTB_FLAGS TTB_IRGN_WB|TTB_RGN_OC_WB | ||
31 | #else | 36 | #else |
32 | #define TTB_FLAGS TTB_C|TTB_S|TTB_RGN_OC_WBWA @ mark PTWs cacheable and shared, outer WBWA | 37 | /* PTWs cacheable, inner WBWA shareable, outer WBWA not shareable */ |
38 | #define TTB_FLAGS TTB_IRGN_WBWA|TTB_S|TTB_NOS|TTB_RGN_OC_WBWA | ||
33 | #endif | 39 | #endif |
34 | 40 | ||
35 | ENTRY(cpu_v7_proc_init) | 41 | ENTRY(cpu_v7_proc_init) |
@@ -176,8 +182,8 @@ cpu_v7_name: | |||
176 | */ | 182 | */ |
177 | __v7_setup: | 183 | __v7_setup: |
178 | #ifdef CONFIG_SMP | 184 | #ifdef CONFIG_SMP |
179 | mrc p15, 0, r0, c1, c0, 1 @ Enable SMP/nAMP mode | 185 | mrc p15, 0, r0, c1, c0, 1 @ Enable SMP/nAMP mode and |
180 | orr r0, r0, #(0x1 << 6) | 186 | orr r0, r0, #(1 << 6) | (1 << 0) @ TLB ops broadcasting |
181 | mcr p15, 0, r0, c1, c0, 1 | 187 | mcr p15, 0, r0, c1, c0, 1 |
182 | #endif | 188 | #endif |
183 | adr r12, __v7_setup_stack @ the local stack | 189 | adr r12, __v7_setup_stack @ the local stack |
@@ -227,12 +233,43 @@ __v7_setup: | |||
227 | mov r10, #0x1f @ domains 0, 1 = manager | 233 | mov r10, #0x1f @ domains 0, 1 = manager |
228 | mcr p15, 0, r10, c3, c0, 0 @ load domain access register | 234 | mcr p15, 0, r10, c3, c0, 0 @ load domain access register |
229 | #endif | 235 | #endif |
230 | ldr r5, =0xff0aa1a8 | 236 | /* |
231 | ldr r6, =0x40e040e0 | 237 | * Memory region attributes with SCTLR.TRE=1 |
238 | * | ||
239 | * n = TEX[0],C,B | ||
240 | * TR = PRRR[2n+1:2n] - memory type | ||
241 | * IR = NMRR[2n+1:2n] - inner cacheable property | ||
242 | * OR = NMRR[2n+17:2n+16] - outer cacheable property | ||
243 | * | ||
244 | * n TR IR OR | ||
245 | * UNCACHED 000 00 | ||
246 | * BUFFERABLE 001 10 00 00 | ||
247 | * WRITETHROUGH 010 10 10 10 | ||
248 | * WRITEBACK 011 10 11 11 | ||
249 | * reserved 110 | ||
250 | * WRITEALLOC 111 10 01 01 | ||
251 | * DEV_SHARED 100 01 | ||
252 | * DEV_NONSHARED 100 01 | ||
253 | * DEV_WC 001 10 | ||
254 | * DEV_CACHED 011 10 | ||
255 | * | ||
256 | * Other attributes: | ||
257 | * | ||
258 | * DS0 = PRRR[16] = 0 - device shareable property | ||
259 | * DS1 = PRRR[17] = 1 - device shareable property | ||
260 | * NS0 = PRRR[18] = 0 - normal shareable property | ||
261 | * NS1 = PRRR[19] = 1 - normal shareable property | ||
262 | * NOS = PRRR[24+n] = 1 - not outer shareable | ||
263 | */ | ||
264 | ldr r5, =0xff0a81a8 @ PRRR | ||
265 | ldr r6, =0x40e040e0 @ NMRR | ||
232 | mcr p15, 0, r5, c10, c2, 0 @ write PRRR | 266 | mcr p15, 0, r5, c10, c2, 0 @ write PRRR |
233 | mcr p15, 0, r6, c10, c2, 1 @ write NMRR | 267 | mcr p15, 0, r6, c10, c2, 1 @ write NMRR |
234 | adr r5, v7_crval | 268 | adr r5, v7_crval |
235 | ldmia r5, {r5, r6} | 269 | ldmia r5, {r5, r6} |
270 | #ifdef CONFIG_CPU_ENDIAN_BE8 | ||
271 | orr r6, r6, #1 << 25 @ big-endian page tables | ||
272 | #endif | ||
236 | mrc p15, 0, r0, c1, c0, 0 @ read control register | 273 | mrc p15, 0, r0, c1, c0, 0 @ read control register |
237 | bic r0, r0, r5 @ clear bits them | 274 | bic r0, r0, r5 @ clear bits them |
238 | orr r0, r0, r6 @ set them | 275 | orr r0, r0, r6 @ set them |
@@ -240,14 +277,14 @@ __v7_setup: | |||
240 | ENDPROC(__v7_setup) | 277 | ENDPROC(__v7_setup) |
241 | 278 | ||
242 | /* AT | 279 | /* AT |
243 | * TFR EV X F I D LR | 280 | * TFR EV X F I D LR S |
244 | * .EEE ..EE PUI. .T.T 4RVI ZFRS BLDP WCAM | 281 | * .EEE ..EE PUI. .T.T 4RVI ZWRS BLDP WCAM |
245 | * rxxx rrxx xxx0 0101 xxxx xxxx x111 xxxx < forced | 282 | * rxxx rrxx xxx0 0101 xxxx xxxx x111 xxxx < forced |
246 | * 1 0 110 0011 1.00 .111 1101 < we want | 283 | * 1 0 110 0011 1100 .111 1101 < we want |
247 | */ | 284 | */ |
248 | .type v7_crval, #object | 285 | .type v7_crval, #object |
249 | v7_crval: | 286 | v7_crval: |
250 | crval clear=0x0120c302, mmuset=0x10c0387d, ucset=0x00c0187c | 287 | crval clear=0x0120c302, mmuset=0x10c03c7d, ucset=0x00c01c7c |
251 | 288 | ||
252 | __v7_setup_stack: | 289 | __v7_setup_stack: |
253 | .space 4 * 11 @ 11 registers | 290 | .space 4 * 11 @ 11 registers |