咳嗽记忆消毒剂;如何使其打印源行号

时间:2014-06-25 02:59:08

标签: clang++ msan

我正在用clang++ -fsanitize=memory -fsanitize-memory-track-origins -fno-omit-frame-pointer -g -O0编译我的程序,当我运行它时,输出是:

matiu@matiu-laptop:~/projects/json++11/build$ ./tests 
.......==10534== WARNING: MemorySanitizer: use-of-uninitialized-value
    #0 0x7fe7602d4a51 (/home/matiu/projects/json++11/build/tests+0x106a51)
    #1 0x7fe7602dfca6 (/home/matiu/projects/json++11/build/tests+0x111ca6)
    ...
    #31 0x7fe75edbaec4 (/lib/x86_64-linux-gnu/libc.so.6+0x21ec4)
    #32 0x7fe7602808dc (/home/matiu/projects/json++11/build/tests+0xb28dc)

  Uninitialized value was created by a heap allocation
    #0 0x7fe76026e7b3 (/home/matiu/projects/json++11/build/tests+0xa07b3)
    #1 0x7fe7602ee7da (/home/matiu/projects/json++11/build/tests+0x1207da)
    ...
    #18 0x7fe7602c1c4c (/home/matiu/projects/json++11/build/tests+0xf3c4c)
    #19 0x7fe7602873fa (/home/matiu/projects/json++11/build/tests+0xb93fa)

SUMMARY: MemorySanitizer: use-of-uninitialized-value ??:0 ??
Exiting

如何让它显示如美丽示例中的行号:http://clang.llvm.org/docs/MemorySanitizer.html

我怀疑这可能是不可能的,因为我的pragram是一群巨大的嵌套lambda:https://github.com/matiu2/json--11/blob/master/tests.cpp

1 个答案:

答案 0 :(得分:12)

使用地址清理程序,我注意到我需要定义这些环境变量:

  • ASAN_OPTIONS=symbolize=1(仅在使用GCC> 4.8编译时才需要)和
  • ASAN_SYMBOLIZER_PATH=$(which llvm-symbolizer)我认为符号系统是您正在寻找的。它使用行号和列将符号转换为文件名。

memory sanitizer project website上显示:

  

符号化

     

将MSAN_SYMBOLIZER_PATH环境变量设置为路径   llvm-symbolizer二进制文件(通常使用LLVM构建)。 MemorySanitizer   将使用它来动态地对报告进行符号化。

因此,您需要将MSAN_SYMBOLIZER_PATH设置为与ASAN_SYMBOLIZER_PATH类似。