blob: c662190ff386b7e80ceddaf3421aa5481143ca1c [file] [log] [blame]
Richard Smith1c96bc52013-12-11 01:40:16 +00001// RUN: %clang_cc1 -triple x86_64-linux-gnu -std=c++11 %s -emit-llvm -o - | FileCheck %s
2
3// PR10878
4
5struct S { S(); S(int); ~S(); int n; };
6
7void *p = new S[2][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
8
9// CHECK-LABEL: define
10// CHECK: %[[ALLOC:.*]] = call noalias i8* @_Znam(i64 32)
11// CHECK: %[[COOKIE:.*]] = bitcast i8* %[[ALLOC]] to i64*
12// CHECK: store i64 6, i64* %[[COOKIE]]
David Blaikie218b7832015-02-27 19:18:17 +000013// CHECK: %[[START_AS_i8:.*]] = getelementptr inbounds i8, i8* %[[ALLOC]], i64 8
Richard Smith1c96bc52013-12-11 01:40:16 +000014// CHECK: %[[START_AS_S:.*]] = bitcast i8* %[[START_AS_i8]] to %[[S:.*]]*
15//
16// Explicit initializers:
17//
18// { 1, 2, 3 }
19//
20// CHECK: %[[S_0:.*]] = bitcast %[[S]]* %[[START_AS_S]] to [3 x %[[S]]]*
21//
David Blaikie218b7832015-02-27 19:18:17 +000022// CHECK: %[[S_0_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 0, i64 0
Richard Smith1c96bc52013-12-11 01:40:16 +000023// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_0]], i32 1)
David Blaikie218b7832015-02-27 19:18:17 +000024// CHECK: %[[S_0_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000025// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_1]], i32 2)
David Blaikie218b7832015-02-27 19:18:17 +000026// CHECK: %[[S_0_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_1]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000027// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_2]], i32 3)
28//
29// { 4, 5, 6 }
30//
John McCall7f416cc2015-09-08 08:05:57 +000031// CHECK: %[[S_1:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000032//
David Blaikie218b7832015-02-27 19:18:17 +000033// CHECK: %[[S_1_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 0, i64 0
Richard Smith1c96bc52013-12-11 01:40:16 +000034// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_0]], i32 4)
David Blaikie218b7832015-02-27 19:18:17 +000035// CHECK: %[[S_1_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000036// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_1]], i32 5)
David Blaikie218b7832015-02-27 19:18:17 +000037// CHECK: %[[S_1_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_1]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000038// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_2]], i32 6)
39//
40// CHECK-NOT: br i1
41// CHECK-NOT: call
42// CHECK: }
43
44int n;
45void *q = new S[n][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
46
47// CHECK-LABEL: define
48//
David Blaikiea953f282015-02-27 21:19:58 +000049// CHECK: load i32, i32* @n
Richard Smith1c96bc52013-12-11 01:40:16 +000050// CHECK: call {{.*}} @llvm.umul.with.overflow.i64(i64 %[[N:.*]], i64 12)
51// CHECK: %[[ELTS:.*]] = mul i64 %[[N]], 3
52// CHECK: call {{.*}} @llvm.uadd.with.overflow.i64(i64 %{{.*}}, i64 8)
53// CHECK: %[[ALLOC:.*]] = call noalias i8* @_Znam(i64 %{{.*}})
54//
55// CHECK: %[[COOKIE:.*]] = bitcast i8* %[[ALLOC]] to i64*
56// CHECK: store i64 %[[ELTS]], i64* %[[COOKIE]]
David Blaikie218b7832015-02-27 19:18:17 +000057// CHECK: %[[START_AS_i8:.*]] = getelementptr inbounds i8, i8* %[[ALLOC]], i64 8
Richard Smith1c96bc52013-12-11 01:40:16 +000058// CHECK: %[[START_AS_S:.*]] = bitcast i8* %[[START_AS_i8]] to %[[S]]*
Richard Smith1c96bc52013-12-11 01:40:16 +000059//
60// Explicit initializers:
61//
62// { 1, 2, 3 }
63//
64// CHECK: %[[S_0:.*]] = bitcast %[[S]]* %[[START_AS_S]] to [3 x %[[S]]]*
65//
David Blaikie218b7832015-02-27 19:18:17 +000066// CHECK: %[[S_0_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 0, i64 0
Richard Smith1c96bc52013-12-11 01:40:16 +000067// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_0]], i32 1)
David Blaikie218b7832015-02-27 19:18:17 +000068// CHECK: %[[S_0_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000069// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_1]], i32 2)
David Blaikie218b7832015-02-27 19:18:17 +000070// CHECK: %[[S_0_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_0_1]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000071// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_0_2]], i32 3)
72//
73// { 4, 5, 6 }
74//
John McCall7f416cc2015-09-08 08:05:57 +000075// CHECK: %[[S_1:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000076//
David Blaikie218b7832015-02-27 19:18:17 +000077// CHECK: %[[S_1_0:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 0, i64 0
Richard Smith1c96bc52013-12-11 01:40:16 +000078// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_0]], i32 4)
David Blaikie218b7832015-02-27 19:18:17 +000079// CHECK: %[[S_1_1:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_0]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000080// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_1]], i32 5)
David Blaikie218b7832015-02-27 19:18:17 +000081// CHECK: %[[S_1_2:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_1_1]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000082// CHECK: call void @_ZN1SC1Ei(%[[S]]* %[[S_1_2]], i32 6)
83//
Richard Smith06a67e22014-06-03 06:58:52 +000084// And the rest.
85//
John McCall7f416cc2015-09-08 08:05:57 +000086// CHECK: %[[S_2:.*]] = getelementptr inbounds [3 x %[[S]]], [3 x %[[S]]]* %[[S_1]], i64 1
Richard Smith1c96bc52013-12-11 01:40:16 +000087// CHECK: %[[S_2_AS_S:.*]] = bitcast [3 x %[[S]]]* %[[S_2]] to %[[S]]*
Richard Smith06a67e22014-06-03 06:58:52 +000088//
89// CHECK: %[[REST:.*]] = sub i64 %[[ELTS]], 6
90// CHECK: icmp eq i64 %[[REST]], 0
Richard Smith1c96bc52013-12-11 01:40:16 +000091// CHECK: br i1
92//
David Blaikie218b7832015-02-27 19:18:17 +000093// CHECK: %[[END:.*]] = getelementptr inbounds %[[S]], %[[S]]* %[[S_2_AS_S]], i64 %[[REST]]
Richard Smith1c96bc52013-12-11 01:40:16 +000094// CHECK: br label
95//
Richard Smith06a67e22014-06-03 06:58:52 +000096// CHECK: %[[CUR:.*]] = phi %[[S]]* [ %[[S_2_AS_S]], {{.*}} ], [ %[[NEXT:.*]], {{.*}} ]
97// CHECK: call void @_ZN1SC1Ev(%[[S]]* %[[CUR]])
David Blaikie218b7832015-02-27 19:18:17 +000098// CHECK: %[[NEXT]] = getelementptr inbounds %[[S]], %[[S]]* %[[CUR]], i64 1
Richard Smith06a67e22014-06-03 06:58:52 +000099// CHECK: icmp eq %[[S]]* %[[NEXT]], %[[END]]
Richard Smith1c96bc52013-12-11 01:40:16 +0000100// CHECK: br i1
101//
102// CHECK: }
Richard Smith06a67e22014-06-03 06:58:52 +0000103
104struct T { int a; };
105void *r = new T[n][3]{ { 1, 2, 3 }, { 4, 5, 6 } };
106
107// CHECK-LABEL: define
108//
David Blaikiea953f282015-02-27 21:19:58 +0000109// CHECK: load i32, i32* @n
Richard Smith06a67e22014-06-03 06:58:52 +0000110// CHECK: call {{.*}} @llvm.umul.with.overflow.i64(i64 %[[N:.*]], i64 12)
111// CHECK: %[[ELTS:.*]] = mul i64 %[[N]], 3
112//
113// No cookie.
114// CHECK-NOT: @llvm.uadd.with.overflow
115//
116// CHECK: %[[ALLOC:.*]] = call noalias i8* @_Znam(i64 %{{.*}})
117//
118// CHECK: %[[START_AS_T:.*]] = bitcast i8* %[[ALLOC]] to %[[T:.*]]*
119//
120// Explicit initializers:
121//
122// { 1, 2, 3 }
123//
124// CHECK: %[[T_0:.*]] = bitcast %[[T]]* %[[START_AS_T]] to [3 x %[[T]]]*
125//
David Blaikie218b7832015-02-27 19:18:17 +0000126// CHECK: %[[T_0_0:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_0]], i64 0, i64 0
127// CHECK: %[[T_0_0_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_0]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000128// CHECK: store i32 1, i32* %[[T_0_0_0]]
David Blaikie218b7832015-02-27 19:18:17 +0000129// CHECK: %[[T_0_1:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_0]], i64 1
130// CHECK: %[[T_0_1_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_1]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000131// CHECK: store i32 2, i32* %[[T_0_1_0]]
David Blaikie218b7832015-02-27 19:18:17 +0000132// CHECK: %[[T_0_2:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_1]], i64 1
133// CHECK: %[[T_0_2_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_0_2]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000134// CHECK: store i32 3, i32* %[[T_0_2_0]]
135//
136// { 4, 5, 6 }
137//
John McCall7f416cc2015-09-08 08:05:57 +0000138// CHECK: %[[T_1:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_0]], i64 1
Richard Smith06a67e22014-06-03 06:58:52 +0000139//
David Blaikie218b7832015-02-27 19:18:17 +0000140// CHECK: %[[T_1_0:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_1]], i64 0, i64 0
141// CHECK: %[[T_1_0_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_0]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000142// CHECK: store i32 4, i32* %[[T_1_0_0]]
David Blaikie218b7832015-02-27 19:18:17 +0000143// CHECK: %[[T_1_1:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_0]], i64 1
144// CHECK: %[[T_1_1_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_1]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000145// CHECK: store i32 5, i32* %[[T_1_1_0]]
David Blaikie218b7832015-02-27 19:18:17 +0000146// CHECK: %[[T_1_2:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_1]], i64 1
147// CHECK: %[[T_1_2_0:.*]] = getelementptr inbounds %[[T]], %[[T]]* %[[T_1_2]], i32 0, i32 0
Richard Smith06a67e22014-06-03 06:58:52 +0000148// CHECK: store i32 6, i32* %[[T_1_2_0]]
149//
150// And the rest gets memset to 0.
151//
John McCall7f416cc2015-09-08 08:05:57 +0000152// CHECK: %[[T_2:.*]] = getelementptr inbounds [3 x %[[T]]], [3 x %[[T]]]* %[[T_1]], i64 1
Richard Smith06a67e22014-06-03 06:58:52 +0000153// CHECK: %[[T_2_AS_T:.*]] = bitcast [3 x %[[T]]]* %[[T_2]] to %[[T]]*
154//
155// CHECK: %[[SIZE:.*]] = sub i64 %{{.*}}, 24
156// CHECK: %[[REST:.*]] = bitcast %[[T]]* %[[T_2_AS_T]] to i8*
157// CHECK: call void @llvm.memset.p0i8.i64(i8* %[[REST]], i8 0, i64 %[[SIZE]], i32 4, i1 false)
158//
159// CHECK: }
160