Can you try enlarging MAX_LOAD_SEGMENTS in crashdump-ia64.c? Thanks Zou Nan hai
> -----Original Message----- > From: [EMAIL PROTECTED] > [mailto:[EMAIL PROTECTED] On Behalf Of Jay Lan > Sent: 2006年12月2日 7:55 > To: fastboot > Cc: Linux-IA64 > Subject: IA64: kexec seg fault at xrealloc > > The kexec seg faulted when i ran test at an 56p SN machine. > It was successful on a 2p SN. > > > (gdb) bt > #0 0x200000000016a900 in _int_realloc () from /lib/libc.so.6.1 > #1 0x200000000016e020 in realloc () from /lib/libc.so.6.1 > #2 0x40000000000020c0 in xrealloc (ptr=0x600000000002ada0, size=160) > at kexec/kexec.c:70 > #3 0x40000000000042a0 in add_segment (info=0x60000ffffe2c3718, > buf=0x600000000002ae30, bufsz=12288, base=206963621888, memsz=16384) > at kexec/kexec.c:310 > #4 0x40000000000047f0 in add_buffer (info=0x60000ffffe2c3718, > buf=0x600000000002ae30, bufsz=12288, memsz=16384, buf_align=4096, > buf_min=0, buf_max=18446744073709551615, buf_end=-1) at > kexec/kexec.c:345 > #5 0x400000000001aa20 in load_crashdump_segments (info=0x60000ffffe2c3718, > ehdr=0x60000ffffe2c3578, max_addr=18446744073709551615, min_base=0, > cmdline=0x60000ffffe2c35e8) at kexec/arch/ia64/crashdump-ia64.c:328 > #6 0x4000000000016970 in elf_ia64_load (argc=6, argv=0x60000ffffe2c3af8, > buf=0x2000000000324010 "\177ELF\002\001\001", len=15939392, > info=0x60000ffffe2c3718) at kexec/arch/ia64/kexec-elf-ia64.c:203 > #7 0x4000000000006a00 in my_load (type=0x0, fileind=5, argc=6, > argv=0x60000ffffe2c3af8, kexec_flags=1) at kexec/kexec.c:617 > #8 0x4000000000008220 in main (argc=6, argv=0x60000ffffe2c3af8) > at kexec/kexec.c:859 > (gdb) > > The add_segment() contains code as below: > > add_segment() > { > ... > last = base + memsz -1; > if (!valid_memory_range(base, last)) { > die("Invalid memory segment %p - %p\n", > (void *)base, (void *)last); > } > > size = (info->nr_segments + 1) * sizeof(info->segment[0]); > info->segment = xrealloc(info->segment, size); <====== seg fault > info->segment[info->nr_segments].buf = buf; > info->segment[info->nr_segments].bufsz = bufsz; > info->segment[info->nr_segments].mem = (void *)base; > info->segment[info->nr_segments].memsz = memsz; > > info->nr_segments++; > ... > } > > The seg fault happened on nr_segment=4. At the end of nr_segment=3 > info->segment was set to 2ada0 in the statement > info->segment = xrealloc(info->segment, size); > And the subsequent call to xrealloc() on nr_segment=4, it died. > > On the 2p machine that was successful, the info->segment was set to > 29310 at the end of nr_segment=3. It went all the way to 30b10 at > the end of 9th segment. So, the value 2ada0 seems still in the bound. > > Can anyone more familiar with xrealloc and kexec tell me what might > cause the seg fault? > > Thanks, > - jay > - > To unsubscribe from this list: send the line "unsubscribe linux-ia64" in > the body of a message to [EMAIL PROTECTED] > More majordomo info at http://vger.kernel.org/majordomo-info.html
_______________________________________________ fastboot mailing list [email protected] https://lists.osdl.org/mailman/listinfo/fastboot
