如何在 lli (LLVM) 中使用 I Address Sanitizer

How can use I Address Sanitizer in lli (LLVM)

我想 运行 一个带有地址消毒器参数的位码,但我有一个问题,如果我 运行 它,就会发生分段错误。

$cat sample.c
#include <stdlib.h>
void *p;
int main() {
  p = malloc(7);
  return 0;
}

$clang -emit-llvm -fsanitize=address -c -g sample.c

$lli sample.bc
Stack dump:
0.  Program arguments: lli sample.bc
0  lli                      0x000000010c112d9c llvm::sys::PrintStackTrace(llvm::raw_ostream&) + 37
1  lli                      0x000000010c11319e SignalHandler(int) + 192
2  libsystem_platform.dylib 0x00007fff603e2b3d _sigtramp + 29
3  libsystem_platform.dylib 000000000000000000 _sigtramp + 2680280288
4  lli                      0x000000010be3ff74 llvm::ExecutionEngine::runStaticConstructorsDestructors(llvm::Module&, bool) + 310
5  lli                      0x000000010beac842 llvm::MCJIT::runStaticConstructorsDestructors(bool) + 388
6  lli                      0x000000010bb715c6 main + 8866
7  libdyld.dylib            0x00007fff601f7ed9 start + 1
Segmentation fault: 11

清理后的代码需要特殊的运行时支持,该支持在 Asan 运行时库中实现。 lli 默认不加载这个库(因为用户通常不需要它)所以你需要通过 LD_PRELOAD=libasan.so.VER 明确请求它。注意 libasan.so 是 GCC 约定,对于 Clang,您可能需要像 libclang_rt.asan.XXX 这样的东西。您可以通过

确定完整的库路径
GCC_ASAN_PRELOAD=$(gcc -print-file-name=libasan.so)
CLANG_ASAN_PRELOAD=$(clang -print-file-name=libclang_rt.asan-x86_64.so)