ARM: 6286/1: fix Thumb-2 decompressor broken by "Auto calculate ZRELADDR"
authorRabin Vincent <rabin@rab.in>
Tue, 3 Aug 2010 15:47:03 +0000 (16:47 +0100)
committerRussell King <rmk+kernel@arm.linux.org.uk>
Tue, 10 Aug 2010 21:10:51 +0000 (22:10 +0100)
"ARM: Auto calculate ZRELADDR and provide option for exceptions" broke
the Thumb-2 decompressor because it removed an entry in the LC0 table
but didn't adjust the offset the Thumb-2 code uses to load the SP from
that table.

Fix it, and also change the ARM code to use the separate SP-load since
ARM instructions that include the SP in the LDM register list are
deprecated.

Acked-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: Rabin Vincent <rabin@rab.in>
Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
arch/arm/boot/compressed/head.S

index abf4d65acf6243de88d3a0df342afabce87436e2..6af9907c3b5ccad2ae2d73e37f5470c5b2f6b897 100644 (file)
@@ -170,9 +170,8 @@ not_angel:
 
                .text
                adr     r0, LC0
- ARM(          ldmia   r0, {r1, r2, r3, r5, r6, r11, ip, sp})
- THUMB(                ldmia   r0, {r1, r2, r3, r5, r6, r11, ip}       )
- THUMB(                ldr     sp, [r0, #32]                           )
+               ldmia   r0, {r1, r2, r3, r5, r6, r11, ip}
+               ldr     sp, [r0, #28]
 #ifdef CONFIG_AUTO_ZRELADDR
                @ determine final kernel image address
                and     r4, pc, #0xf8000000