On Wed, Sep 03, 2008 at 02:01:59PM -0700, Jay Lan wrote: > Sometimes the kexec would allocate not enough memory for kdump kernel > itself on IA64 and caused kdump kernel to panic at boot. > > When it happens, the /proc/iomem would show a kernel RAM segment like > this: > 3014000000-3015294fff : System RAM > 3014000000-3014823ccf : Kernel code > 3014823cd0-3014dee8ef : Kernel data > 3014dee8f0-301529448f : Kernel bss > 3015295000-307bffdfff : System RAM > 3018000000-3037ffffff : Crash kernel > > But kexec would allocate memory 3018000000-3019290000 for the kernel, > which is 0x5000 smaller than the regular kernel. In my cases, the > physical_node_map and kern_memmap of the kdump kernel overlaped and > caused data corruption. > > This patch fixes the problem. The patch was generated against > kexec-tools 2.0.0 and tested in 2.6.27-rc4. Hi Jay, I am unclear about why this underallocation occurs. > > Signed-off-by: Jay Lan <jlan at sgi.com> > > --- > kexec/arch/ia64/crashdump-ia64.c | 8 ++++---- > 1 file changed, 4 insertions(+), 4 deletions(-) > > Index: kexec-tools/kexec/arch/ia64/crashdump-ia64.c > =================================================================== > --- kexec-tools.orig/kexec/arch/ia64/crashdump-ia64.c 2008-09-03 11:24:14.289758063 -0700 > +++ kexec-tools/kexec/arch/ia64/crashdump-ia64.c 2008-09-03 11:29:34.095833316 -0700 > @@ -90,15 +90,15 @@ static void add_loaded_segments_info(str > phdr = &ehdr->e_phdr[i]; > if (phdr->p_type != PT_LOAD) > break; > - if (loaded_segments[loaded_segments_num].end != > - phdr->p_paddr & ~(ELF_PAGE_SIZE-1)) > - break; > + if (loaded_segments[loaded_segments_num].end < > + (phdr->p_paddr & ~(ELF_PAGE_SIZE-1)) ) > + loaded_segments[loaded_segments_num].end > + = phdr->p_paddr & ~(ELF_PAGE_SIZE-1); > loaded_segments[loaded_segments_num].end += > (phdr->p_memsz + ELF_PAGE_SIZE - 1) & > ~(ELF_PAGE_SIZE - 1); > i++; > } > - > loaded_segments_num++; > } > } > _______________________________________________ > kexec mailing list > kexec at lists.infradead.org > http://lists.infradead.org/mailman/listinfo/kexec