annotate clang/test/CodeGen/ext-vector.c @ 207:2e18cbf3894f

LLVM12
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Tue, 08 Jun 2021 06:07:14 +0900
parents 1d019706d866
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clang_cc1 -emit-llvm %s -o - | FileCheck %s
anatofuz
parents:
diff changeset
2
anatofuz
parents:
diff changeset
3 typedef __attribute__(( ext_vector_type(4) )) float float4;
anatofuz
parents:
diff changeset
4 typedef __attribute__(( ext_vector_type(2) )) float float2;
anatofuz
parents:
diff changeset
5 typedef __attribute__(( ext_vector_type(4) )) int int4;
anatofuz
parents:
diff changeset
6 typedef __attribute__(( ext_vector_type(4) )) unsigned int uint4;
anatofuz
parents:
diff changeset
7
anatofuz
parents:
diff changeset
8 // CHECK: @foo = {{(dso_local )?}}global <4 x float> <float 1.000000e+00, float 2.000000e+00, float 3.000000e+00, float 4.000000e+00>
anatofuz
parents:
diff changeset
9 float4 foo = (float4){ 1.0, 2.0, 3.0, 4.0 };
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 // CHECK: @bar = {{(dso_local )?}}constant <4 x float> <float 1.000000e+00, float 2.000000e+00, float 3.000000e+00, float 0x7FF0000000000000>
anatofuz
parents:
diff changeset
12 const float4 bar = (float4){ 1.0, 2.0, 3.0, __builtin_inff() };
anatofuz
parents:
diff changeset
13
anatofuz
parents:
diff changeset
14 // CHECK: @test1
anatofuz
parents:
diff changeset
15 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
16 float4 test1(float4 V) {
anatofuz
parents:
diff changeset
17 return V.wzyx+V;
anatofuz
parents:
diff changeset
18 }
anatofuz
parents:
diff changeset
19
anatofuz
parents:
diff changeset
20 float2 vec2, vec2_2;
anatofuz
parents:
diff changeset
21 float4 vec4, vec4_2;
anatofuz
parents:
diff changeset
22 float f;
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 // CHECK: @test2
anatofuz
parents:
diff changeset
25 // CHECK: shufflevector {{.*}} <i32 0, i32 1>
anatofuz
parents:
diff changeset
26 // CHECK: extractelement
anatofuz
parents:
diff changeset
27 // CHECK: shufflevector {{.*}} <i32 1, i32 1, i32 1, i32 1>
anatofuz
parents:
diff changeset
28 // CHECK: insertelement
anatofuz
parents:
diff changeset
29 // CHECK: shufflevector {{.*}} <i32 1, i32 0>
anatofuz
parents:
diff changeset
30 void test2() {
anatofuz
parents:
diff changeset
31 vec2 = vec4.xy; // shorten
anatofuz
parents:
diff changeset
32 f = vec2.x; // extract elt
anatofuz
parents:
diff changeset
33 vec4 = vec4.yyyy; // splat
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 vec2.x = f; // insert one.
anatofuz
parents:
diff changeset
36 vec2.yx = vec2; // reverse
anatofuz
parents:
diff changeset
37 }
anatofuz
parents:
diff changeset
38
anatofuz
parents:
diff changeset
39 // CHECK: @test3
anatofuz
parents:
diff changeset
40 // CHECK: store <4 x float> <float 1.000000e+00, float 2.000000e+00, float 3.000000e+00, float 4.000000e+00>
anatofuz
parents:
diff changeset
41 void test3(float4 *out) {
anatofuz
parents:
diff changeset
42 *out = ((float4) {1.0f, 2.0f, 3.0f, 4.0f });
anatofuz
parents:
diff changeset
43 }
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 // CHECK: @test4
anatofuz
parents:
diff changeset
46 // CHECK: store <4 x float>
anatofuz
parents:
diff changeset
47 // CHECK: store <4 x float>
anatofuz
parents:
diff changeset
48 void test4(float4 *out) {
anatofuz
parents:
diff changeset
49 float a = 1.0f;
anatofuz
parents:
diff changeset
50 float b = 2.0f;
anatofuz
parents:
diff changeset
51 float c = 3.0f;
anatofuz
parents:
diff changeset
52 float d = 4.0f;
anatofuz
parents:
diff changeset
53 *out = ((float4) {a,b,c,d});
anatofuz
parents:
diff changeset
54 }
anatofuz
parents:
diff changeset
55
anatofuz
parents:
diff changeset
56 // CHECK: @test5
anatofuz
parents:
diff changeset
57 // CHECK: shufflevector {{.*}} <4 x i32> zeroinitializer
anatofuz
parents:
diff changeset
58 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
59 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
60 // CHECK: shufflevector {{.*}} <4 x i32> zeroinitializer
anatofuz
parents:
diff changeset
61 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
62 void test5(float4 *out) {
anatofuz
parents:
diff changeset
63 float a;
anatofuz
parents:
diff changeset
64 float4 b;
anatofuz
parents:
diff changeset
65
anatofuz
parents:
diff changeset
66 a = 1.0f;
anatofuz
parents:
diff changeset
67 b = a;
anatofuz
parents:
diff changeset
68 b = b * 5.0f;
anatofuz
parents:
diff changeset
69 b = 5.0f * b;
anatofuz
parents:
diff changeset
70 b *= a;
anatofuz
parents:
diff changeset
71
anatofuz
parents:
diff changeset
72 *out = b;
anatofuz
parents:
diff changeset
73 }
anatofuz
parents:
diff changeset
74
anatofuz
parents:
diff changeset
75 // CHECK: @test6
anatofuz
parents:
diff changeset
76 void test6(float4 *ap, float4 *bp, float c) {
anatofuz
parents:
diff changeset
77 float4 a = *ap;
anatofuz
parents:
diff changeset
78 float4 b = *bp;
anatofuz
parents:
diff changeset
79
anatofuz
parents:
diff changeset
80 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
81 // CHECK: fsub <4 x float>
anatofuz
parents:
diff changeset
82 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
83 // CHECK: fdiv <4 x float>
anatofuz
parents:
diff changeset
84 a = a + b;
anatofuz
parents:
diff changeset
85 a = a - b;
anatofuz
parents:
diff changeset
86 a = a * b;
anatofuz
parents:
diff changeset
87 a = a / b;
anatofuz
parents:
diff changeset
88
anatofuz
parents:
diff changeset
89 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
90 // CHECK: fsub <4 x float>
anatofuz
parents:
diff changeset
91 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
92 // CHECK: fdiv <4 x float>
anatofuz
parents:
diff changeset
93 a = a + c;
anatofuz
parents:
diff changeset
94 a = a - c;
anatofuz
parents:
diff changeset
95 a = a * c;
anatofuz
parents:
diff changeset
96 a = a / c;
anatofuz
parents:
diff changeset
97
anatofuz
parents:
diff changeset
98 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
99 // CHECK: fsub <4 x float>
anatofuz
parents:
diff changeset
100 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
101 // CHECK: fdiv <4 x float>
anatofuz
parents:
diff changeset
102 a += b;
anatofuz
parents:
diff changeset
103 a -= b;
anatofuz
parents:
diff changeset
104 a *= b;
anatofuz
parents:
diff changeset
105 a /= b;
anatofuz
parents:
diff changeset
106
anatofuz
parents:
diff changeset
107 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
108 // CHECK: fsub <4 x float>
anatofuz
parents:
diff changeset
109 // CHECK: fmul <4 x float>
anatofuz
parents:
diff changeset
110 // CHECK: fdiv <4 x float>
anatofuz
parents:
diff changeset
111 a += c;
anatofuz
parents:
diff changeset
112 a -= c;
anatofuz
parents:
diff changeset
113 a *= c;
anatofuz
parents:
diff changeset
114 a /= c;
anatofuz
parents:
diff changeset
115
anatofuz
parents:
diff changeset
116 // Vector comparisons can sometimes crash the x86 backend: rdar://6326239,
anatofuz
parents:
diff changeset
117 // reject them until the implementation is stable.
anatofuz
parents:
diff changeset
118 #if 0
anatofuz
parents:
diff changeset
119 int4 cmp;
anatofuz
parents:
diff changeset
120 cmp = a < b;
anatofuz
parents:
diff changeset
121 cmp = a <= b;
anatofuz
parents:
diff changeset
122 cmp = a < b;
anatofuz
parents:
diff changeset
123 cmp = a >= b;
anatofuz
parents:
diff changeset
124 cmp = a == b;
anatofuz
parents:
diff changeset
125 cmp = a != b;
anatofuz
parents:
diff changeset
126 #endif
anatofuz
parents:
diff changeset
127 }
anatofuz
parents:
diff changeset
128
anatofuz
parents:
diff changeset
129 // CHECK: @test7
anatofuz
parents:
diff changeset
130 void test7(int4 *ap, int4 *bp, int c) {
anatofuz
parents:
diff changeset
131 int4 a = *ap;
anatofuz
parents:
diff changeset
132 int4 b = *bp;
anatofuz
parents:
diff changeset
133
anatofuz
parents:
diff changeset
134 // CHECK: add <4 x i32>
anatofuz
parents:
diff changeset
135 // CHECK: sub <4 x i32>
anatofuz
parents:
diff changeset
136 // CHECK: mul <4 x i32>
anatofuz
parents:
diff changeset
137 // CHECK: sdiv <4 x i32>
anatofuz
parents:
diff changeset
138 // CHECK: srem <4 x i32>
anatofuz
parents:
diff changeset
139 a = a + b;
anatofuz
parents:
diff changeset
140 a = a - b;
anatofuz
parents:
diff changeset
141 a = a * b;
anatofuz
parents:
diff changeset
142 a = a / b;
anatofuz
parents:
diff changeset
143 a = a % b;
anatofuz
parents:
diff changeset
144
anatofuz
parents:
diff changeset
145 // CHECK: add <4 x i32>
anatofuz
parents:
diff changeset
146 // CHECK: sub <4 x i32>
anatofuz
parents:
diff changeset
147 // CHECK: mul <4 x i32>
anatofuz
parents:
diff changeset
148 // CHECK: sdiv <4 x i32>
anatofuz
parents:
diff changeset
149 // CHECK: srem <4 x i32>
anatofuz
parents:
diff changeset
150 a = a + c;
anatofuz
parents:
diff changeset
151 a = a - c;
anatofuz
parents:
diff changeset
152 a = a * c;
anatofuz
parents:
diff changeset
153 a = a / c;
anatofuz
parents:
diff changeset
154 a = a % c;
anatofuz
parents:
diff changeset
155
anatofuz
parents:
diff changeset
156 // CHECK: add <4 x i32>
anatofuz
parents:
diff changeset
157 // CHECK: sub <4 x i32>
anatofuz
parents:
diff changeset
158 // CHECK: mul <4 x i32>
anatofuz
parents:
diff changeset
159 // CHECK: sdiv <4 x i32>
anatofuz
parents:
diff changeset
160 // CHECK: srem <4 x i32>
anatofuz
parents:
diff changeset
161 a += b;
anatofuz
parents:
diff changeset
162 a -= b;
anatofuz
parents:
diff changeset
163 a *= b;
anatofuz
parents:
diff changeset
164 a /= b;
anatofuz
parents:
diff changeset
165 a %= b;
anatofuz
parents:
diff changeset
166
anatofuz
parents:
diff changeset
167 // CHECK: add <4 x i32>
anatofuz
parents:
diff changeset
168 // CHECK: sub <4 x i32>
anatofuz
parents:
diff changeset
169 // CHECK: mul <4 x i32>
anatofuz
parents:
diff changeset
170 // CHECK: sdiv <4 x i32>
anatofuz
parents:
diff changeset
171 // CHECK: srem <4 x i32>
anatofuz
parents:
diff changeset
172 a += c;
anatofuz
parents:
diff changeset
173 a -= c;
anatofuz
parents:
diff changeset
174 a *= c;
anatofuz
parents:
diff changeset
175 a /= c;
anatofuz
parents:
diff changeset
176 a %= c;
anatofuz
parents:
diff changeset
177
anatofuz
parents:
diff changeset
178
anatofuz
parents:
diff changeset
179 // Vector comparisons.
anatofuz
parents:
diff changeset
180 // CHECK: icmp slt
anatofuz
parents:
diff changeset
181 // CHECK: icmp sle
anatofuz
parents:
diff changeset
182 // CHECK: icmp sgt
anatofuz
parents:
diff changeset
183 // CHECK: icmp sge
anatofuz
parents:
diff changeset
184 // CHECK: icmp eq
anatofuz
parents:
diff changeset
185 // CHECK: icmp ne
anatofuz
parents:
diff changeset
186 int4 cmp;
anatofuz
parents:
diff changeset
187 cmp = a < b;
anatofuz
parents:
diff changeset
188 cmp = a <= b;
anatofuz
parents:
diff changeset
189 cmp = a > b;
anatofuz
parents:
diff changeset
190 cmp = a >= b;
anatofuz
parents:
diff changeset
191 cmp = a == b;
anatofuz
parents:
diff changeset
192 cmp = a != b;
anatofuz
parents:
diff changeset
193 }
anatofuz
parents:
diff changeset
194
anatofuz
parents:
diff changeset
195 // CHECK: @test8
anatofuz
parents:
diff changeset
196 void test8(float4 *ap, float4 *bp, int c) {
anatofuz
parents:
diff changeset
197 float4 a = *ap;
anatofuz
parents:
diff changeset
198 float4 b = *bp;
anatofuz
parents:
diff changeset
199
anatofuz
parents:
diff changeset
200 // Vector comparisons.
anatofuz
parents:
diff changeset
201 // CHECK: fcmp olt
anatofuz
parents:
diff changeset
202 // CHECK: fcmp ole
anatofuz
parents:
diff changeset
203 // CHECK: fcmp ogt
anatofuz
parents:
diff changeset
204 // CHECK: fcmp oge
anatofuz
parents:
diff changeset
205 // CHECK: fcmp oeq
anatofuz
parents:
diff changeset
206 // CHECK: fcmp une
anatofuz
parents:
diff changeset
207 int4 cmp;
anatofuz
parents:
diff changeset
208 cmp = a < b;
anatofuz
parents:
diff changeset
209 cmp = a <= b;
anatofuz
parents:
diff changeset
210 cmp = a > b;
anatofuz
parents:
diff changeset
211 cmp = a >= b;
anatofuz
parents:
diff changeset
212 cmp = a == b;
anatofuz
parents:
diff changeset
213 cmp = a != b;
anatofuz
parents:
diff changeset
214 }
anatofuz
parents:
diff changeset
215
anatofuz
parents:
diff changeset
216 // CHECK: @test9
anatofuz
parents:
diff changeset
217 // CHECK: extractelement <4 x i32>
anatofuz
parents:
diff changeset
218 int test9(int4 V) {
anatofuz
parents:
diff changeset
219 return V.xy.x;
anatofuz
parents:
diff changeset
220 }
anatofuz
parents:
diff changeset
221
anatofuz
parents:
diff changeset
222 // CHECK: @test10
anatofuz
parents:
diff changeset
223 // CHECK: add <4 x i32>
anatofuz
parents:
diff changeset
224 // CHECK: extractelement <4 x i32>
anatofuz
parents:
diff changeset
225 int test10(int4 V) {
anatofuz
parents:
diff changeset
226 return (V+V).x;
anatofuz
parents:
diff changeset
227 }
anatofuz
parents:
diff changeset
228
anatofuz
parents:
diff changeset
229 // CHECK: @test11
anatofuz
parents:
diff changeset
230 // CHECK: extractelement <4 x i32>
anatofuz
parents:
diff changeset
231 int4 test11a();
anatofuz
parents:
diff changeset
232 int test11() {
anatofuz
parents:
diff changeset
233 return test11a().x;
anatofuz
parents:
diff changeset
234 }
anatofuz
parents:
diff changeset
235
anatofuz
parents:
diff changeset
236 // CHECK: @test12
anatofuz
parents:
diff changeset
237 // CHECK: shufflevector {{.*}} <i32 2, i32 1, i32 0>
anatofuz
parents:
diff changeset
238 // CHECK: shufflevector {{.*}} <i32 0, i32 1, i32 2, i32 undef>
anatofuz
parents:
diff changeset
239 // CHECK: shufflevector {{.*}} <i32 4, i32 5, i32 6, i32 3>
anatofuz
parents:
diff changeset
240 int4 test12(int4 V) {
anatofuz
parents:
diff changeset
241 V.xyz = V.zyx;
anatofuz
parents:
diff changeset
242 return V;
anatofuz
parents:
diff changeset
243 }
anatofuz
parents:
diff changeset
244
anatofuz
parents:
diff changeset
245 // CHECK: @test13
anatofuz
parents:
diff changeset
246 // CHECK: shufflevector {{.*}} <i32 2, i32 1, i32 0, i32 3>
anatofuz
parents:
diff changeset
247 int4 test13(int4 *V) {
anatofuz
parents:
diff changeset
248 return V->zyxw;
anatofuz
parents:
diff changeset
249 }
anatofuz
parents:
diff changeset
250
anatofuz
parents:
diff changeset
251 // CHECK: @test14
anatofuz
parents:
diff changeset
252 void test14(uint4 *ap, uint4 *bp, unsigned c) {
anatofuz
parents:
diff changeset
253 uint4 a = *ap;
anatofuz
parents:
diff changeset
254 uint4 b = *bp;
anatofuz
parents:
diff changeset
255 int4 d;
anatofuz
parents:
diff changeset
256
anatofuz
parents:
diff changeset
257 // CHECK: udiv <4 x i32>
anatofuz
parents:
diff changeset
258 // CHECK: urem <4 x i32>
anatofuz
parents:
diff changeset
259 a = a / b;
anatofuz
parents:
diff changeset
260 a = a % b;
anatofuz
parents:
diff changeset
261
anatofuz
parents:
diff changeset
262 // CHECK: udiv <4 x i32>
anatofuz
parents:
diff changeset
263 // CHECK: urem <4 x i32>
anatofuz
parents:
diff changeset
264 a = a / c;
anatofuz
parents:
diff changeset
265 a = a % c;
anatofuz
parents:
diff changeset
266
anatofuz
parents:
diff changeset
267 // CHECK: icmp ult
anatofuz
parents:
diff changeset
268 // CHECK: icmp ule
anatofuz
parents:
diff changeset
269 // CHECK: icmp ugt
anatofuz
parents:
diff changeset
270 // CHECK: icmp uge
anatofuz
parents:
diff changeset
271 // CHECK: icmp eq
anatofuz
parents:
diff changeset
272 // CHECK: icmp ne
anatofuz
parents:
diff changeset
273 d = a < b;
anatofuz
parents:
diff changeset
274 d = a <= b;
anatofuz
parents:
diff changeset
275 d = a > b;
anatofuz
parents:
diff changeset
276 d = a >= b;
anatofuz
parents:
diff changeset
277 d = a == b;
anatofuz
parents:
diff changeset
278 d = a != b;
anatofuz
parents:
diff changeset
279 }
anatofuz
parents:
diff changeset
280
anatofuz
parents:
diff changeset
281 // CHECK: @test15
anatofuz
parents:
diff changeset
282 int4 test15(uint4 V0) {
anatofuz
parents:
diff changeset
283 // CHECK: icmp eq <4 x i32>
anatofuz
parents:
diff changeset
284 int4 V = !V0;
anatofuz
parents:
diff changeset
285 V = V && V;
anatofuz
parents:
diff changeset
286 V = V || V;
anatofuz
parents:
diff changeset
287 return V;
anatofuz
parents:
diff changeset
288 }
anatofuz
parents:
diff changeset
289
anatofuz
parents:
diff changeset
290 // CHECK: @test16
anatofuz
parents:
diff changeset
291 void test16(float2 a, float2 b) {
anatofuz
parents:
diff changeset
292 float2 t0 = (a + b) / 2;
anatofuz
parents:
diff changeset
293 }
anatofuz
parents:
diff changeset
294
anatofuz
parents:
diff changeset
295 typedef char char16 __attribute__((ext_vector_type(16)));
anatofuz
parents:
diff changeset
296
anatofuz
parents:
diff changeset
297 // CHECK: @test17
anatofuz
parents:
diff changeset
298 void test17(void) {
anatofuz
parents:
diff changeset
299 char16 valA;
anatofuz
parents:
diff changeset
300 char valB;
anatofuz
parents:
diff changeset
301 char valC;
anatofuz
parents:
diff changeset
302 char16 destVal = valC ? valA : valB;
anatofuz
parents:
diff changeset
303 }
anatofuz
parents:
diff changeset
304
anatofuz
parents:
diff changeset
305 typedef __attribute__(( ext_vector_type(16) )) float float16;
anatofuz
parents:
diff changeset
306
anatofuz
parents:
diff changeset
307 float16 vec16, vec16_2;
anatofuz
parents:
diff changeset
308
anatofuz
parents:
diff changeset
309 // CHECK: @test_rgba
anatofuz
parents:
diff changeset
310 void test_rgba() {
anatofuz
parents:
diff changeset
311 // CHECK: fadd <4 x float>
anatofuz
parents:
diff changeset
312 vec4_2 = vec4.abgr + vec4;
anatofuz
parents:
diff changeset
313
anatofuz
parents:
diff changeset
314 // CHECK: shufflevector {{.*}} <i32 0, i32 1>
anatofuz
parents:
diff changeset
315 vec2 = vec4.rg;
anatofuz
parents:
diff changeset
316 // CHECK: shufflevector {{.*}} <i32 2, i32 3>
anatofuz
parents:
diff changeset
317 vec2_2 = vec4.ba;
anatofuz
parents:
diff changeset
318 // CHECK: extractelement {{.*}} 2
anatofuz
parents:
diff changeset
319 f = vec4.b;
anatofuz
parents:
diff changeset
320 // CHECK: shufflevector {{.*}} <i32 2, i32 2, i32 2, i32 2>
anatofuz
parents:
diff changeset
321 vec4_2 = vec4_2.bbbb;
anatofuz
parents:
diff changeset
322
anatofuz
parents:
diff changeset
323 // CHECK: insertelement {{.*}} 0
anatofuz
parents:
diff changeset
324 vec2.r = f;
anatofuz
parents:
diff changeset
325 // CHECK: shufflevector {{.*}} <i32 1, i32 0>
anatofuz
parents:
diff changeset
326 vec2.gr = vec2;
anatofuz
parents:
diff changeset
327
anatofuz
parents:
diff changeset
328 // CHECK: extractelement {{.*}} 0
anatofuz
parents:
diff changeset
329 f = vec4_2.rg.r;
anatofuz
parents:
diff changeset
330 // CHECK: shufflevector {{.*}} <i32 2, i32 1, i32 0>
anatofuz
parents:
diff changeset
331 // CHECK: shufflevector {{.*}} <i32 0, i32 1, i32 2, i32 undef>
anatofuz
parents:
diff changeset
332 // CHECK: shufflevector {{.*}} <i32 4, i32 5, i32 6, i32 3>
anatofuz
parents:
diff changeset
333 vec4.rgb = vec4.bgr;
anatofuz
parents:
diff changeset
334
anatofuz
parents:
diff changeset
335 // CHECK: extractelement {{.*}} 11
anatofuz
parents:
diff changeset
336 // CHECK: insertelement {{.*}} 2
anatofuz
parents:
diff changeset
337 vec4.b = vec16.sb;
anatofuz
parents:
diff changeset
338 // CHECK: shufflevector {{.*}} <i32 10, i32 11, i32 12, i32 13>
anatofuz
parents:
diff changeset
339 vec4_2 = vec16.sabcd;
anatofuz
parents:
diff changeset
340 }