On Mon, Aug 14, 2006 at 10:04:29AM -0700, H. Peter Anvin wrote: > Vivek Goyal wrote: > >On Thu, Aug 10, 2006 at 02:09:58PM -0600, Eric W. Biederman wrote: > >>>I just reserved memory at non 2MB aligned location [EMAIL PROTECTED] so > >>>that > >>>kernel is loaded at 16MB and other smaller segments below the compressed > >>>image, then I can successfully booted into the kdump kernel. > >>:) > >> > >>>So basically kexec on panic path seems to be clean except stomping issue. > >>>May be bzImage program header should reflect right "MemSize" which > >>>takes into account extra memory space calculations. > >>Yes. That sounds like the right thing to do. > >> > >>I remember trying to compute a good memsize when I created the bzImage > >>header but it is completely possible I missed some part of the > >>calculation or assumed that the kernels .bss section would always be > >>larger than what I needed for decompression. > >> > > Could someone please describe the intended semantics of this MemSize > header, *and* its intended usage? >
Now and ELF header(attached to bzImage) is being used to describe the kernel executable. One program header of PT_LOAD type is being created. The "p_filesz" field of program header is basically describing the vmlinux file size and "p_memsz" is giving how much memory will be consumed by kernel image at load time. Ideally "p_memsz" should be "p_memsz" summation of all the program headers of vmlinux file but I guess in this case we are stretching the ELF specification a little bit and also taking into the account the additional memory which will be used by decompressor and decompression logic by the time execution is transferred to the actual kernel. The intended usage is currently kexec/kdump. While pre-loading a kernel in memory, kexec creates multiple segments and puts various data into it. (like kernel image, initrd, parameters etc.) Kexec needs to know how much memory is being used by the loaded kernel so that it can place another segment after kernel at a safe distance. By reading "p_memsz" from ELF header, kexec can determine it. Currently problem we are facing in kdump case is that parameter segment (command line and other bootloader parameters) is being placed immediately after kernel which gets stomped over by decompressor code and kernel boot fails. Normal boot never faces this problem as parameter segment is always loaded below where kernel image is loaded. Thanks Vivek _______________________________________________ fastboot mailing list [email protected] https://lists.osdl.org/mailman/listinfo/fastboot
