Sanitizer

Address Sanitizer:

ASAN最早可以追溯到 LLVM 的 sanitizers项目(https://github.com/google/sanitizers),这个项目包含了AddressSanitizer,MemorySanitizer,ThreadSanitizer 和 LeakSanitizer等工具。这些工具可以检测用户空间的内存问题。通过在编译时加入指定的选项,就可以给用户程序加入 Address Sanitizer 功能。

  其中Address Sanitizer(ASAN)工具是一个内存错误检测器,可以检测以下问题:

  1)Out-of-bounds accesses to heap, stack and globals 堆、栈以及全局变量越界

  2)Use-after-free 即访问dangling pointer,已经free的指针

  3)Use-after-return (to some extent)

  4)Double-free, invalid free

  5)Memory leaks (experimental)

  ASan基于shadow memory实现,目前已经集成到Clang 3.1和GCC 4.8以上版本。

 

编译选项

  -fsanitize=address 使能Address Sanitizer工具

   -fsanitize=leak 只使能Leak Sanitizer,检测内存泄漏问题

  -fno-omit-frame-pointer 检测到内存错误时打印函数调用栈

  -O1 代码优化选项,可以打印更清晰的函数调用栈

参考资料:https://github.com/google/sanitizers/wiki/AddressSanitizer

(1) 编译时添加编译选项
-fsanitize=leak -fsanitize=address -fno-omit-frame-pointer,其中leak是可选项。
(2) 链接时添加链接选项:
-fsanitize=leak -fsanitize=address -fno-omit-frame-pointer,其中leak是可选项。
(3) 运行时添加配置选项:

export LD_PRELOAD="/lib/libasan.so"
export ASAN_OPTIONS=halt_on_error=0:log_path=/home/asan.log:quarantine_size_mb=64 3

Thread Sanitizer:

参考资料:https: //github.com/google/sanitizers/wiki/ThreadSanitizerFlags

CFLAGS += -fno-omit-frame-pointer

CFLAGS +=-fsanitize=thread

LDFLAGS += -fsanitize=thread

export LD_PRELOAD="/lib/libtsan.so"
export TSAN_OPTIONS=log_path=/home/tsan.log:io_sync=2:external_symbolizer_path=llvm-symbolizer:memory_limit_mb=1600

 

参考链接:https://www.cnblogs.com/justin-y-lin/p/11314059.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值