aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm/boot/compressed/head.S
diff options
context:
space:
mode:
authorNicolas Pitre <nicolas.pitre@linaro.org>2011-04-19 15:42:43 -0400
committerNicolas Pitre <nico@fluxnic.net>2011-05-07 00:07:59 -0400
commit34cc1a8fe0d3f89f3602b49f1121a99d2bfc5efc (patch)
treed8c70249ddd62093a3074996fd8b25b46a4ad211 /arch/arm/boot/compressed/head.S
parentea9df3b168e641e87dbf889afae16390119e4179 (diff)
ARM: zImage: no need to get the decompressed size from the filesystem
In commit d239b1dc093d the hardcoded 4x estimate for the decompressed kernel size was replaced by the exact Image file size and passed to the linker as a symbol value. Turns out that this is unneeded as the size is already included at the end of the compressed piggy data. For those compressed formats that don't include this data, the build system already takes care of appending it using size_append in scripts/Makefile.lib. So let's use that instead. Signed-off-by: Nicolas Pitre <nicolas.pitre@linaro.org> Tested-by: Shawn Guo <shawn.guo@linaro.org> Tested-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/boot/compressed/head.S')
-rw-r--r--arch/arm/boot/compressed/head.S18
1 files changed, 16 insertions, 2 deletions
diff --git a/arch/arm/boot/compressed/head.S b/arch/arm/boot/compressed/head.S
index d1fd1cfca9c..b541217bd04 100644
--- a/arch/arm/boot/compressed/head.S
+++ b/arch/arm/boot/compressed/head.S
@@ -187,7 +187,7 @@ not_angel:
187 bl cache_on 187 bl cache_on
188 188
189restart: adr r0, LC0 189restart: adr r0, LC0
190 ldmia r0, {r1, r2, r3, r6, r9, r11, r12} 190 ldmia r0, {r1, r2, r3, r6, r10, r11, r12}
191 ldr sp, [r0, #28] 191 ldr sp, [r0, #28]
192 192
193 /* 193 /*
@@ -196,6 +196,20 @@ restart: adr r0, LC0
196 */ 196 */
197 sub r0, r0, r1 @ calculate the delta offset 197 sub r0, r0, r1 @ calculate the delta offset
198 add r6, r6, r0 @ _edata 198 add r6, r6, r0 @ _edata
199 add r10, r10, r0 @ inflated kernel size location
200
201 /*
202 * The kernel build system appends the size of the
203 * decompressed kernel at the end of the compressed data
204 * in little-endian form.
205 */
206 ldrb r9, [r10, #0]
207 ldrb lr, [r10, #1]
208 orr r9, r9, lr, lsl #8
209 ldrb lr, [r10, #2]
210 ldrb r10, [r10, #3]
211 orr r9, r9, lr, lsl #16
212 orr r9, r9, r10, lsl #24
199 213
200#ifndef CONFIG_ZBOOT_ROM 214#ifndef CONFIG_ZBOOT_ROM
201 /* malloc space is above the relocated stack (64k max) */ 215 /* malloc space is above the relocated stack (64k max) */
@@ -355,7 +369,7 @@ LC0: .word LC0 @ r1
355 .word __bss_start @ r2 369 .word __bss_start @ r2
356 .word _end @ r3 370 .word _end @ r3
357 .word _edata @ r6 371 .word _edata @ r6
358 .word _image_size @ r9 372 .word input_data_end - 4 @ r10 (inflated size location)
359 .word _got_start @ r11 373 .word _got_start @ r11
360 .word _got_end @ ip 374 .word _got_end @ ip
361 .word user_stack_end @ sp 375 .word user_stack_end @ sp