[Gc] SIGSEGVs avoided by calling GC_expand_hp
jan at stepien.cc
Sat Jan 8 15:25:07 PST 2011
On Sun, 09 Jan 2011 00:41:19 +0300
Ivan Maidanski <ivmai at mail.ru> wrote:
> > During work on my thesis I've been developing a C application
> > which uses both the GC and GLib. I've encountered a problem which seems
> > to occur when a lot of small allocations are executed.
> > I'm on 32 bit GNU/Linux 2.6.35. I've configured gc-7.1 with
> > --disable-threads, --disable-cplusplus and --disable-shared and built a
> > static library. I've instructed GLib to use GC's allocation functions
> > instead of the ones from glibc and called GC_INIT before allocating
> > anything.
> > The SIGSEGV in GC_malloc_atomic is received at line malloc.c:225.
> > *opp = obj_link(op);
> > After checking in gdb it appears that the op variable tends to have
> > small integer values lesser than 0xf00 which clearly aren't pointers.
> In other words, GC_aobjfreelist contains a corrupted link pointer. Could you debug and find out who places that value to GC_aobjfreelist?
> My guess is: GC had collected an object (which is now in GC_aobjfreelist) that is reachable from some untraceable memory and the application has modified that object (first word of it) some later (thus producing that corrupted link pointer).
> Also, it would be good if you fetch the recent BDWGC snapshot from CVS and test whether the problem still exists. (If you don't want to fetch from the CVS, here's the snapshot as a tar-ball - http://www.ivmaisoft.com/_mirror/hpl/bdwgc-7_2alpha5-20110107.tar.bz2).
Thanks for the reply. Unfortunately updating doesn't help. Currently
I'm tinkering with GDB trying to figure out how does free lists work
and check where and how they are altered. I'll post a follow up when
I'll get some results.
Jan Stępień <jan at stepien.cc>
More information about the Gc