public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* Re: [PATCH 1/2] boot: increase stack size for kernel boot loader decompressor -- payload_length
@ 2008-04-10 20:34 Yinghai Lu
  2008-04-10 20:37 ` H. Peter Anvin
  0 siblings, 1 reply; 8+ messages in thread
From: Yinghai Lu @ 2008-04-10 20:34 UTC (permalink / raw)
  To: Ingo Molnar, H. Peter Anvin
  Cc: Alexander van Heukelum, Mike Travis, Thomas Gleixner,
	Andrew Morton, linux-kernel, heukelum

On Tue, Apr 8, 2008 at 1:23 AM, Ingo Molnar <mingo@elte.hu> wrote:
>
>  * Alexander van Heukelum <heukelum@mailshack.com> wrote:
>
>  > I did see that the malloc space that the inflate code is using is
>  > taken from _after_ the end of the bss. I don't see how this is
>  > protected from being used/overwritten. Changing the stack size changes
>  > the memory layout a bit... maybe you were so unlucky to create a
>  > vmlinux image that was just barely smaller than some threshold and
>  > increasing the stack size made the decompression/relocation area be
>  > located somewhere else?
>  >
>  > Test patch follows.
>
>  that's a really interesting theory.
>
>  FWIIW, i've been booting allyesconfig bzImages for a long time (with
>  only minimal amount of drivers disabled - mostly old ISA ones that
>  assume the presence of the real hardware), and they boot and work fine
>  on both 32-bit and 64-bit typical whitebox PCs. That means huge bzImages
>  that decompresses into a ~41 MB kernel image. I'd expect that to be a
>  rather severe test of the decompressor.

payload_offset and payload_length in arch/x86/boot/head.S
seems to be used by bootloader  to seat the bzImage.  or just use size
of bzImage

and bootloader is supposed to load bzImage from 2M, and initrd near 4G...

so if you have memhole from [2M+36M, 2M+45M), and bzImage is only 10M,
...then you will have problem.

but I assume that bootloader already used bzImage size or payload size with


extra_bytes = (uncompressed_size >> 12) + 32768 + 18 + decompressor_size.

to get unzip size for good position for bzImage.


long term, should add one field after payload_length like
payload_unzip_length to make bootloader or kexec what buffer size
needed.
YH

^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2008-04-10 22:58 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-04-10 20:34 [PATCH 1/2] boot: increase stack size for kernel boot loader decompressor -- payload_length Yinghai Lu
2008-04-10 20:37 ` H. Peter Anvin
2008-04-10 21:15   ` Yinghai Lu
2008-04-10 21:46     ` H. Peter Anvin
2008-04-10 21:48       ` Yinghai Lu
2008-04-10 22:14         ` H. Peter Anvin
2008-04-10 22:55           ` Yinghai Lu
2008-04-10 22:57             ` H. Peter Anvin

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox