1 // RUN: %clang_cc1 -std=c++98 %s -triple x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-CXX98
2 // RUN: %clang_cc1 -std=c++17 %s -triple x86_64-apple-darwin10 -emit-llvm -o - | FileCheck %s --check-prefix=CHECK --check-prefix=CHECK-CXX17
15 // CHECK: _Z15test_value_initv
16 void test_value_init() {
17 // This value initialization requires zero initialization of the 'B'
18 // subobject followed by a call to its constructor.
21 // CHECK: store i32 17
22 // CHECK: call void @llvm.memset.p0.i64
23 // CHECK: call void @_ZN1BC1Ev
25 // CHECK: call void @_ZN1CD1Ev
28 enum enum_type
{ negative_number
= -1, magic_number
= 42 };
35 enum_holder() : m_enum(magic_number
) { }
38 struct enum_holder_and_int
44 // CHECK: _Z24test_enum_holder_and_intv()
45 void test_enum_holder_and_int() {
47 // CHECK-NEXT: call void @llvm.memset
48 // CHECK-NEXT: call void @_ZN19enum_holder_and_intC1Ev
49 enum_holder_and_int();
50 // CHECK-NEXT: ret void
53 // PR7834: don't crash.
59 A
&operator=(const A
&);
77 // CHECK-LABEL: define{{.*}} i32 @_ZN6ptrmem4testEPNS_1SE
79 // CHECK: call void @llvm.memcpy.p0.p0.i64
80 // CHECK: getelementptr
100 struct Test3
: public Test
{ };
102 // CHECK-LABEL: define{{.*}} void @_ZN6PR98011fEv
104 // CHECK-NOT: call void @llvm.memset.p0.i64
105 // CHECK: call void @_ZN6PR98014TestC1Ei
106 // CHECK-NOT: call void @llvm.memset.p0.i64
107 // CHECK: call void @_ZN6PR98014TestC1Ev
108 Test partial
[3] = { 1 };
110 // CHECK-NOT: call void @llvm.memset.p0.i64
111 // CHECK: call void @_ZN6PR98014TestC1Ev
112 // CHECK-NOT: call void @_ZN6PR98014TestC1Ev
115 // CHECK: call void @llvm.memset.p0.i64
116 // CHECK-NOT: call void @llvm.memset.p0.i64
117 // CHECK-CXX98: call void @_ZN6PR98015Test2C1Ev
118 // CHECK-CXX17: call void @_ZN6PR98014TestC1Ev
119 // CHECK-NOT: call void @_ZN6PR98015Test2C1Ev
120 Test2 empty2
[3] = {};
122 // CHECK: call void @llvm.memset.p0.i64
123 // CHECK-NOT: call void @llvm.memset.p0.i64
124 // CHECK-CXX98: call void @_ZN6PR98015Test3C1Ev
125 // CHECK-CXX17: call void @_ZN6PR98014TestC2Ev
126 // CHECK-NOT: call void @llvm.memset.p0.i64
127 // CHECK-NOT: call void @_ZN6PR98015Test3C1Ev
128 Test3 empty3
[3] = {};
136 // CHECK-LABEL: define{{.*}} i32 @_ZN8zeroinit4testEv()
138 // CHECK: call void @llvm.memset.p0.i64
153 // CHECK-LABEL: define{{.*}} void @_ZN8zeroinit9testX0_X1Ev
155 // CHECK: call void @llvm.memset.p0.i64
156 // CHECK-NEXT: call void @_ZN8zeroinit2X1C1Ev
157 // CHECK-NEXT: call void @_ZN8zeroinit2X11fEv
168 struct X3
: X2
<int> {
174 // CHECK-LABEL: define{{.*}} void @_ZN8zeroinit9testX0_X3Ev
176 // CHECK-NOT: call void @llvm.memset
177 // CHECK: call void @_ZN8zeroinit2X3IiEC1Ev
178 // CHECK: call void @_ZN8zeroinit2X2IiE1fEv
179 // CHECK-NEXT: ret void
183 // More checks at EOF
200 struct A
{ A(); A(int); };
203 A arr
[10][20] = { 5 };
205 // CHECK-LABEL: define{{.*}} void @_ZN5test64testEv()
206 // CHECK: [[ARR:%.*]] = alloca [10 x [20 x [[A:%.*]]]],
208 // CHECK-NEXT: [[INNER:%.*]] = getelementptr inbounds [10 x [20 x [[A]]]], ptr [[ARR]], i64 0, i64 0
209 // CHECK-NEXT: [[T0:%.*]] = getelementptr inbounds [20 x [[A]]], ptr [[INNER]], i64 0, i64 0
210 // CHECK-NEXT: call void @_ZN5test61AC1Ei(ptr {{[^,]*}} [[T0]], i32 noundef 5)
211 // CHECK-NEXT: [[BEGIN:%.*]] = getelementptr inbounds [[A]], ptr [[T0]], i64 1
212 // CHECK-NEXT: [[END:%.*]] = getelementptr inbounds [[A]], ptr [[T0]], i64 20
213 // CHECK-NEXT: br label
214 // CHECK: [[CUR:%.*]] = phi ptr [ [[BEGIN]], {{%.*}} ], [ [[NEXT:%.*]], {{%.*}} ]
215 // CHECK-NEXT: call void @_ZN5test61AC1Ev(ptr {{[^,]*}} [[CUR]])
216 // CHECK-NEXT: [[NEXT]] = getelementptr inbounds [[A]], ptr [[CUR]], i64 1
217 // CHECK-NEXT: [[T0:%.*]] = icmp eq ptr [[NEXT]], [[END]]
220 // CHECK: [[BEGIN:%.*]] = getelementptr inbounds [20 x [[A]]], ptr [[INNER]], i64 1
221 // CHECK-NEXT: [[END:%.*]] = getelementptr inbounds [20 x [[A]]], ptr [[INNER]], i64 10
222 // CHECK-NEXT: br label
223 // CHECK: [[CUR:%.*]] = phi ptr [ [[BEGIN]], {{%.*}} ], [ [[NEXT:%.*]], {{%.*}} ]
226 // CHECK-NEXT: [[IBEGIN:%.*]] = getelementptr inbounds [20 x [[A]]], ptr [[CUR]], i{{32|64}} 0, i{{32|64}} 0
227 // CHECK-NEXT: [[IEND:%.*]] = getelementptr inbounds [[A]], ptr [[IBEGIN]], i64 20
228 // CHECK-NEXT: br label
229 // CHECK: [[ICUR:%.*]] = phi ptr [ [[IBEGIN]], {{%.*}} ], [ [[INEXT:%.*]], {{%.*}} ]
230 // CHECK-NEXT: call void @_ZN5test61AC1Ev(ptr {{[^,]*}} [[ICUR]])
231 // CHECK-NEXT: [[INEXT:%.*]] = getelementptr inbounds [[A]], ptr [[ICUR]], i64 1
232 // CHECK-NEXT: [[T0:%.*]] = icmp eq ptr [[INEXT]], [[IEND]]
233 // CHECK-NEXT: br i1 [[T0]],
235 // CHECK: [[NEXT]] = getelementptr inbounds [20 x [[A]]], ptr [[CUR]], i64 1
236 // CHECK-NEXT: [[T0:%.*]] = icmp eq ptr [[NEXT]], [[END]]
237 // CHECK-NEXT: br i1 [[T0]]
242 // Make sure C::C doesn't overwrite parts of A while it is zero-initializing B
243 struct A
{ int a
; A(); A(int); };
244 struct B
: virtual A
{ int b
; };
245 struct C
: B
{ C(); };
246 C::C() : A(3), B() {}
247 // CHECK-LABEL: define{{.*}} void @_ZN7PR111241CC1Ev
248 // CHECK: call void @llvm.memset.p0.i64(ptr align 8 {{.*}}, i8 0, i64 12, i1 false)
249 // CHECK-NEXT: call void @_ZN7PR111241BC2Ev
250 // Make sure C::C doesn't overwrite parts of A while it is zero-initializing B
252 struct B2
: virtual A
{ int B::*b
; };
253 struct C2
: B2
{ C2(); };
254 C2::C2() : A(3), B2() {}
255 // CHECK-LABEL: define{{.*}} void @_ZN7PR111242C2C1Ev
256 // CHECK: call void @llvm.memcpy.p0.p0.i64(ptr align 8 %{{.*}}, ptr align 8 {{.*}}, i64 16, i1 false)
257 // CHECK-NEXT: call void @_ZN7PR111242B2C2Ev
260 // Ensure we produce an i1 here, and don't assert.
261 // CHECK-LABEL: define{{.*}} void @_Z9r170806_bv(
262 // CHECK: call void @_Z9r170806_ab(i1 noundef zeroext false)
263 void r170806_a(bool b
= bool());
264 void r170806_b() { r170806_a(); }
267 struct data
{ int i
; };
269 template<typename T
= int>
271 data d
; // not value-init
275 // CHECK-LABEL: define {{.*}} @_ZN7PR202561gIiEENS_4dataEv(
280 template<typename
...T
>
282 data
d(t
...); // value-init
286 // CHECK-LABEL: define {{.*}} @_ZN7PR202561hIJEEENS_4dataEDpT_(
287 // CHECK: call void @llvm.memset
291 template<typename T
= int>
293 data d
= {}; // value-init
297 // CHECK-LABEL: define {{.*}} @_ZN7PR202561jIiEENS_4dataEv(
298 // CHECK: call void @llvm.memset
302 data d
; // not value-init
305 // CHECK-LABEL: define {{.*}} @_ZN7PR202561fEv(
311 data d
= {}; // value-init
314 // CHECK-LABEL: define {{.*}} @_ZN7PR202561iEv(
315 // CHECK: call void @llvm.memset
319 // CHECK-LABEL: define {{.*}}@_Z20explicitly_defaultedv
320 int explicitly_defaulted() {
321 struct A
{ A() = default; int n
; };
322 // CHECK: call void @llvm.memset
327 // CHECK-LABEL: define linkonce_odr void @_ZN8zeroinit2X3IiEC2Ev(ptr {{[^,]*}} %this) unnamed_addr
328 // CHECK: call void @llvm.memset.p0.i64
329 // CHECK-NEXT: call void @_ZN8zeroinit2X2IiEC2Ev
330 // CHECK-NEXT: ret void
332 #if __cplusplus >= 201103L
333 namespace transparent_init_list
{
334 struct optional_assign_base
{};
335 struct optional_data_dtor_base
{ char dummy_
[24]; };
336 struct optional
: optional_data_dtor_base
, optional_assign_base
{};
337 optional
f(optional a
) { return {optional(a
)}; }