[RFC] [PATCH] PowerPC: add more than 4MB kernel image size support to bootwarapper

Valentine Barshak vbarshak at ru.mvista.com
Mon Sep 24 21:36:27 EST 2007


Currently zImage is linked at the 4MB base address.
Some platforms (using cuboot, treeboot) need the zImage's
entry point and base address. They place zImage exactly
at the base address it's been linked to. Sometimes 4MB left
at the start of the memory is simply not enough to unpack zImage.
This could happen with initramfs enabled, since the kernel image
packed along with initramfs.cpio could be over 5MB in size.
This patch checks vmlinux image size and links zImage at
the base address that is equal to the unpacked image size
aligned to 4MB boundary. This way zImage base address is 4MB
only if unpacked kernel image size is less then 4MB.

Signed-off-by: Valentine Barshak <vbarshak at ru.mvista.com>
---
 arch/powerpc/boot/wrapper      |    6 ++++--
 arch/powerpc/boot/zImage.lds.S |    2 +-
 2 files changed, 5 insertions(+), 3 deletions(-)

diff -ruN linux-2.6.orig/arch/powerpc/boot/wrapper linux-2.6/arch/powerpc/boot/wrapper
--- linux-2.6.orig/arch/powerpc/boot/wrapper	2007-09-22 00:48:08.000000000 +0400
+++ linux-2.6/arch/powerpc/boot/wrapper	2007-09-22 04:03:40.000000000 +0400
@@ -215,8 +215,10 @@
 fi
 
 if [ "$platform" != "miboot" ]; then
-    ${CROSS}ld -m elf32ppc -T $lds -o "$ofile" \
-	$platformo $tmp $object/wrapper.a
+    kstart=0x`${CROSS}nm "$kernel" | grep ' _start$' | cut -d' ' -f1`
+    kend=0x`${CROSS}nm "$kernel" | grep ' _end$' | cut -d' ' -f1`
+    ${CROSS}ld -m elf32ppc --defsym _kstart=$kstart --defsym _kend=$kend \
+	-T $lds -o "$ofile" $platformo $tmp $object/wrapper.a
     rm $tmp
 fi
 
diff -ruN linux-2.6.orig/arch/powerpc/boot/zImage.lds.S linux-2.6/arch/powerpc/boot/zImage.lds.S
--- linux-2.6.orig/arch/powerpc/boot/zImage.lds.S	2007-09-22 00:48:08.000000000 +0400
+++ linux-2.6/arch/powerpc/boot/zImage.lds.S	2007-09-22 04:03:58.000000000 +0400
@@ -3,7 +3,7 @@
 EXTERN(_zimage_start)
 SECTIONS
 {
-  . = (4*1024*1024);
+  . = ALIGN((_kend - _kstart), (4*1024*1024));
   _start = .;
   .text      :
   {



More information about the Linuxppc-dev mailing list