LeakSanitizer 和泄漏库

问题描述 投票:0回答:1

我正在尝试使用 gcc 的泄漏清理选项来检测程序中的泄漏。

为此,我使用相关标志进行编译,运行我的程序,然后终止,这会产生以下输出:

==8013==ERROR: LeakSanitizer: detected memory leaks

Direct leak of 72704 byte(s) in 1 object(s) allocated from:
    #0 0x7f3ace944ada in __interceptor_malloc /build/gcc/src/gcc/libsanitizer/asan/asan_malloc_linux.cc:144
    #1 0x7f3ab2f8690d  (<unknown module>)
    #2 0x7f3ab2f50525  (<unknown module>)

Direct leak of 72704 byte(s) in 1 object(s) allocated from:
    #0 0x7f3ace944ada in __interceptor_malloc /build/gcc/src/gcc/libsanitizer/asan/asan_malloc_linux.cc:144
    #1 0x7f3ab51d2aad  (<unknown module>)
    #2 0x7f3ab51c4475  (<unknown module>)

Direct leak of 256 byte(s) in 1 object(s) allocated from:
    #0 0x7f3ace944ada in __interceptor_malloc /build/gcc/src/gcc/libsanitizer/asan/asan_malloc_linux.cc:144
    #1 0x562db822861c in RenderHandler::RenderHandler() ../Src/main.cpp:68
    #2 0x562db8226ee2 in main ../Src/main.cpp:200
    #3 0x7f3acdf61ee2 in __libc_start_main (/usr/lib/libc.so.6+0x26ee2)

Direct leak of 232 byte(s) in 5 object(s) allocated from:
    #0 0x7f3ace944ada in __interceptor_malloc /build/gcc/src/gcc/libsanitizer/asan/asan_malloc_linux.cc:144
    #1 0x7f3ab3e31677  (<unknown module>)
[...]

据我所知,许多库(甚至标准库)都可能存在代码泄漏,对此我并不十分担心。如果我的视频驱动程序有漏洞代码,我不会修复它。

然而,在上面的堆栈跟踪中,有一个相关的泄漏(报告了第三个)。这是我故意添加的。

我不想打印“未知模块”中发生的任何泄漏,因为我无法修复发生在我不知道的地方的泄漏(这些泄漏可能来自第三方库),并且它们倾向于隐藏我实际上可以修复的漏洞。

是否有一种机制可以指示泄漏消毒器避免打印某些类型的泄漏?

c++ debugging memory-leaks address-sanitizer memory-leak-detector
1个回答
4
投票

使用抑制文件,如 AddressSanitizerLeakSanitizer#suppressions:

中所述

您可以通过传入抑制文件来指示 LeakSanitizer 忽略某些泄漏。该文件每行必须包含一个抑制规则,每个规则的形式为

leak:<pattern>
。该模式将与泄漏的符号化堆栈跟踪进行子字符串匹配。如果函数名称、源文件名称或二进制文件名称匹配,泄漏报告将被抑制。

您可以通过设置环境变量在运行时传递文件

LSAN_OPTIONS=suppressions:my_suppressions.txt

在您的特定情况下,由于

<unknown module>
条目,可能很难找到合适的字符串来匹配。将
-fno-omit-frame-pointer
传递给编译器可能有助于获得更好的堆栈跟踪(无论如何,这在调试过程中很有帮助)。

© www.soinside.com 2019 - 2024. All rights reserved.