sYSMALLOc: Assertion-Fehler - irgendwelche Ideen, wie zum Debuggen effektiv?

Meine server-daemon funktioniert gut auf den meisten Maschinen aber auf eines bin ich immer:

malloc.c:3074: sYSMALLOc: Assertion `(old_top == (((mbinptr) (((char *) &((av)->bins[((1)
 - 1) * 2])) - __builtin_offsetof (struct malloc_chunk, fd)))) && old_size == 0) ||
 ((unsigned long) (old_size) >= (unsigned long)((((__builtin_offsetof (struct 
malloc_chunk, fd_nextsize))+((2 * (sizeof(size_t))) - 1)) & ~((2 * (sizeof(size_t))) - 
1)))&& ((old_top)->size & 0x1) && ((unsigned long)old_end & pagemask) == 0)' failed.

gdb backtrace:

#4  0x002a8300 in sYSMALLOc (av=<value optimised out>, bytes=<value optimised out>) at malloc.c:3071
#5  _int_malloc (av=<value optimised out>, bytes=<value optimised out>) at malloc.c:4702
#6  0x002a9898 in *__GI___libc_malloc (bytes=16) at malloc.c:3638
#7  0x0804d575 in xmpp_ctx_new (mem=0x0, log=0x0) at src/ctx.c:383
#8  0x0804916e in main (argc=1, argv=0xbffff834) at ../src/adminbot.c:277

Irgendwelche Ideen, was zu versuchen sonst ? Ich bin nicht in der Lage zu finden, einen Fehler in meinem code, es könnte ein bug im XMPP-Bibliothek und ich muss feststellen, dass.

Dank.

  • Re-kompilieren der Dämon mit -O0 (keine Optimierung) - vielleicht die parameter-Werte in acktrace für _int_malloc und sYSMALLOc beleuchten
  • Ich bin damit einverstanden, kompilieren, ohne Optimierungen, und sicher sein, um die debugging-Symbole, dann führen Sie es durch valgrind. Die Valgrind-Ausgabe ist eigentlich viel mehr hilfreich bei der Diagnose dieser als der Lärm der Behauptung wirft.
InformationsquelleAutor | 2010-02-23
Schreibe einen Kommentar