// RUN: %clang -fPIC -shared -O2 -D_FORTIFY_SOURCE=2 -D_DSO %s -o %t.so // RUN: %clang_asan %s -o %t %t.so // RUN: not %run %t 2>&1 | FileCheck %s // UNSUPPORTED: android #ifdef _DSO #include #include #include #include __attribute__((noinline)) char foo(const char *format, ...) { char *write_buffer = (char *)malloc(1); va_list ap; va_start(ap, format); // CHECK: AddressSanitizer: heap-buffer-overflow vsnprintf(write_buffer, 4096, format, ap); va_end(ap); return write_buffer[0]; } #else extern int foo(const char *format, ...); int main() { return foo("%s_%s", "one", "two"); } #endif