1 // RUN: %clang -shared -fPIC -D_DSO -O2 -D_FORTIFY_SOURCE=2 %s -o %t.so
2 // RUN: %clang_asan %s -o %t %t.so
3 // RUN: not %run %t 2>&1 | FileCheck %s
4 // REQUIRES: glibc-2.27
10 __attribute__((noinline
)) char foo(const char *format
, ...) {
11 char *write_buffer
= (char *)malloc(1);
14 // CHECK: AddressSanitizer: heap-buffer-overflow
15 vsprintf(write_buffer
, format
, ap
);
17 return write_buffer
[0];
20 extern int foo(const char *format
, ...);
21 int main() { return foo("%s_%s", "one", "two"); }