Я пытаюсь подавить предупреждение от средства очистки адреса в clang / gcc
Мой исходный файл выглядит так:
int foo(){
double bar[] = {7,8};
return bar[3];
}
int main(){
return foo();
}
и, очевидно, в строке 3 переполнение.
файл подавления (myasan.supp) содержит:
interceptor_via_fun:foo
компиляция (clang также создает предупреждение) и выполнение:
clang -O0 -g -fsanitize=address -fno-omit-frame-pointer sanitizerTest.c
ASAN_SYMBOLIZER_PATH=/software/clang/7.0.0/bin/llvm-symbolizer ASAN_OPTIONS=suppressions=myasan.supp ./a.out
, но средство для удаления адресов по-прежнемужалуется на переполнение.
==8119==ERROR: AddressSanitizer: stack-buffer-overflow on address 0x7ffeab4e75f8 at pc 0x0000004008bf bp 0x7ffeab4e75b0 sp 0x7ffeab4e75a8
READ of size 8 at 0x7ffeab4e75f8 thread T0
#0 0x4008be in foo() /tmp/asan/sanitizerTest.c:3
#1 0x400919 in main /tmp/asan/sanitizerTest.c:7
#2 0x7f549fbfb82f in __libc_start_main (/lib/x86_64-linux-gnu/libc.so.6+0x2082f)
#3 0x400718 in _start (/tmp/asan/a.out+0x400718)
Компилятор clang7.Я также протестировал clang6, gcc7.
Есть идеи, как заставить это работать?