diff options
author | Will Deacon <will.deacon@arm.com> | 2010-09-14 04:50:03 -0400 |
---|---|---|
committer | Russell King <rmk+kernel@arm.linux.org.uk> | 2010-09-17 05:16:50 -0400 |
commit | 6491848d1ab246f6d243ddef25085fc1d836ff2c (patch) | |
tree | c818251255daf1edc51f4fe04b2a34c0e8580c2c /arch | |
parent | 63f469324f999a28e67b90eb27a5fe0e379b7064 (diff) |
ARM: 6387/1: errata: check primary part ID in proc-v7.S
Kconfig doesn't have any knowledge of specific v7 cores, so it is possible
to select errata workarounds that may cause inadvertent behaviour when
executed on a core other than those targetted by the fix.
This patch improves the variant and revision checking in proc-v7.S so
that the primary part number is also considered when applying errata
workarounds.
Acked-by: Catalin Marinas <catalin.marinas@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mm/proc-v7.S | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/arch/arm/mm/proc-v7.S b/arch/arm/mm/proc-v7.S index 6a8506d99ee9..1f16f9e3f441 100644 --- a/arch/arm/mm/proc-v7.S +++ b/arch/arm/mm/proc-v7.S | |||
@@ -204,8 +204,13 @@ __v7_setup: | |||
204 | bne 2f | 204 | bne 2f |
205 | and r5, r0, #0x00f00000 @ variant | 205 | and r5, r0, #0x00f00000 @ variant |
206 | and r6, r0, #0x0000000f @ revision | 206 | and r6, r0, #0x0000000f @ revision |
207 | orr r0, r6, r5, lsr #20-4 @ combine variant and revision | 207 | orr r6, r6, r5, lsr #20-4 @ combine variant and revision |
208 | ubfx r0, r0, #4, #12 @ primary part number | ||
208 | 209 | ||
210 | /* Cortex-A8 Errata */ | ||
211 | ldr r10, =0x00000c08 @ Cortex-A8 primary part number | ||
212 | teq r0, r10 | ||
213 | bne 2f | ||
209 | #ifdef CONFIG_ARM_ERRATA_430973 | 214 | #ifdef CONFIG_ARM_ERRATA_430973 |
210 | teq r5, #0x00100000 @ only present in r1p* | 215 | teq r5, #0x00100000 @ only present in r1p* |
211 | mrceq p15, 0, r10, c1, c0, 1 @ read aux control register | 216 | mrceq p15, 0, r10, c1, c0, 1 @ read aux control register |
@@ -213,14 +218,14 @@ __v7_setup: | |||
213 | mcreq p15, 0, r10, c1, c0, 1 @ write aux control register | 218 | mcreq p15, 0, r10, c1, c0, 1 @ write aux control register |
214 | #endif | 219 | #endif |
215 | #ifdef CONFIG_ARM_ERRATA_458693 | 220 | #ifdef CONFIG_ARM_ERRATA_458693 |
216 | teq r0, #0x20 @ only present in r2p0 | 221 | teq r6, #0x20 @ only present in r2p0 |
217 | mrceq p15, 0, r10, c1, c0, 1 @ read aux control register | 222 | mrceq p15, 0, r10, c1, c0, 1 @ read aux control register |
218 | orreq r10, r10, #(1 << 5) @ set L1NEON to 1 | 223 | orreq r10, r10, #(1 << 5) @ set L1NEON to 1 |
219 | orreq r10, r10, #(1 << 9) @ set PLDNOP to 1 | 224 | orreq r10, r10, #(1 << 9) @ set PLDNOP to 1 |
220 | mcreq p15, 0, r10, c1, c0, 1 @ write aux control register | 225 | mcreq p15, 0, r10, c1, c0, 1 @ write aux control register |
221 | #endif | 226 | #endif |
222 | #ifdef CONFIG_ARM_ERRATA_460075 | 227 | #ifdef CONFIG_ARM_ERRATA_460075 |
223 | teq r0, #0x20 @ only present in r2p0 | 228 | teq r6, #0x20 @ only present in r2p0 |
224 | mrceq p15, 1, r10, c9, c0, 2 @ read L2 cache aux ctrl register | 229 | mrceq p15, 1, r10, c9, c0, 2 @ read L2 cache aux ctrl register |
225 | tsteq r10, #1 << 22 | 230 | tsteq r10, #1 << 22 |
226 | orreq r10, r10, #(1 << 22) @ set the Write Allocate disable bit | 231 | orreq r10, r10, #(1 << 22) @ set the Write Allocate disable bit |