Commit 161e04a5 authored by Ard Biesheuvel's avatar Ard Biesheuvel

ARM: decompressor: split off _edata and stack base into separate object

In preparation of moving the handling of the LC0 object to a later stage
in the decompressor startup code, move out _edata and the initial value
of the stack pointer, which are needed earlier than the remaining
contents of LC0.
Signed-off-by: default avatarArd Biesheuvel <ardb@kernel.org>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: default avatarNicolas Pitre <nico@fluxnic.net>
parent 691cbe5b
...@@ -293,22 +293,20 @@ not_angel: ...@@ -293,22 +293,20 @@ not_angel:
orrcc r4, r4, #1 @ remember we skipped cache_on orrcc r4, r4, #1 @ remember we skipped cache_on
blcs cache_on blcs cache_on
restart: adr r0, LC0 restart: adr r0, LC1
ldmia r0, {r1, r2, r3, r6, r11, r12} ldr sp, [r0]
ldr sp, [r0, #24] ldr r6, [r0, #4]
add sp, sp, r0
add r6, r6, r0
/* adr r0, LC0
* We might be running at a different address. We need ldmia r0, {r1, r2, r3, r11, r12}
* to fix up various pointers.
*/
sub r0, r0, r1 @ calculate the delta offset sub r0, r0, r1 @ calculate the delta offset
add r6, r6, r0 @ _edata
get_inflated_image_size r9, r10, lr get_inflated_image_size r9, r10, lr
#ifndef CONFIG_ZBOOT_ROM #ifndef CONFIG_ZBOOT_ROM
/* malloc space is above the relocated stack (64k max) */ /* malloc space is above the relocated stack (64k max) */
add sp, sp, r0
add r10, sp, #0x10000 add r10, sp, #0x10000
#else #else
/* /*
...@@ -660,12 +658,15 @@ not_relocated: mov r0, #0 ...@@ -660,12 +658,15 @@ not_relocated: mov r0, #0
LC0: .word LC0 @ r1 LC0: .word LC0 @ r1
.word __bss_start @ r2 .word __bss_start @ r2
.word _end @ r3 .word _end @ r3
.word _edata @ r6
.word _got_start @ r11 .word _got_start @ r11
.word _got_end @ ip .word _got_end @ ip
.word .L_user_stack_end @ sp
.size LC0, . - LC0 .size LC0, . - LC0
.type LC1, #object
LC1: .word .L_user_stack_end - LC1 @ sp
.word _edata - LC1 @ r6
.size LC1, . - LC1
.Lheadroom: .Lheadroom:
.word _end - restart + 16384 + 1024*1024 .word _end - restart + 16384 + 1024*1024
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment