summaryrefslogtreecommitdiff
path: root/test/asan/TestCases/malloc_context_size.cc
blob: 8831de22f30e4f7b627bd6c0fe6c1d90f89472c8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
// RUN: %clangxx_asan -O0 %s -o %t
// RUN: ASAN_OPTIONS=malloc_context_size=0:fast_unwind_on_malloc=0 not %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os
// RUN: ASAN_OPTIONS=malloc_context_size=0:fast_unwind_on_malloc=1 not %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os
// RUN: ASAN_OPTIONS=malloc_context_size=1:fast_unwind_on_malloc=0 not %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os
// RUN: ASAN_OPTIONS=malloc_context_size=1:fast_unwind_on_malloc=1 not %t 2>&1 | FileCheck %s --check-prefix=CHECK-%os
// RUN: ASAN_OPTIONS=malloc_context_size=2 not %t 2>&1 | FileCheck %s --check-prefix=TWO

int main() {
  char *x = new char[20];
  delete[] x;
  return x[0];
  // We need to keep duplicate lines with different 'CHECK-%os' prefixes,
  // otherwise FileCheck barks on missing 'CHECK-%os' before 'CHECK-%os-NEXT'.

  // CHECK-Linux: freed by thread T{{.*}} here:
  // CHECK-Linux-NEXT: #0 0x{{.*}} in operator delete[]
  // CHECK-Darwin: freed by thread T{{.*}} here:
  // CHECK-Darwin-NEXT: #0 0x{{.*}} in wrap__ZdaPv
  // CHECK-NOT: #1 0x{{.*}}

  // CHECK-Linux: previously allocated by thread T{{.*}} here:
  // CHECK-Linux-NEXT: #0 0x{{.*}} in operator new[]
  // CHECK-Darwin: previously allocated by thread T{{.*}} here:
  // CHECK-Darwin-NEXT: #0 0x{{.*}} in wrap__Znam
  // CHECK-NOT: #1 0x{{.*}}

  // CHECK: SUMMARY: AddressSanitizer: heap-use-after-free

  // TWO: previously allocated by thread T{{.*}} here:
  // TWO-NEXT: #0 0x{{.*}}
  // TWO-NEXT: #1 0x{{.*}} in main {{.*}}malloc_context_size.cc
  // TWO: SUMMARY: AddressSanitizer: heap-use-after-free
}