blob: a6e082502df2317188b0141373edee57646d4d97 [file] [log] [blame]
Daniel Dunbara5728872009-12-15 20:14:24 +00001// RUN: %clang_cc1 -triple x86_64-unknown-unknown %s -emit-llvm -o - | FileCheck %s
John McCallb1c98a32011-05-16 01:05:12 +00002
3typedef __typeof__(sizeof(0)) size_t;
Anders Carlssoned4e3672009-05-31 20:21:44 +00004
Richard Smithddcff1b2013-07-21 23:12:18 +00005// Ensure that this declaration doesn't cause operator new to lose its
6// 'noalias' attribute.
7void *operator new[](size_t);
8
Anders Carlssoned4e3672009-05-31 20:21:44 +00009void t1() {
Richard Smithddcff1b2013-07-21 23:12:18 +000010 delete new int;
11 delete [] new int [3];
Anders Carlssoned4e3672009-05-31 20:21:44 +000012}
Anders Carlssond9583892009-05-31 20:26:12 +000013
Richard Smithddcff1b2013-07-21 23:12:18 +000014// CHECK: declare noalias i8* @_Znwm(i64) [[ATTR_NOBUILTIN:#[^ ]*]]
15// CHECK: declare void @_ZdlPv(i8*) [[ATTR_NOBUILTIN_NOUNWIND:#[^ ]*]]
16// CHECK: declare noalias i8* @_Znam(i64) [[ATTR_NOBUILTIN]]
17// CHECK: declare void @_ZdaPv(i8*) [[ATTR_NOBUILTIN_NOUNWIND]]
18
19namespace std {
20 struct nothrow_t {};
21}
22std::nothrow_t nothrow;
23
John McCallb1c98a32011-05-16 01:05:12 +000024// Declare the reserved placement operators.
25void *operator new(size_t, void*) throw();
26void operator delete(void*, void*) throw();
27void *operator new[](size_t, void*) throw();
28void operator delete[](void*, void*) throw();
Anders Carlssond9583892009-05-31 20:26:12 +000029
Richard Smithddcff1b2013-07-21 23:12:18 +000030// Declare the replaceable global allocation operators.
31void *operator new(size_t, const std::nothrow_t &) throw();
32void *operator new[](size_t, const std::nothrow_t &) throw();
33void operator delete(void *, const std::nothrow_t &) throw();
34void operator delete[](void *, const std::nothrow_t &) throw();
35
36
Anders Carlssond9583892009-05-31 20:26:12 +000037void t2(int* a) {
38 int* b = new (a) int;
39}
Anders Carlsson6d0ffad2009-05-31 20:56:36 +000040
Anders Carlsson627a3e52009-05-31 21:12:26 +000041struct S {
42 int a;
43};
44
Anders Carlssond3fd6ba2009-05-31 21:53:59 +000045// POD types.
Anders Carlsson6d0ffad2009-05-31 20:56:36 +000046void t3() {
47 int *a = new int(10);
Anders Carlsson3923e952009-05-31 21:07:58 +000048 _Complex int* b = new _Complex int(10i);
49
Anders Carlsson627a3e52009-05-31 21:12:26 +000050 S s;
51 s.a = 10;
52 S *sp = new S(s);
Anders Carlsson6d0ffad2009-05-31 20:56:36 +000053}
Anders Carlssond3fd6ba2009-05-31 21:53:59 +000054
55// Non-POD
56struct T {
57 T();
58 int a;
59};
60
61void t4() {
Anders Carlssona4d4c012009-09-23 16:07:23 +000062 // CHECK: call void @_ZN1TC1Ev
Anders Carlssond3fd6ba2009-05-31 21:53:59 +000063 T *t = new T;
64}
65
66struct T2 {
67 int a;
68 T2(int, int);
69};
70
71void t5() {
Anders Carlssona4d4c012009-09-23 16:07:23 +000072 // CHECK: call void @_ZN2T2C1Eii
Anders Carlssond3fd6ba2009-05-31 21:53:59 +000073 T2 *t2 = new T2(10, 10);
74}
Anders Carlssonf1108532009-06-01 00:05:16 +000075
76int *t6() {
77 // Null check.
78 return new (0) int(10);
79}
Anders Carlsson215bd202009-06-01 00:26:14 +000080
81void t7() {
82 new int();
83}
Anders Carlssona4d4c012009-09-23 16:07:23 +000084
Anders Carlsson6ac5fc42009-09-23 18:59:48 +000085struct U {
86 ~U();
87};
88
Anders Carlssona4d4c012009-09-23 16:07:23 +000089void t8(int n) {
90 new int[10];
91 new int[n];
92
93 // Non-POD
94 new T[10];
95 new T[n];
Anders Carlsson6ac5fc42009-09-23 18:59:48 +000096
97 // Cookie required
98 new U[10];
99 new U[n];
Anders Carlssona4d4c012009-09-23 16:07:23 +0000100}
Anders Carlsson09edb9c2009-11-22 19:25:33 +0000101
102void t9() {
103 bool b;
104
105 new bool(true);
106 new (&b) bool(true);
107}
Fariborz Jahanian048f52a2009-11-24 18:29:37 +0000108
109struct A {
110 void* operator new(__typeof(sizeof(int)), int, float, ...);
111 A();
112};
113
114A* t10() {
115 // CHECK: @_ZN1AnwEmifz
116 return new(1, 2, 3.45, 100) A;
117}
118
Douglas Gregor59174c02010-07-21 01:10:17 +0000119// CHECK: define void @_Z3t11i
Anders Carlsson0d7c5832010-05-03 01:20:20 +0000120struct B { int a; };
Douglas Gregor59174c02010-07-21 01:10:17 +0000121struct Bmemptr { int Bmemptr::* memptr; int a; };
122
123void t11(int n) {
Nuno Lopesfc284482009-12-16 16:59:22 +0000124 // CHECK: call noalias i8* @_Znwm
Mon P Wang3ecd7852010-04-04 03:10:52 +0000125 // CHECK: call void @llvm.memset.p0i8.i64(
Anders Carlsson30311fa2009-12-16 06:57:54 +0000126 B* b = new B();
Douglas Gregor59174c02010-07-21 01:10:17 +0000127
128 // CHECK: call noalias i8* @_Znam
129 // CHECK: {{call void.*llvm.memset.p0i8.i64.*i8 0, i64 %}}
130 B *b2 = new B[n]();
131
132 // CHECK: call noalias i8* @_Znam
133 // CHECK: call void @llvm.memcpy.p0i8.p0i8.i64
134 // CHECK: br
135 Bmemptr *b_memptr = new Bmemptr[n]();
136
137 // CHECK: ret void
Anders Carlsson30311fa2009-12-16 06:57:54 +0000138}
Anders Carlssone99bdb62010-05-03 15:09:17 +0000139
140struct Empty { };
141
142// We don't need to initialize an empty class.
Douglas Gregor59174c02010-07-21 01:10:17 +0000143// CHECK: define void @_Z3t12v
Anders Carlssone99bdb62010-05-03 15:09:17 +0000144void t12() {
Douglas Gregor59174c02010-07-21 01:10:17 +0000145 // CHECK: call noalias i8* @_Znam
146 // CHECK-NOT: br
Anders Carlssone99bdb62010-05-03 15:09:17 +0000147 (void)new Empty[10];
Douglas Gregor59174c02010-07-21 01:10:17 +0000148
149 // CHECK: call noalias i8* @_Znam
150 // CHECK-NOT: br
151 (void)new Empty[10]();
152
153 // CHECK: ret void
154}
155
156// Zero-initialization
157// CHECK: define void @_Z3t13i
158void t13(int n) {
159 // CHECK: call noalias i8* @_Znwm
160 // CHECK: store i32 0, i32*
161 (void)new int();
162
163 // CHECK: call noalias i8* @_Znam
164 // CHECK: {{call void.*llvm.memset.p0i8.i64.*i8 0, i64 %}}
165 (void)new int[n]();
166
167 // CHECK-NEXT: ret void
Anders Carlssone99bdb62010-05-03 15:09:17 +0000168}
Argyrios Kyrtzidisd2932982010-08-25 23:14:56 +0000169
170struct Alloc{
Argyrios Kyrtzidise7ab92e2010-08-26 15:23:38 +0000171 int x;
Argyrios Kyrtzidisd2932982010-08-25 23:14:56 +0000172 void* operator new[](size_t size);
173 void operator delete[](void* p);
Argyrios Kyrtzidise7ab92e2010-08-26 15:23:38 +0000174 ~Alloc();
Argyrios Kyrtzidisd2932982010-08-25 23:14:56 +0000175};
176
177void f() {
Argyrios Kyrtzidise7ab92e2010-08-26 15:23:38 +0000178 // CHECK: call i8* @_ZN5AllocnaEm(i64 808)
179 // CHECK: store i64 200
John McCall1e7fe752010-09-02 09:58:18 +0000180 // CHECK: call void @_ZN5AllocD1Ev(
Argyrios Kyrtzidisd2932982010-08-25 23:14:56 +0000181 // CHECK: call void @_ZN5AllocdaEPv(i8*
182 delete[] new Alloc[10][20];
Douglas Gregorcc09c022010-09-02 23:24:14 +0000183 // CHECK: call noalias i8* @_Znwm
184 // CHECK: call void @_ZdlPv(i8*
185 delete new bool;
186 // CHECK: ret void
Argyrios Kyrtzidisd2932982010-08-25 23:14:56 +0000187}
John McCallb1c98a32011-05-16 01:05:12 +0000188
189namespace test15 {
190 struct A { A(); ~A(); };
191
192 // CHECK: define void @_ZN6test155test0EPv(
193 // CHECK: [[P:%.*]] = load i8*
194 // CHECK-NEXT: icmp eq i8* [[P]], null
195 // CHECK-NEXT: br i1
196 // CHECK: [[T0:%.*]] = bitcast i8* [[P]] to [[A:%.*]]*
197 // CHECK-NEXT: call void @_ZN6test151AC1Ev([[A]]* [[T0]])
198 void test0(void *p) {
199 new (p) A();
200 }
201
202 // CHECK: define void @_ZN6test155test1EPv(
John McCallc3c07662011-07-13 06:10:41 +0000203 // CHECK: [[P:%.*]] = load i8**
John McCallb1c98a32011-05-16 01:05:12 +0000204 // CHECK-NEXT: icmp eq i8* [[P]], null
205 // CHECK-NEXT: br i1
John McCallc3c07662011-07-13 06:10:41 +0000206 // CHECK: [[BEGIN:%.*]] = bitcast i8* [[P]] to [[A:%.*]]*
207 // CHECK-NEXT: [[END:%.*]] = getelementptr inbounds [[A]]* [[BEGIN]], i64 5
208 // CHECK-NEXT: br label
209 // CHECK: [[CUR:%.*]] = phi [[A]]* [ [[BEGIN]], {{%.*}} ], [ [[NEXT:%.*]], {{%.*}} ]
210 // CHECK-NEXT: call void @_ZN6test151AC1Ev([[A]]* [[CUR]])
211 // CHECK-NEXT: [[NEXT]] = getelementptr inbounds [[A]]* [[CUR]], i64 1
212 // CHECK-NEXT: [[DONE:%.*]] = icmp eq [[A]]* [[NEXT]], [[END]]
213 // CHECK-NEXT: br i1 [[DONE]]
John McCallb1c98a32011-05-16 01:05:12 +0000214 void test1(void *p) {
215 new (p) A[5];
216 }
217
218 // TODO: it's okay if all these size calculations get dropped.
219 // FIXME: maybe we should try to throw on overflow?
220 // CHECK: define void @_ZN6test155test2EPvi(
221 // CHECK: [[N:%.*]] = load i32*
222 // CHECK-NEXT: [[T0:%.*]] = sext i32 [[N]] to i64
223 // CHECK-NEXT: [[T1:%.*]] = icmp slt i64 [[T0]], 0
224 // CHECK-NEXT: [[T2:%.*]] = select i1 [[T1]], i64 -1, i64 [[T0]]
225 // CHECK-NEXT: [[P:%.*]] = load i8*
226 // CHECK-NEXT: icmp eq i8* [[P]], null
227 // CHECK-NEXT: br i1
John McCallc3c07662011-07-13 06:10:41 +0000228 // CHECK: [[BEGIN:%.*]] = bitcast i8* [[P]] to [[A:%.*]]*
229 // CHECK-NEXT: [[ISEMPTY:%.*]] = icmp eq i64 [[T0]], 0
230 // CHECK-NEXT: br i1 [[ISEMPTY]],
231 // CHECK: [[END:%.*]] = getelementptr inbounds [[A]]* [[BEGIN]], i64 [[T0]]
232 // CHECK-NEXT: br label
233 // CHECK: [[CUR:%.*]] = phi [[A]]* [ [[BEGIN]],
234 // CHECK-NEXT: call void @_ZN6test151AC1Ev([[A]]* [[CUR]])
John McCallb1c98a32011-05-16 01:05:12 +0000235 void test2(void *p, int n) {
236 new (p) A[n];
237 }
238}
Douglas Gregord0e8b782011-06-27 16:55:54 +0000239
240namespace PR10197 {
241 // CHECK: define weak_odr void @_ZN7PR101971fIiEEvv()
242 template<typename T>
243 void f() {
244 // CHECK: [[CALL:%.*]] = call noalias i8* @_Znwm
245 // CHECK-NEXT: [[CASTED:%.*]] = bitcast i8* [[CALL]] to
246 new T;
247 // CHECK-NEXT: ret void
248 }
249
250 template void f<int>();
251}
Eli Friedman40563cd2011-12-09 23:05:37 +0000252
253namespace PR11523 {
254 class MyClass;
255 typedef int MyClass::* NewTy;
256 // CHECK: define i64* @_ZN7PR115231fEv
257 // CHECK: store i64 -1
258 NewTy* f() { return new NewTy[2](); }
259}
Eli Friedman22cfaf52012-02-16 22:45:48 +0000260
261namespace PR11757 {
262 // Make sure we elide the copy construction.
263 struct X { X(); X(const X&); };
264 X* a(X* x) { return new X(X()); }
265 // CHECK: define {{.*}} @_ZN7PR117571aEPNS_1XE
266 // CHECK: [[CALL:%.*]] = call noalias i8* @_Znwm
267 // CHECK-NEXT: [[CASTED:%.*]] = bitcast i8* [[CALL]] to
268 // CHECK-NEXT: call void @_ZN7PR117571XC1Ev({{.*}}* [[CASTED]])
269 // CHECK-NEXT: ret {{.*}} [[CASTED]]
270}
Eli Friedmanb41ba1a2012-08-25 07:11:29 +0000271
272namespace PR13380 {
273 struct A { A() {} };
274 struct B : public A { int x; };
275 // CHECK: define i8* @_ZN7PR133801fEv
276 // CHECK: call noalias i8* @_Znam(
277 // CHECK: call void @llvm.memset.p0i8
278 // CHECK-NEXT: call void @_ZN7PR133801BC1Ev
279 void* f() { return new B[2](); }
280}
Richard Smithddcff1b2013-07-21 23:12:18 +0000281
282struct MyPlacementType {} mpt;
283void *operator new(size_t, MyPlacementType);
284
285namespace N3664 {
286 struct S { S() throw(int); };
287
288 // CHECK-LABEL: define void @_ZN5N36641fEv
289 void f() {
290 // CHECK: call noalias i8* @_Znwm(i64 4) [[ATTR_BUILTIN_NEW:#[^ ]*]]
291 int *p = new int;
292 // CHECK: call void @_ZdlPv({{.*}}) [[ATTR_BUILTIN_DELETE:#[^ ]*]]
293 delete p;
294
295 // CHECK: call noalias i8* @_Znam(i64 12) [[ATTR_BUILTIN_NEW]]
296 int *q = new int[3];
297 // CHECK: call void @_ZdaPv({{.*}}) [[ATTR_BUILTIN_DELETE]]
298 delete [] p;
299
300 // CHECK: call i8* @_ZnamRKSt9nothrow_t(i64 3, {{.*}}) [[ATTR_BUILTIN_NOTHROW_NEW:#[^ ]*]]
301 (void) new (nothrow) S[3];
302
303 // CHECK: call i8* @_Znwm15MyPlacementType(i64 4){{$}}
304 (void) new (mpt) int;
305 }
306
307 // FIXME: Can we mark this noalias?
308 // CHECK: declare i8* @_ZnamRKSt9nothrow_t(i64, {{.*}}) [[ATTR_NOBUILTIN_NOUNWIND]]
309
310 // CHECK-LABEL: define void @_ZN5N36641gEv
311 void g() {
312 // It's OK for there to be attributes here, so long as we don't have a
313 // 'builtin' attribute.
314 // CHECK: call noalias i8* @_Znwm(i64 4){{$}}
315 int *p = (int*)operator new(4);
316 // CHECK: call void @_ZdlPv({{.*}}) [[ATTR_NOUNWIND:#[^ ]*]]
317 operator delete(p);
318
319 // CHECK: call noalias i8* @_Znam(i64 12){{$}}
320 int *q = (int*)operator new[](12);
321 // CHECK: call void @_ZdaPv({{.*}}) [[ATTR_NOUNWIND]]
322 operator delete [](p);
323
324 // CHECK: call i8* @_ZnamRKSt9nothrow_t(i64 3, {{.*}}) [[ATTR_NOUNWIND]]
325 (void) operator new[](3, nothrow);
326 }
327}
328
329// CHECK-DAG: attributes [[ATTR_NOBUILTIN]] = {{[{].*}} nobuiltin {{.*[}]}}
330// CHECK-DAG: attributes [[ATTR_NOBUILTIN_NOUNWIND]] = {{[{].*}} nobuiltin nounwind {{.*[}]}}
331
332// CHECK: attributes [[ATTR_NOUNWIND]] =
333// CHECK-NOT: builtin
334// CHECK-NOT: attributes
335// CHECK: nounwind
336// CHECK-NOT: builtin
337// CHECK: attributes
338
339// CHECK-DAG: attributes [[ATTR_BUILTIN_NEW]] = {{[{].*}} builtin {{.*[}]}}
340// CHECK-DAG: attributes [[ATTR_BUILTIN_DELETE]] = {{[{].*}} builtin {{.*[}]}}