blob: 1299b29a03a8eb5bcd83704d10aa47426407ad2c [file] [log] [blame]
John McCall1e7fe752010-09-02 09:58:18 +00001// RUN: %clang_cc1 -triple x86_64-apple-darwin10 %s -emit-llvm -o - | FileCheck %s
Anders Carlsson60e282c2009-08-16 21:13:42 +00002
3void t1(int *a) {
4 delete a;
5}
6
7struct S {
8 int a;
9};
10
11// POD types.
12void t3(S *s) {
13 delete s;
14}
15
16// Non-POD
17struct T {
18 ~T();
19 int a;
20};
21
John McCall9c82afc2010-04-20 02:18:25 +000022// CHECK: define void @_Z2t4P1T
Anders Carlsson60e282c2009-08-16 21:13:42 +000023void t4(T *t) {
John McCall9c82afc2010-04-20 02:18:25 +000024 // CHECK: call void @_ZN1TD1Ev
25 // CHECK-NEXT: bitcast
26 // CHECK-NEXT: call void @_ZdlPv
Anders Carlsson60e282c2009-08-16 21:13:42 +000027 delete t;
28}
Douglas Gregord69dd782009-10-01 05:49:51 +000029
30// PR5102
31template <typename T>
32class A {
John McCallca82a822011-09-21 08:36:56 +000033 public: operator T *() const;
Douglas Gregord69dd782009-10-01 05:49:51 +000034};
35
36void f() {
37 A<char*> a;
38
39 delete a;
40}
John McCall9c82afc2010-04-20 02:18:25 +000041
42namespace test0 {
43 struct A {
44 void *operator new(__SIZE_TYPE__ sz);
45 void operator delete(void *p) { ::operator delete(p); }
46 ~A() {}
47 };
48
49 // CHECK: define void @_ZN5test04testEPNS_1AE(
50 void test(A *a) {
51 // CHECK: call void @_ZN5test01AD1Ev
52 // CHECK-NEXT: bitcast
53 // CHECK-NEXT: call void @_ZN5test01AdlEPv
54 delete a;
55 }
56
Chris Lattner9cbe4f02011-07-09 17:41:47 +000057 // CHECK: define linkonce_odr void @_ZN5test01AD1Ev(%"struct.test0::A"* %this) unnamed_addr
John McCall9c82afc2010-04-20 02:18:25 +000058 // CHECK: define linkonce_odr void @_ZN5test01AdlEPv
59}
John McCall1e7fe752010-09-02 09:58:18 +000060
61namespace test1 {
62 struct A {
63 int x;
64 ~A();
65 };
66
67 // CHECK: define void @_ZN5test14testEPA10_A20_NS_1AE(
68 void test(A (*arr)[10][20]) {
69 delete [] arr;
John McCall7cfd76c2011-07-13 01:41:37 +000070 // CHECK: icmp eq [10 x [20 x [[A:%.*]]]]* [[PTR:%.*]], null
John McCall1e7fe752010-09-02 09:58:18 +000071 // CHECK-NEXT: br i1
72
John McCall7cfd76c2011-07-13 01:41:37 +000073 // CHECK: [[BEGIN:%.*]] = getelementptr inbounds [10 x [20 x [[A]]]]* [[PTR]], i32 0, i32 0, i32 0
74 // CHECK-NEXT: [[T0:%.*]] = bitcast [[A]]* [[BEGIN]] to i8*
75 // CHECK-NEXT: [[ALLOC:%.*]] = getelementptr inbounds i8* [[T0]], i64 -8
76 // CHECK-NEXT: [[T1:%.*]] = bitcast i8* [[ALLOC]] to i64*
77 // CHECK-NEXT: [[COUNT:%.*]] = load i64* [[T1]]
John McCall7cfd76c2011-07-13 01:41:37 +000078 // CHECK: [[END:%.*]] = getelementptr inbounds [[A]]* [[BEGIN]], i64 [[COUNT]]
John McCallfbf780a2011-07-13 08:09:46 +000079 // CHECK-NEXT: [[ISEMPTY:%.*]] = icmp eq [[A]]* [[BEGIN]], [[END]]
80 // CHECK-NEXT: br i1 [[ISEMPTY]],
John McCall7cfd76c2011-07-13 01:41:37 +000081 // CHECK: [[PAST:%.*]] = phi [[A]]* [ [[END]], {{%.*}} ], [ [[CUR:%.*]], {{%.*}} ]
82 // CHECK-NEXT: [[CUR:%.*]] = getelementptr inbounds [[A]]* [[PAST]], i64 -1
83 // CHECK-NEXT: call void @_ZN5test11AD1Ev([[A]]* [[CUR]])
84 // CHECK-NEXT: [[ISDONE:%.*]] = icmp eq [[A]]* [[CUR]], [[BEGIN]]
85 // CHECK-NEXT: br i1 [[ISDONE]]
John McCall1e7fe752010-09-02 09:58:18 +000086 // CHECK: call void @_ZdaPv(i8* [[ALLOC]])
87 }
88}
Douglas Gregorf9cce312010-09-02 15:34:35 +000089
90namespace test2 {
91 // CHECK: define void @_ZN5test21fEPb
92 void f(bool *b) {
93 // CHECK: call void @_ZdlPv(i8*
94 delete b;
95 // CHECK: call void @_ZdaPv(i8*
96 delete [] b;
97 }
98}
Argyrios Kyrtzidis4076dac2010-09-13 20:15:54 +000099
100namespace test3 {
101 void f(int a[10][20]) {
102 // CHECK: call void @_ZdaPv(i8*
103 delete a;
104 }
105}
Douglas Gregora8b20f72011-07-13 00:54:47 +0000106
107namespace test4 {
108 // PR10341: ::delete with a virtual destructor
109 struct X {
110 virtual ~X();
111 void operator delete (void *);
112 };
113
114 // CHECK: define void @_ZN5test421global_delete_virtualEPNS_1XE
115 void global_delete_virtual(X *xp) {
John McCallecd03b42012-09-25 10:10:39 +0000116 // Load the offset-to-top from the vtable and apply it.
117 // This has to be done first because the dtor can mess it up.
118 // CHECK: [[T0:%.*]] = bitcast [[X:%.*]]* [[XP:%.*]] to i64**
119 // CHECK-NEXT: [[VTABLE:%.*]] = load i64** [[T0]]
120 // CHECK-NEXT: [[T0:%.*]] = getelementptr inbounds i64* [[VTABLE]], i64 -2
121 // CHECK-NEXT: [[OFFSET:%.*]] = load i64* [[T0]], align 8
122 // CHECK-NEXT: [[T0:%.*]] = bitcast [[X]]* [[XP]] to i8*
123 // CHECK-NEXT: [[ALLOCATED:%.*]] = getelementptr inbounds i8* [[T0]], i64 [[OFFSET]]
124 // Load the complete-object destructor (not the deleting destructor)
125 // and call it.
126 // CHECK-NEXT: [[T0:%.*]] = bitcast [[X:%.*]]* [[XP:%.*]] to void ([[X]]*)***
127 // CHECK-NEXT: [[VTABLE:%.*]] = load void ([[X]]*)*** [[T0]]
128 // CHECK-NEXT: [[T0:%.*]] = getelementptr inbounds void ([[X]]*)** [[VTABLE]], i64 0
129 // CHECK-NEXT: [[DTOR:%.*]] = load void ([[X]]*)** [[T0]]
130 // CHECK-NEXT: call void [[DTOR]]([[X]]* [[OBJ:%.*]])
131 // Call the global operator delete.
Bill Wendling4e1125f2013-02-22 09:10:20 +0000132 // CHECK-NEXT: call void @_ZdlPv(i8* [[ALLOCATED]]) [[NUW:#[0-9]+]]
Douglas Gregora8b20f72011-07-13 00:54:47 +0000133 ::delete xp;
134 }
135}
Eli Friedman91873b72011-07-27 18:54:57 +0000136
137namespace test5 {
138 struct Incomplete;
Eli Friedmanaebab722011-08-02 18:05:30 +0000139 // CHECK: define void @_ZN5test523array_delete_incompleteEPNS_10IncompleteES1_
140 void array_delete_incomplete(Incomplete *p1, Incomplete *p2) {
141 // CHECK: call void @_ZdlPv
142 delete p1;
Eli Friedman8c830312011-07-27 20:09:36 +0000143 // CHECK: call void @_ZdaPv
Eli Friedmanaebab722011-08-02 18:05:30 +0000144 delete [] p2;
Eli Friedman91873b72011-07-27 18:54:57 +0000145 }
146}
Bill Wendling4e1125f2013-02-22 09:10:20 +0000147
148// CHECK: attributes [[NUW]] = { nounwind{{.*}} }