0

以下のコードでテストしました

// main.c
#include <sys/mman.h>
#include <string.h>
#include <stdlib.h>

int main() {
    int* ptr1 = (int*)malloc(1);
    int* ptr2 = (int*)mmap(0, 4096*10, PROT_READ|PROT_WRITE, MAP_ANONYMOUS|MAP_SHARED, -1, 0);
}

以下のようにビルドして実行する
と、結果が示すように、LSan は malloc でのみリークを検出しました
が、mmap でリークを検出するように強制するオプションはありますか、または LSan はそのように設計されていますか?

$ gcc -fsanitize=address -O0 main.cpp
$ ASAN_OPTIONS=detect_leaks=1 ./a.out

=================================================================
==14654==ERROR: LeakSanitizer: detected memory leaks

Direct leak of 1 byte(s) in 1 object(s) allocated from:
    #0 0x7fc1054f0b50 in __interceptor_malloc (/usr/lib/x86_64-linux-gnu/libasan.so.4+0xdeb50)
    #1 0x55c984e2283b in main (/home/work/a.out+0x83b)
    #2 0x7fc105042b96 in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x21b96)

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

1 に答える 1

1

LSan github から回答を得た
ので、誰かが LSan にこのポリシーがある理由を知りたい場合は、以下のリンクを参照してください。

https://github.com/google/sanitizers/issues/1224

于 2020-04-17T06:17:57.167 に答える