抑制由第三方库引起的间接泄漏

问题描述

我有一个非常简单的 C 代码,使用 scheme 调用 guile 脚本:

/* main.c */
#include <libguile.h>

int main(void)
{
    scm_init_guile();
    scm_c_primitive_load("script.scm");

    SCM func = scm_variable_ref(scm_c_lookup("func"));

    scm_call_0(func);
    return 0;
}

scheme 脚本:

; script.scm
(define (func)
    (display "Hello from scheme\n")
)

编译和运行:

export ASAN_OPTIONS=detect_leaks=1 LSAN_OPTIONS=suppressions=asan.supp
gcc -std=c11 -Wpedantic -Wall `pkg-config --cflags guile-3.0` \
    -fsanitize=address -fno-omit-frame-pointer \
    -o demo main.c `pkg-config --libs guile-3.0`
./demo

我可以使用此抑制文件 (guile) 抑制由 asan.supp 引起的一些泄漏:

leak:iconv_open
leak:libguile

但是其中一个泄漏没有提供足够的信息,消毒剂输出是:

=================================================================
==33333==ERROR: LeakSanitizer: detected memory leaks

Indirect leak of 208 byte(s) in 1 object(s) allocated from:
    #0 0x7ff8a9b8d517 in malloc (/lib/x86_64-linux-gnu/libasan.so.6+0xb0517)
    #1 0x7ff8a97e94f6  (/lib/x86_64-linux-gnu/libc.so.6+0x344f6)

-----------------------------------------------------
Suppressions used:
  count      bytes template
      2      32752 iconv_open
      1         32 libguile
-----------------------------------------------------

SUMMARY: AddressSanitizer: 208 byte(s) leaked in 1 allocation(s).

如您所见,有关泄漏的信息非常笼统(malloclibc),当然我不能将libc 放入抑制文件中,因为我不会得到关于我真实泄密的信息。

有没有办法抑制所有由第三方库引起的“间接泄漏”?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)