diff options
author | Tony Breeds <tony@bakeyournoodle.com> | 2008-06-24 00:20:29 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2008-06-30 21:28:32 -0400 |
commit | 9b09c6d909dfd8de96b99b9b9c808b94b0a71614 (patch) | |
tree | 0796f29964a133130ed39584000b2108497f3d65 /arch/powerpc/boot | |
parent | c230328def963373ec474056f372e1918692c3c8 (diff) |
powerpc: Change the default link address for pSeries zImage kernels
Currently we set the start of the .text section to be 4Mb for pSeries.
In situations where the zImage is > 8Mb we'll fail to boot (due to
overlapping with OF). Move .text in a zImage from 4MB to 64MB
(well past OF).
We still will not be able to load large zImage unless we also move OF,
to that end, add a note to the zImage ELF to move OF to 32Mb. If this
is the very first kernel booted then we'll need to move OF manually by
setting real-base.
Signed-off-by: Tony Breeds <tony@bakeyournoodle.com>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/powerpc/boot')
-rw-r--r-- | arch/powerpc/boot/addnote.c | 2 | ||||
-rw-r--r-- | arch/powerpc/boot/oflib.c | 15 | ||||
-rwxr-xr-x | arch/powerpc/boot/wrapper | 14 | ||||
-rw-r--r-- | arch/powerpc/boot/zImage.coff.lds.S | 1 | ||||
-rw-r--r-- | arch/powerpc/boot/zImage.lds.S | 1 |
5 files changed, 26 insertions, 7 deletions
diff --git a/arch/powerpc/boot/addnote.c b/arch/powerpc/boot/addnote.c index 8041a9845ab7..b1e5611b2ab1 100644 --- a/arch/powerpc/boot/addnote.c +++ b/arch/powerpc/boot/addnote.c | |||
@@ -25,7 +25,7 @@ char arch[] = "PowerPC"; | |||
25 | #define N_DESCR 6 | 25 | #define N_DESCR 6 |
26 | unsigned int descr[N_DESCR] = { | 26 | unsigned int descr[N_DESCR] = { |
27 | 0xffffffff, /* real-mode = true */ | 27 | 0xffffffff, /* real-mode = true */ |
28 | 0x00c00000, /* real-base, i.e. where we expect OF to be */ | 28 | 0x02000000, /* real-base, i.e. where we expect OF to be */ |
29 | 0xffffffff, /* real-size */ | 29 | 0xffffffff, /* real-size */ |
30 | 0xffffffff, /* virt-base */ | 30 | 0xffffffff, /* virt-base */ |
31 | 0xffffffff, /* virt-size */ | 31 | 0xffffffff, /* virt-size */ |
diff --git a/arch/powerpc/boot/oflib.c b/arch/powerpc/boot/oflib.c index 95b8fd69a403..b0ec9cf3eaaf 100644 --- a/arch/powerpc/boot/oflib.c +++ b/arch/powerpc/boot/oflib.c | |||
@@ -168,8 +168,19 @@ void *of_claim(unsigned long virt, unsigned long size, unsigned long align) | |||
168 | 168 | ||
169 | void *of_vmlinux_alloc(unsigned long size) | 169 | void *of_vmlinux_alloc(unsigned long size) |
170 | { | 170 | { |
171 | void *p = malloc(size); | 171 | unsigned long start = (unsigned long)_start, end = (unsigned long)_end; |
172 | 172 | void *addr; | |
173 | void *p; | ||
174 | |||
175 | /* With some older POWER4 firmware we need to claim the area the kernel | ||
176 | * will reside in. Newer firmwares don't need this so we just ignore | ||
177 | * the return value. | ||
178 | */ | ||
179 | addr = of_claim(start, end - start, 0); | ||
180 | printf("Trying to claim from 0x%lx to 0x%lx (0x%lx) got %p\r\n", | ||
181 | start, end, end - start, addr); | ||
182 | |||
183 | p = malloc(size); | ||
173 | if (!p) | 184 | if (!p) |
174 | fatal("Can't allocate memory for kernel image!\n\r"); | 185 | fatal("Can't allocate memory for kernel image!\n\r"); |
175 | 186 | ||
diff --git a/arch/powerpc/boot/wrapper b/arch/powerpc/boot/wrapper index cb87a015be7c..df2358e9f1ca 100755 --- a/arch/powerpc/boot/wrapper +++ b/arch/powerpc/boot/wrapper | |||
@@ -138,14 +138,20 @@ objflags=-S | |||
138 | tmp=$tmpdir/zImage.$$.o | 138 | tmp=$tmpdir/zImage.$$.o |
139 | ksection=.kernel:vmlinux.strip | 139 | ksection=.kernel:vmlinux.strip |
140 | isection=.kernel:initrd | 140 | isection=.kernel:initrd |
141 | link_address='0x400000' | ||
141 | 142 | ||
142 | case "$platform" in | 143 | case "$platform" in |
143 | pmac|pseries|chrp) | 144 | pseries) |
145 | platformo=$object/of.o | ||
146 | link_address='0x4000000' | ||
147 | ;; | ||
148 | pmac|chrp) | ||
144 | platformo=$object/of.o | 149 | platformo=$object/of.o |
145 | ;; | 150 | ;; |
146 | coff) | 151 | coff) |
147 | platformo=$object/of.o | 152 | platformo=$object/of.o |
148 | lds=$object/zImage.coff.lds | 153 | lds=$object/zImage.coff.lds |
154 | link_address='0x500000' | ||
149 | ;; | 155 | ;; |
150 | miboot|uboot) | 156 | miboot|uboot) |
151 | # miboot and U-boot want just the bare bits, not an ELF binary | 157 | # miboot and U-boot want just the bare bits, not an ELF binary |
@@ -190,6 +196,7 @@ ps3) | |||
190 | objflags="-O binary --set-section-flags=.bss=contents,alloc,load,data" | 196 | objflags="-O binary --set-section-flags=.bss=contents,alloc,load,data" |
191 | ksection=.kernel:vmlinux.bin | 197 | ksection=.kernel:vmlinux.bin |
192 | isection=.kernel:initrd | 198 | isection=.kernel:initrd |
199 | link_address='' | ||
193 | ;; | 200 | ;; |
194 | ep88xc|ep405|ep8248e) | 201 | ep88xc|ep405|ep8248e) |
195 | platformo="$object/fixed-head.o $object/$platform.o" | 202 | platformo="$object/fixed-head.o $object/$platform.o" |
@@ -272,7 +279,10 @@ if [ -n "$dtb" ]; then | |||
272 | fi | 279 | fi |
273 | 280 | ||
274 | if [ "$platform" != "miboot" ]; then | 281 | if [ "$platform" != "miboot" ]; then |
275 | ${CROSS}ld -m elf32ppc -T $lds -o "$ofile" \ | 282 | if [ -n "$link_address" ] ; then |
283 | text_start="-Ttext $link_address --defsym _start=$link_address" | ||
284 | fi | ||
285 | ${CROSS}ld -m elf32ppc -T $lds $text_start -o "$ofile" \ | ||
276 | $platformo $tmp $object/wrapper.a | 286 | $platformo $tmp $object/wrapper.a |
277 | rm $tmp | 287 | rm $tmp |
278 | fi | 288 | fi |
diff --git a/arch/powerpc/boot/zImage.coff.lds.S b/arch/powerpc/boot/zImage.coff.lds.S index fe87a90ce7f1..856dc78b14ef 100644 --- a/arch/powerpc/boot/zImage.coff.lds.S +++ b/arch/powerpc/boot/zImage.coff.lds.S | |||
@@ -3,7 +3,6 @@ ENTRY(_zimage_start_opd) | |||
3 | EXTERN(_zimage_start_opd) | 3 | EXTERN(_zimage_start_opd) |
4 | SECTIONS | 4 | SECTIONS |
5 | { | 5 | { |
6 | . = (5*1024*1024); | ||
7 | _start = .; | 6 | _start = .; |
8 | .text : | 7 | .text : |
9 | { | 8 | { |
diff --git a/arch/powerpc/boot/zImage.lds.S b/arch/powerpc/boot/zImage.lds.S index f6e380fdb388..0962d62bdb50 100644 --- a/arch/powerpc/boot/zImage.lds.S +++ b/arch/powerpc/boot/zImage.lds.S | |||
@@ -3,7 +3,6 @@ ENTRY(_zimage_start) | |||
3 | EXTERN(_zimage_start) | 3 | EXTERN(_zimage_start) |
4 | SECTIONS | 4 | SECTIONS |
5 | { | 5 | { |
6 | . = (4*1024*1024); | ||
7 | _start = .; | 6 | _start = .; |
8 | .text : | 7 | .text : |
9 | { | 8 | { |