1*673dc3d4SNico Weber // RUN: %clang_cl_asan -Od %s -Fe%t
2*673dc3d4SNico Weber // RUN: not %run %t 2>&1 | FileCheck %s
3*673dc3d4SNico Weber 
4*673dc3d4SNico Weber #include <malloc.h>
5*673dc3d4SNico Weber 
main()6*673dc3d4SNico Weber int main() {
7*673dc3d4SNico Weber   int *x = new int[42];
8*673dc3d4SNico Weber   delete [] x;
9*673dc3d4SNico Weber   delete [] x;
10*673dc3d4SNico Weber // CHECK: AddressSanitizer: attempting double-free on [[ADDR:0x[0-9a-f]+]]
11*673dc3d4SNico Weber // FIXME: The 'operator delete' frame should have [].
12*673dc3d4SNico Weber // CHECK-NEXT: {{#0 .* operator delete}}
13*673dc3d4SNico Weber // CHECK-NEXT: {{#1 .* main .*double_operator_delete.cpp}}:[[@LINE-4]]
14*673dc3d4SNico Weber // CHECK: [[ADDR]] is located 0 bytes inside of 168-byte region
15*673dc3d4SNico Weber // CHECK-LABEL: freed by thread T0 here:
16*673dc3d4SNico Weber // FIXME: The 'operator delete' frame should have [].
17*673dc3d4SNico Weber // CHECK-NEXT: {{#0 .* operator delete}}
18*673dc3d4SNico Weber // CHECK-NEXT: {{#1 .* main .*double_operator_delete.cpp}}:[[@LINE-10]]
19*673dc3d4SNico Weber // CHECK-LABEL: previously allocated by thread T0 here:
20*673dc3d4SNico Weber // FIXME: The 'operator new' frame should have [].
21*673dc3d4SNico Weber // CHECK-NEXT: {{#0 .* operator new}}
22*673dc3d4SNico Weber // CHECK-NEXT: {{#1 .* main .*double_operator_delete.cpp}}:[[@LINE-15]]
23*673dc3d4SNico Weber   return 0;
24*673dc3d4SNico Weber }
25*673dc3d4SNico Weber 
26