2

Callgrind は malloc でアサーション違反を報告しましたが、memcheck と通常の実行ではエラーは明らかになりません。

stp: malloc.c:3096: sYSMALLOc: アサーション `(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)' が失敗しました。

実行コマンドは次のとおりです。

taskset -c 7 valgrind --main-stacksize=256768768 --tool=callgrind no-asserts-no-cbitp/stp ~/profiling-stp/python-samples-without-const-arr/*.smt

プログラムは -O2 -g オプションでビルドされます。valgrind を実行する前に、「ulimit -s unlimited」が呼び出されます。

Callgrind によって報告されたエラーのスタック トレースを取得することは可能ですか? そうでない場合 - デバッグ方法のアイデアはありますか?

ありがとう!

4

1 に答える 1

1

これはアサーション エラーであるため、プログラムはコア ダンプでクラッシュするはずです。そうでない場合は、コア ダンプの保存を有効にし (ulimit -c unlimited)、gdb でコア ダンプを開きます。

于 2011-08-10T10:01:08.737 に答える