aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/boot/compressed/head.S
diff options
context:
space:
mode:
authorDave Martin <dave.martin@linaro.org>2010-11-29 13:43:26 -0500
committerRussell King <rmk+kernel@arm.linux.org.uk>2010-11-30 08:44:25 -0500
commitbfa64c4ab1235b732542f11f4e0005e1774f779a (patch)
treed390ec77a74719fbbb060337efbc5aadb3a1d585 /arch/arm/boot/compressed/head.S
parent6323875db20fd8ca8c8fbbd608bc377f2d4c8cf5 (diff)
ARM: 6502/1: Thumb-2: Fix CONFIG_THUMB2_KERNEL breakage in compressed/head.S
Some instruction operand combinations are used here which are nor permitted in Thumb-2. In particular, most uses of pc as an operand are disallowed in Thumb-2, and deprecated in ARM from ARMv7 onwards. The modified code introduced by this patch should be compatible with all architecture versions >= v3, with or without CONFIG_THUMB2_KERNEL. Reviewed-by: Will Deacon <will.deacon@arm.com> Signed-off-by: Dave Martin <dave.martin@linaro.org> Acked-by: Catalin Marinas <catalin.marinas@arm.com> Acked-by: Nicolas Pitre <nicolas.pitre@linaro.org> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
Diffstat (limited to 'arch/arm/boot/compressed/head.S')
-rw-r--r--arch/arm/boot/compressed/head.S6
1 files changed, 4 insertions, 2 deletions
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S
index 9be21ba648cd..be97e0832d73 100644
--- a/arch/arm/boot/compressed/head.S
+++ b/arch/arm/boot/compressed/head.S
@@ -174,7 +174,8 @@ not_angel:
174 ldr sp, [r0, #28] 174 ldr sp, [r0, #28]
175#ifdef CONFIG_AUTO_ZRELADDR 175#ifdef CONFIG_AUTO_ZRELADDR
176 @ determine final kernel image address 176 @ determine final kernel image address
177 and r4, pc, #0xf8000000 177 mov r4, pc
178 and r4, r4, #0xf8000000
178 add r4, r4, #TEXT_OFFSET 179 add r4, r4, #TEXT_OFFSET
179#else 180#else
180 ldr r4, =zreladdr 181 ldr r4, =zreladdr
@@ -445,7 +446,8 @@ __setup_mmu: sub r3, r4, #16384 @ Page directory size
445 */ 446 */
446 mov r1, #0x1e 447 mov r1, #0x1e
447 orr r1, r1, #3 << 10 448 orr r1, r1, #3 << 10
448 mov r2, pc, lsr #20 449 mov r2, pc
450 mov r2, r2, lsr #20
449 orr r1, r1, r2, lsl #20 451 orr r1, r1, r2, lsl #20
450 add r0, r3, r2, lsl #2 452 add r0, r3, r2, lsl #2
451 str r1, [r0], #4 453 str r1, [r0], #4