1 // RUN: %clangxx_asan -O0 %s -o %t && not %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os --check-prefix=CHECK
2 // RUN: %clangxx_asan -O1 %s -o %t && not %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os --check-prefix=CHECK
3 // RUN: %clangxx_asan -O2 %s -o %t && not %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os --check-prefix=CHECK
4 // RUN: %clangxx_asan -O3 %s -o %t && not %run %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os --check-prefix=CHECK
5 // REQUIRES: stable-runtime
7 // Issue #108194: Incomplete .debug_line at -O1 and above.
8 // XFAIL: target={{.*sparc.*}}
11 __attribute__((noinline
))
12 static void LargeFunction(int *x
, int zero
) {
24 // CHECK: {{.*ERROR: AddressSanitizer: heap-buffer-overflow on address}}
25 // CHECK: {{0x.* at pc 0x.* bp 0x.* sp 0x.*}}
26 // CHECK: {{READ of size 4 at 0x.* thread T0}}
27 x
[zero
+ 103]++; // we should report this exact line
28 // atos incorrectly extracts the symbol name for the static functions on
30 // CHECK-Linux: {{#0 0x.* in LargeFunction.*large_func_test.cpp:}}[[@LINE-3]]
31 // CHECK-SunOS: {{#0 0x.* in LargeFunction.*large_func_test.cpp:}}[[@LINE-4]]
32 // CHECK-Windows:{{#0 0x.* in LargeFunction.*large_func_test.cpp:}}[[@LINE-5]]
33 // CHECK-FreeBSD:{{#0 0x.* in LargeFunction.*large_func_test.cpp:}}[[@LINE-6]]
34 // CHECK-Darwin: {{#0 0x.* in .*LargeFunction.*large_func_test.cpp}}:[[@LINE-7]]
48 int main(int argc
, char **argv
) {
49 int *x
= new int[100];
50 LargeFunction(x
, argc
- 1);
51 // CHECK: {{ #1 0x.* in main .*large_func_test.cpp:}}[[@LINE-1]]
52 // CHECK: {{0x.* is located 12 bytes after 400-byte region}}
53 // CHECK: {{allocated by thread T0 here:}}
54 // CHECK-Linux: {{ #0 0x.* in operator new}}
55 // CHECK-SunOS: {{ #0 0x.* in operator new}}
56 // CHECK-Windows:{{ #0 0x.* in operator new}}
57 // CHECK-FreeBSD:{{ #0 0x.* in operator new}}
58 // CHECK-Darwin: {{ #0 0x.* in .*_Zna}}
59 // CHECK-NEXT: {{ #1 0x.* in main .*large_func_test.cpp:}}[[@LINE-10]]