[MIPS GlobalISel] Select MSA vector generic and builtin add
[llvm-complete.git] / test / CodeGen / AArch64 / arm64-big-endian-vector-callee.ll
blob52d269d37730a3955423ff9ae8e3ec6341f7c876
1 ; RUN: llc -mtriple aarch64_be < %s -aarch64-enable-ldst-opt=false -o - | FileCheck %s
2 ; RUN: llc -mtriple aarch64_be < %s -fast-isel=true -aarch64-enable-ldst-opt=false -o - | FileCheck %s
4 ; CHECK-LABEL: test_i64_f64:
5 define i64 @test_i64_f64(double %p) {
6 ; CHECK-NOT: rev
7     %1 = fadd double %p, %p
8     %2 = bitcast double %1 to i64
9     %3 = add i64 %2, %2
10     ret i64 %3
13 ; CHECK-LABEL: test_i64_v1i64:
14 define i64 @test_i64_v1i64(<1 x i64> %p) {
15 ; CHECK-NOT: rev
16     %1 = add <1 x i64> %p, %p
17     %2 = bitcast <1 x i64> %1 to i64
18     %3 = add i64 %2, %2
19     ret i64 %3
22 ; CHECK-LABEL: test_i64_v2f32:
23 define i64 @test_i64_v2f32(<2 x float> %p) {
24 ; CHECK: rev64 v{{[0-9]+}}.2s
25     %1 = fadd <2 x float> %p, %p
26     %2 = bitcast <2 x float> %1 to i64
27     %3 = add i64 %2, %2
28     ret i64 %3
31 ; CHECK-LABEL: test_i64_v2i32:
32 define i64 @test_i64_v2i32(<2 x i32> %p) {
33 ; CHECK: rev64 v{{[0-9]+}}.2s
34     %1 = add <2 x i32> %p, %p
35     %2 = bitcast <2 x i32> %1 to i64
36     %3 = add i64 %2, %2
37     ret i64 %3
40 ; CHECK-LABEL: test_i64_v4i16:
41 define i64 @test_i64_v4i16(<4 x i16> %p) {
42 ; CHECK: rev64 v{{[0-9]+}}.4h
43     %1 = add <4 x i16> %p, %p
44     %2 = bitcast <4 x i16> %1 to i64
45     %3 = add i64 %2, %2
46     ret i64 %3
49 ; CHECK-LABEL: test_i64_v8i8:
50 define i64 @test_i64_v8i8(<8 x i8> %p) {
51 ; CHECK: rev64 v{{[0-9]+}}.8b
52     %1 = add <8 x i8> %p, %p
53     %2 = bitcast <8 x i8> %1 to i64
54     %3 = add i64 %2, %2
55     ret i64 %3
58 ; CHECK-LABEL: test_f64_i64:
59 define double @test_f64_i64(i64 %p) {
60 ; CHECK-NOT: rev
61     %1 = add i64 %p, %p
62     %2 = bitcast i64 %1 to double
63     %3 = fadd double %2, %2
64     ret double %3
67 ; CHECK-LABEL: test_f64_v1i64:
68 define double @test_f64_v1i64(<1 x i64> %p) {
69 ; CHECK-NOT: rev
70     %1 = add <1 x i64> %p, %p
71     %2 = bitcast <1 x i64> %1 to double
72     %3 = fadd double %2, %2
73     ret double %3
76 ; CHECK-LABEL: test_f64_v2f32:
77 define double @test_f64_v2f32(<2 x float> %p) {
78 ; CHECK: rev64 v{{[0-9]+}}.2s
79     %1 = fadd <2 x float> %p, %p
80     %2 = bitcast <2 x float> %1 to double
81     %3 = fadd double %2, %2
82     ret double %3
85 ; CHECK-LABEL: test_f64_v2i32:
86 define double @test_f64_v2i32(<2 x i32> %p) {
87 ; CHECK: rev64 v{{[0-9]+}}.2s
88     %1 = add <2 x i32> %p, %p
89     %2 = bitcast <2 x i32> %1 to double
90     %3 = fadd double %2, %2
91     ret double %3
94 ; CHECK-LABEL: test_f64_v4i16:
95 define double @test_f64_v4i16(<4 x i16> %p) {
96 ; CHECK: rev64 v{{[0-9]+}}.4h
97     %1 = add <4 x i16> %p, %p
98     %2 = bitcast <4 x i16> %1 to double
99     %3 = fadd double %2, %2
100     ret double %3
103 ; CHECK-LABEL: test_f64_v8i8:
104 define double @test_f64_v8i8(<8 x i8> %p) {
105 ; CHECK: rev64 v{{[0-9]+}}.8b
106     %1 = add <8 x i8> %p, %p
107     %2 = bitcast <8 x i8> %1 to double
108     %3 = fadd double %2, %2
109     ret double %3
112 ; CHECK-LABEL: test_v1i64_i64:
113 define <1 x i64> @test_v1i64_i64(i64 %p) {
114 ; CHECK-NOT: rev
115     %1 = add i64 %p, %p
116     %2 = bitcast i64 %1 to <1 x i64>
117     %3 = add <1 x i64> %2, %2
118     ret <1 x i64> %3
121 ; CHECK-LABEL: test_v1i64_f64:
122 define <1 x i64> @test_v1i64_f64(double %p) {
123 ; CHECK-NOT: rev
124     %1 = fadd double %p, %p
125     %2 = bitcast double %1 to <1 x i64>
126     %3 = add <1 x i64> %2, %2
127     ret <1 x i64> %3
130 ; CHECK-LABEL: test_v1i64_v2f32:
131 define <1 x i64> @test_v1i64_v2f32(<2 x float> %p) {
132 ; CHECK: rev64 v{{[0-9]+}}.2s
133     %1 = fadd <2 x float> %p, %p
134     %2 = bitcast <2 x float> %1 to <1 x i64>
135     %3 = add <1 x i64> %2, %2
136     ret <1 x i64> %3
139 ; CHECK-LABEL: test_v1i64_v2i32:
140 define <1 x i64> @test_v1i64_v2i32(<2 x i32> %p) {
141 ; CHECK: rev64 v{{[0-9]+}}.2s
142     %1 = add <2 x i32> %p, %p
143     %2 = bitcast <2 x i32> %1 to <1 x i64>
144     %3 = add <1 x i64> %2, %2
145     ret <1 x i64> %3
148 ; CHECK-LABEL: test_v1i64_v4i16:
149 define <1 x i64> @test_v1i64_v4i16(<4 x i16> %p) {
150 ; CHECK: rev64 v{{[0-9]+}}.4h
151     %1 = add <4 x i16> %p, %p
152     %2 = bitcast <4 x i16> %1 to <1 x i64>
153     %3 = add <1 x i64> %2, %2
154     ret <1 x i64> %3
157 ; CHECK-LABEL: test_v1i64_v8i8:
158 define <1 x i64> @test_v1i64_v8i8(<8 x i8> %p) {
159 ; CHECK: rev64 v{{[0-9]+}}.8b
160     %1 = add <8 x i8> %p, %p
161     %2 = bitcast <8 x i8> %1 to <1 x i64>
162     %3 = add <1 x i64> %2, %2
163     ret <1 x i64> %3
166 ; CHECK-LABEL: test_v2f32_i64:
167 define <2 x float> @test_v2f32_i64(i64 %p) {
168 ; CHECK: rev64 v{{[0-9]+}}.2s
169     %1 = add i64 %p, %p
170     %2 = bitcast i64 %1 to <2 x float>
171     %3 = fadd <2 x float> %2, %2
172     ret <2 x float> %3
175 ; CHECK-LABEL: test_v2f32_f64:
176 define <2 x float> @test_v2f32_f64(double %p) {
177 ; CHECK: rev64 v{{[0-9]+}}.2s
178     %1 = fadd double %p, %p
179     %2 = bitcast double %1 to <2 x float>
180     %3 = fadd <2 x float> %2, %2
181     ret <2 x float> %3
184 ; CHECK-LABEL: test_v2f32_v1i64:
185 define <2 x float> @test_v2f32_v1i64(<1 x i64> %p) {
186 ; CHECK: rev64 v{{[0-9]+}}.2s
187     %1 = add <1 x i64> %p, %p
188     %2 = bitcast <1 x i64> %1 to <2 x float>
189     %3 = fadd <2 x float> %2, %2
190     ret <2 x float> %3
193 ; CHECK-LABEL: test_v2f32_v2i32:
194 define <2 x float> @test_v2f32_v2i32(<2 x i32> %p) {
195 ; CHECK: rev64 v{{[0-9]+}}.2s
196 ; CHECK: rev64 v{{[0-9]+}}.2s
197     %1 = add <2 x i32> %p, %p
198     %2 = bitcast <2 x i32> %1 to <2 x float>
199     %3 = fadd <2 x float> %2, %2
200     ret <2 x float> %3
203 ; CHECK-LABEL: test_v2f32_v4i16:
204 define <2 x float> @test_v2f32_v4i16(<4 x i16> %p) {
205 ; CHECK: rev64 v{{[0-9]+}}.4h
206 ; CHECK: rev64 v{{[0-9]+}}.2s
207     %1 = add <4 x i16> %p, %p
208     %2 = bitcast <4 x i16> %1 to <2 x float>
209     %3 = fadd <2 x float> %2, %2
210     ret <2 x float> %3
213 ; CHECK-LABEL: test_v2f32_v8i8:
214 define <2 x float> @test_v2f32_v8i8(<8 x i8> %p) {
215 ; CHECK: rev64 v{{[0-9]+}}.8b
216 ; CHECK: rev64 v{{[0-9]+}}.2s
217     %1 = add <8 x i8> %p, %p
218     %2 = bitcast <8 x i8> %1 to <2 x float>
219     %3 = fadd <2 x float> %2, %2
220     ret <2 x float> %3
223 ; CHECK-LABEL: test_v2i32_i64:
224 define <2 x i32> @test_v2i32_i64(i64 %p) {
225 ; CHECK: rev64 v{{[0-9]+}}.2s
226     %1 = add i64 %p, %p
227     %2 = bitcast i64 %1 to <2 x i32>
228     %3 = add <2 x i32> %2, %2
229     ret <2 x i32> %3
232 ; CHECK-LABEL: test_v2i32_f64:
233 define <2 x i32> @test_v2i32_f64(double %p) {
234 ; CHECK: rev64 v{{[0-9]+}}.2s
235     %1 = fadd double %p, %p
236     %2 = bitcast double %1 to <2 x i32>
237     %3 = add <2 x i32> %2, %2
238     ret <2 x i32> %3
241 ; CHECK-LABEL: test_v2i32_v1i64:
242 define <2 x i32> @test_v2i32_v1i64(<1 x i64> %p) {
243 ; CHECK: rev64 v{{[0-9]+}}.2s
244     %1 = add <1 x i64> %p, %p
245     %2 = bitcast <1 x i64> %1 to <2 x i32>
246     %3 = add <2 x i32> %2, %2
247     ret <2 x i32> %3
250 ; CHECK-LABEL: test_v2i32_v2f32:
251 define <2 x i32> @test_v2i32_v2f32(<2 x float> %p) {
252 ; CHECK: rev64 v{{[0-9]+}}.2s
253 ; CHECK: rev64 v{{[0-9]+}}.2s
254     %1 = fadd <2 x float> %p, %p
255     %2 = bitcast <2 x float> %1 to <2 x i32>
256     %3 = add <2 x i32> %2, %2
257     ret <2 x i32> %3
260 ; CHECK-LABEL: test_v2i32_v4i16:
261 define <2 x i32> @test_v2i32_v4i16(<4 x i16> %p) {
262 ; CHECK: rev64 v{{[0-9]+}}.4h
263 ; CHECK: rev64 v{{[0-9]+}}.2s
264     %1 = add <4 x i16> %p, %p
265     %2 = bitcast <4 x i16> %1 to <2 x i32>
266     %3 = add <2 x i32> %2, %2
267     ret <2 x i32> %3
270 ; CHECK-LABEL: test_v2i32_v8i8:
271 define <2 x i32> @test_v2i32_v8i8(<8 x i8> %p) {
272 ; CHECK: rev64 v{{[0-9]+}}.8b
273 ; CHECK: rev64 v{{[0-9]+}}.2s
274     %1 = add <8 x i8> %p, %p
275     %2 = bitcast <8 x i8> %1 to <2 x i32>
276     %3 = add <2 x i32> %2, %2
277     ret <2 x i32> %3
280 ; CHECK-LABEL: test_v4i16_i64:
281 define <4 x i16> @test_v4i16_i64(i64 %p) {
282 ; CHECK: rev64 v{{[0-9]+}}.4h
283     %1 = add i64 %p, %p
284     %2 = bitcast i64 %1 to <4 x i16>
285     %3 = add <4 x i16> %2, %2
286     ret <4 x i16> %3
289 ; CHECK-LABEL: test_v4i16_f64:
290 define <4 x i16> @test_v4i16_f64(double %p) {
291 ; CHECK: rev64 v{{[0-9]+}}.4h
292     %1 = fadd double %p, %p
293     %2 = bitcast double %1 to <4 x i16>
294     %3 = add <4 x i16> %2, %2
295     ret <4 x i16> %3
298 ; CHECK-LABEL: test_v4i16_v1i64:
299 define <4 x i16> @test_v4i16_v1i64(<1 x i64> %p) {
300 ; CHECK: rev64 v{{[0-9]+}}.4h
301     %1 = add <1 x i64> %p, %p
302     %2 = bitcast <1 x i64> %1 to <4 x i16>
303     %3 = add <4 x i16> %2, %2
304     ret <4 x i16> %3
307 ; CHECK-LABEL: test_v4i16_v2f32:
308 define <4 x i16> @test_v4i16_v2f32(<2 x float> %p) {
309 ; CHECK: rev64 v{{[0-9]+}}.2s
310 ; CHECK: rev64 v{{[0-9]+}}.4h
311     %1 = fadd <2 x float> %p, %p
312     %2 = bitcast <2 x float> %1 to <4 x i16>
313     %3 = add <4 x i16> %2, %2
314     ret <4 x i16> %3
317 ; CHECK-LABEL: test_v4i16_v2i32:
318 define <4 x i16> @test_v4i16_v2i32(<2 x i32> %p) {
319 ; CHECK: rev64 v{{[0-9]+}}.2s
320 ; CHECK: rev64 v{{[0-9]+}}.4h
321     %1 = add <2 x i32> %p, %p
322     %2 = bitcast <2 x i32> %1 to <4 x i16>
323     %3 = add <4 x i16> %2, %2
324     ret <4 x i16> %3
327 ; CHECK-LABEL: test_v4i16_v8i8:
328 define <4 x i16> @test_v4i16_v8i8(<8 x i8> %p) {
329 ; CHECK: rev64 v{{[0-9]+}}.8b
330 ; CHECK: rev64 v{{[0-9]+}}.4h
331     %1 = add <8 x i8> %p, %p
332     %2 = bitcast <8 x i8> %1 to <4 x i16>
333     %3 = add <4 x i16> %2, %2
334     ret <4 x i16> %3
337 ; CHECK-LABEL: test_v8i8_i64:
338 define <8 x i8> @test_v8i8_i64(i64 %p) {
339 ; CHECK: rev64 v{{[0-9]+}}.8b
340     %1 = add i64 %p, %p
341     %2 = bitcast i64 %1 to <8 x i8>
342     %3 = add <8 x i8> %2, %2
343     ret <8 x i8> %3
346 ; CHECK-LABEL: test_v8i8_f64:
347 define <8 x i8> @test_v8i8_f64(double %p) {
348 ; CHECK: rev64 v{{[0-9]+}}.8b
349     %1 = fadd double %p, %p
350     %2 = bitcast double %1 to <8 x i8>
351     %3 = add <8 x i8> %2, %2
352     ret <8 x i8> %3
355 ; CHECK-LABEL: test_v8i8_v1i64:
356 define <8 x i8> @test_v8i8_v1i64(<1 x i64> %p) {
357 ; CHECK: rev64 v{{[0-9]+}}.8b
358     %1 = add <1 x i64> %p, %p
359     %2 = bitcast <1 x i64> %1 to <8 x i8>
360     %3 = add <8 x i8> %2, %2
361     ret <8 x i8> %3
364 ; CHECK-LABEL: test_v8i8_v2f32:
365 define <8 x i8> @test_v8i8_v2f32(<2 x float> %p) {
366 ; CHECK: rev64 v{{[0-9]+}}.2s
367 ; CHECK: rev64 v{{[0-9]+}}.8b
368     %1 = fadd <2 x float> %p, %p
369     %2 = bitcast <2 x float> %1 to <8 x i8>
370     %3 = add <8 x i8> %2, %2
371     ret <8 x i8> %3
374 ; CHECK-LABEL: test_v8i8_v2i32:
375 define <8 x i8> @test_v8i8_v2i32(<2 x i32> %p) {
376 ; CHECK: rev64 v{{[0-9]+}}.2s
377 ; CHECK: rev64 v{{[0-9]+}}.8b
378     %1 = add <2 x i32> %p, %p
379     %2 = bitcast <2 x i32> %1 to <8 x i8>
380     %3 = add <8 x i8> %2, %2
381     ret <8 x i8> %3
384 ; CHECK-LABEL: test_v8i8_v4i16:
385 define <8 x i8> @test_v8i8_v4i16(<4 x i16> %p) {
386 ; CHECK: rev64 v{{[0-9]+}}.4h
387 ; CHECK: rev64 v{{[0-9]+}}.8b
388     %1 = add <4 x i16> %p, %p
389     %2 = bitcast <4 x i16> %1 to <8 x i8>
390     %3 = add <8 x i8> %2, %2
391     ret <8 x i8> %3
394 ; CHECK-LABEL: test_f128_v2f64:
395 define fp128 @test_f128_v2f64(<2 x double> %p) {
396 ; CHECK: ext
397     %1 = fadd <2 x double> %p, %p
398     %2 = bitcast <2 x double> %1 to fp128
399     %3 = fadd fp128 %2, %2
400     ret fp128 %3
403 ; CHECK-LABEL: test_f128_v2i64:
404 define fp128 @test_f128_v2i64(<2 x i64> %p) {
405 ; CHECK: ext
406     %1 = add <2 x i64> %p, %p
407     %2 = bitcast <2 x i64> %1 to fp128
408     %3 = fadd fp128 %2, %2
409     ret fp128 %3
412 ; CHECK-LABEL: test_f128_v4f32:
413 define fp128 @test_f128_v4f32(<4 x float> %p) {
414 ; CHECK: rev64 v{{[0-9]+}}.4s
415 ; CHECK: ext
416     %1 = fadd <4 x float> %p, %p
417     %2 = bitcast <4 x float> %1 to fp128
418     %3 = fadd fp128 %2, %2
419     ret fp128 %3
422 ; CHECK-LABEL: test_f128_v4i32:
423 define fp128 @test_f128_v4i32(<4 x i32> %p) {
424 ; CHECK: rev64 v{{[0-9]+}}.4s
425 ; CHECK: ext
426     %1 = add <4 x i32> %p, %p
427     %2 = bitcast <4 x i32> %1 to fp128
428     %3 = fadd fp128 %2, %2
429     ret fp128 %3
432 ; CHECK-LABEL: test_f128_v8i16:
433 define fp128 @test_f128_v8i16(<8 x i16> %p) {
434 ; CHECK: rev64 v{{[0-9]+}}.8h
435 ; CHECK: ext
436     %1 = add <8 x i16> %p, %p
437     %2 = bitcast <8 x i16> %1 to fp128
438     %3 = fadd fp128 %2, %2
439     ret fp128 %3
442 ; CHECK-LABEL: test_f128_v16i8:
443 define fp128 @test_f128_v16i8(<16 x i8> %p) {
444 ; CHECK: rev64 v{{[0-9]+}}.16b
445 ; CHECK: ext
446     %1 = add <16 x i8> %p, %p
447     %2 = bitcast <16 x i8> %1 to fp128
448     %3 = fadd fp128 %2, %2
449     ret fp128 %3
452 ; CHECK-LABEL: test_v2f64_f128:
453 define <2 x double> @test_v2f64_f128(fp128 %p) {
454 ; CHECK: ext
455     %1 = fadd fp128 %p, %p
456     %2 = bitcast fp128 %1 to <2 x double>
457     %3 = fadd <2 x double> %2, %2
458     ret <2 x double> %3
461 ; CHECK-LABEL: test_v2f64_v2i64:
462 define <2 x double> @test_v2f64_v2i64(<2 x i64> %p) {
463 ; CHECK: ext
464 ; CHECK: ext
465     %1 = add <2 x i64> %p, %p
466     %2 = bitcast <2 x i64> %1 to <2 x double>
467     %3 = fadd <2 x double> %2, %2
468     ret <2 x double> %3
471 ; CHECK-LABEL: test_v2f64_v4f32:
472 define <2 x double> @test_v2f64_v4f32(<4 x float> %p) {
473 ; CHECK: rev64 v{{[0-9]+}}.4s
474 ; CHECK: ext
475 ; CHECK: ext
476     %1 = fadd <4 x float> %p, %p
477     %2 = bitcast <4 x float> %1 to <2 x double>
478     %3 = fadd <2 x double> %2, %2
479     ret <2 x double> %3
482 ; CHECK-LABEL: test_v2f64_v4i32:
483 define <2 x double> @test_v2f64_v4i32(<4 x i32> %p) {
484 ; CHECK: rev64 v{{[0-9]+}}.4s
485 ; CHECK: ext
486 ; CHECK: ext
487     %1 = add <4 x i32> %p, %p
488     %2 = bitcast <4 x i32> %1 to <2 x double>
489     %3 = fadd <2 x double> %2, %2
490     ret <2 x double> %3
493 ; CHECK-LABEL: test_v2f64_v8i16:
494 define <2 x double> @test_v2f64_v8i16(<8 x i16> %p) {
495 ; CHECK: rev64 v{{[0-9]+}}.8h
496 ; CHECK: ext
497 ; CHECK: ext
498     %1 = add <8 x i16> %p, %p
499     %2 = bitcast <8 x i16> %1 to <2 x double>
500     %3 = fadd <2 x double> %2, %2
501     ret <2 x double> %3
504 ; CHECK-LABEL: test_v2f64_v16i8:
505 define <2 x double> @test_v2f64_v16i8(<16 x i8> %p) {
506 ; CHECK: rev64 v{{[0-9]+}}.16b
507 ; CHECK: ext
508 ; CHECK: ext
509     %1 = add <16 x i8> %p, %p
510     %2 = bitcast <16 x i8> %1 to <2 x double>
511     %3 = fadd <2 x double> %2, %2
512     ret <2 x double> %3
515 ; CHECK-LABEL: test_v2i64_f128:
516 define <2 x i64> @test_v2i64_f128(fp128 %p) {
517 ; CHECK: ext
518     %1 = fadd fp128 %p, %p
519     %2 = bitcast fp128 %1 to <2 x i64>
520     %3 = add <2 x i64> %2, %2
521     ret <2 x i64> %3
524 ; CHECK-LABEL: test_v2i64_v2f64:
525 define <2 x i64> @test_v2i64_v2f64(<2 x double> %p) {
526 ; CHECK: ext
527 ; CHECK: ext
528     %1 = fadd <2 x double> %p, %p
529     %2 = bitcast <2 x double> %1 to <2 x i64>
530     %3 = add <2 x i64> %2, %2
531     ret <2 x i64> %3
534 ; CHECK-LABEL: test_v2i64_v4f32:
535 define <2 x i64> @test_v2i64_v4f32(<4 x float> %p) {
536 ; CHECK: rev64 v{{[0-9]+}}.4s
537 ; CHECK: ext
538 ; CHECK: ext
539     %1 = fadd <4 x float> %p, %p
540     %2 = bitcast <4 x float> %1 to <2 x i64>
541     %3 = add <2 x i64> %2, %2
542     ret <2 x i64> %3
545 ; CHECK-LABEL: test_v2i64_v4i32:
546 define <2 x i64> @test_v2i64_v4i32(<4 x i32> %p) {
547 ; CHECK: rev64 v{{[0-9]+}}.4s
548 ; CHECK: ext
549 ; CHECK: ext
550     %1 = add <4 x i32> %p, %p
551     %2 = bitcast <4 x i32> %1 to <2 x i64>
552     %3 = add <2 x i64> %2, %2
553     ret <2 x i64> %3
556 ; CHECK-LABEL: test_v2i64_v8i16:
557 define <2 x i64> @test_v2i64_v8i16(<8 x i16> %p) {
558 ; CHECK: rev64 v{{[0-9]+}}.8h
559 ; CHECK: ext
560 ; CHECK: ext
561     %1 = add <8 x i16> %p, %p
562     %2 = bitcast <8 x i16> %1 to <2 x i64>
563     %3 = add <2 x i64> %2, %2
564     ret <2 x i64> %3
567 ; CHECK-LABEL: test_v2i64_v16i8:
568 define <2 x i64> @test_v2i64_v16i8(<16 x i8> %p) {
569 ; CHECK: rev64 v{{[0-9]+}}.16b
570 ; CHECK: ext
571 ; CHECK: ext
572     %1 = add <16 x i8> %p, %p
573     %2 = bitcast <16 x i8> %1 to <2 x i64>
574     %3 = add <2 x i64> %2, %2
575     ret <2 x i64> %3
578 ; CHECK-LABEL: test_v4f32_f128:
579 define <4 x float> @test_v4f32_f128(fp128 %p) {
580 ; CHECK: rev64 v{{[0-9]+}}.4s
581 ; CHECK: ext
582     %1 = fadd fp128 %p, %p
583     %2 = bitcast fp128 %1 to <4 x float>
584     %3 = fadd <4 x float> %2, %2
585     ret <4 x float> %3
588 ; CHECK-LABEL: test_v4f32_v2f64:
589 define <4 x float> @test_v4f32_v2f64(<2 x double> %p) {
590 ; CHECK: ext
591 ; CHECK: rev64 v{{[0-9]+}}.4s
592 ; CHECK: ext
593     %1 = fadd <2 x double> %p, %p
594     %2 = bitcast <2 x double> %1 to <4 x float>
595     %3 = fadd <4 x float> %2, %2
596     ret <4 x float> %3
599 ; CHECK-LABEL: test_v4f32_v2i64:
600 define <4 x float> @test_v4f32_v2i64(<2 x i64> %p) {
601 ; CHECK: ext
602 ; CHECK: rev64 v{{[0-9]+}}.4s
603 ; CHECK: ext
604     %1 = add <2 x i64> %p, %p
605     %2 = bitcast <2 x i64> %1 to <4 x float>
606     %3 = fadd <4 x float> %2, %2
607     ret <4 x float> %3
610 ; CHECK-LABEL: test_v4f32_v4i32:
611 define <4 x float> @test_v4f32_v4i32(<4 x i32> %p) {
612 ; CHECK: rev64 v{{[0-9]+}}.4s
613 ; CHECK: ext
614 ; CHECK: rev64 v{{[0-9]+}}.4s
615 ; CHECK: ext
616     %1 = add <4 x i32> %p, %p
617     %2 = bitcast <4 x i32> %1 to <4 x float>
618     %3 = fadd <4 x float> %2, %2
619     ret <4 x float> %3
622 ; CHECK-LABEL: test_v4f32_v8i16:
623 define <4 x float> @test_v4f32_v8i16(<8 x i16> %p) {
624 ; CHECK: rev64 v{{[0-9]+}}.8h
625 ; CHECK: ext
626 ; CHECK: rev64 v{{[0-9]+}}.4s
627 ; CHECK: ext
628     %1 = add <8 x i16> %p, %p
629     %2 = bitcast <8 x i16> %1 to <4 x float>
630     %3 = fadd <4 x float> %2, %2
631     ret <4 x float> %3
634 ; CHECK-LABEL: test_v4f32_v16i8:
635 define <4 x float> @test_v4f32_v16i8(<16 x i8> %p) {
636 ; CHECK: rev64 v{{[0-9]+}}.16b
637 ; CHECK: ext
638 ; CHECK: rev64 v{{[0-9]+}}.4s
639 ; CHECK: ext
640     %1 = add <16 x i8> %p, %p
641     %2 = bitcast <16 x i8> %1 to <4 x float>
642     %3 = fadd <4 x float> %2, %2
643     ret <4 x float> %3
646 ; CHECK-LABEL: test_v4i32_f128:
647 define <4 x i32> @test_v4i32_f128(fp128 %p) {
648 ; CHECK: rev64 v{{[0-9]+}}.4s
649 ; CHECK: ext
650     %1 = fadd fp128 %p, %p
651     %2 = bitcast fp128 %1 to <4 x i32>
652     %3 = add <4 x i32> %2, %2
653     ret <4 x i32> %3
656 ; CHECK-LABEL: test_v4i32_v2f64:
657 define <4 x i32> @test_v4i32_v2f64(<2 x double> %p) {
658 ; CHECK: ext
659 ; CHECK: rev64 v{{[0-9]+}}.4s
660 ; CHECK: ext
661     %1 = fadd <2 x double> %p, %p
662     %2 = bitcast <2 x double> %1 to <4 x i32>
663     %3 = add <4 x i32> %2, %2
664     ret <4 x i32> %3
667 ; CHECK-LABEL: test_v4i32_v2i64:
668 define <4 x i32> @test_v4i32_v2i64(<2 x i64> %p) {
669 ; CHECK: ext
670 ; CHECK: rev64 v{{[0-9]+}}.4s
671 ; CHECK: ext
672     %1 = add <2 x i64> %p, %p
673     %2 = bitcast <2 x i64> %1 to <4 x i32>
674     %3 = add <4 x i32> %2, %2
675     ret <4 x i32> %3
678 ; CHECK-LABEL: test_v4i32_v4f32:
679 define <4 x i32> @test_v4i32_v4f32(<4 x float> %p) {
680 ; CHECK: rev64 v{{[0-9]+}}.4s
681 ; CHECK: ext
682 ; CHECK: rev64 v{{[0-9]+}}.4s
683 ; CHECK: ext
684     %1 = fadd <4 x float> %p, %p
685     %2 = bitcast <4 x float> %1 to <4 x i32>
686     %3 = add <4 x i32> %2, %2
687     ret <4 x i32> %3
690 ; CHECK-LABEL: test_v4i32_v8i16:
691 define <4 x i32> @test_v4i32_v8i16(<8 x i16> %p) {
692 ; CHECK: rev64 v{{[0-9]+}}.8h
693 ; CHECK: ext
694 ; CHECK: rev64 v{{[0-9]+}}.4s
695 ; CHECK: ext
696     %1 = add <8 x i16> %p, %p
697     %2 = bitcast <8 x i16> %1 to <4 x i32>
698     %3 = add <4 x i32> %2, %2
699     ret <4 x i32> %3
702 ; CHECK-LABEL: test_v4i32_v16i8:
703 define <4 x i32> @test_v4i32_v16i8(<16 x i8> %p) {
704 ; CHECK: rev64 v{{[0-9]+}}.16b
705 ; CHECK: ext
706 ; CHECK: rev64 v{{[0-9]+}}.4s
707 ; CHECK: ext
708     %1 = add <16 x i8> %p, %p
709     %2 = bitcast <16 x i8> %1 to <4 x i32>
710     %3 = add <4 x i32> %2, %2
711     ret <4 x i32> %3
714 ; CHECK-LABEL: test_v8i16_f128:
715 define <8 x i16> @test_v8i16_f128(fp128 %p) {
716 ; CHECK: rev64 v{{[0-9]+}}.8h
717 ; CHECK: ext
718     %1 = fadd fp128 %p, %p
719     %2 = bitcast fp128 %1 to <8 x i16>
720     %3 = add <8 x i16> %2, %2
721     ret <8 x i16> %3
724 ; CHECK-LABEL: test_v8i16_v2f64:
725 define <8 x i16> @test_v8i16_v2f64(<2 x double> %p) {
726 ; CHECK: ext
727 ; CHECK: rev64 v{{[0-9]+}}.8h
728 ; CHECK: ext
729     %1 = fadd <2 x double> %p, %p
730     %2 = bitcast <2 x double> %1 to <8 x i16>
731     %3 = add <8 x i16> %2, %2
732     ret <8 x i16> %3
735 ; CHECK-LABEL: test_v8i16_v2i64:
736 define <8 x i16> @test_v8i16_v2i64(<2 x i64> %p) {
737 ; CHECK: ext
738 ; CHECK: rev64 v{{[0-9]+}}.8h
739 ; CHECK: ext
740     %1 = add <2 x i64> %p, %p
741     %2 = bitcast <2 x i64> %1 to <8 x i16>
742     %3 = add <8 x i16> %2, %2
743     ret <8 x i16> %3
746 ; CHECK-LABEL: test_v8i16_v4f32:
747 define <8 x i16> @test_v8i16_v4f32(<4 x float> %p) {
748 ; CHECK: rev64 v{{[0-9]+}}.4s
749 ; CHECK: ext
750 ; CHECK: rev64 v{{[0-9]+}}.8h
751 ; CHECK: ext
752     %1 = fadd <4 x float> %p, %p
753     %2 = bitcast <4 x float> %1 to <8 x i16>
754     %3 = add <8 x i16> %2, %2
755     ret <8 x i16> %3
758 ; CHECK-LABEL: test_v8i16_v4i32:
759 define <8 x i16> @test_v8i16_v4i32(<4 x i32> %p) {
760 ; CHECK: rev64 v{{[0-9]+}}.4s
761 ; CHECK: ext
762 ; CHECK: rev64 v{{[0-9]+}}.8h
763 ; CHECK: ext
764     %1 = add <4 x i32> %p, %p
765     %2 = bitcast <4 x i32> %1 to <8 x i16>
766     %3 = add <8 x i16> %2, %2
767     ret <8 x i16> %3
770 ; CHECK-LABEL: test_v8i16_v16i8:
771 define <8 x i16> @test_v8i16_v16i8(<16 x i8> %p) {
772 ; CHECK: rev64 v{{[0-9]+}}.16b
773 ; CHECK: ext
774 ; CHECK: rev64 v{{[0-9]+}}.8h
775 ; CHECK: ext
776     %1 = add <16 x i8> %p, %p
777     %2 = bitcast <16 x i8> %1 to <8 x i16>
778     %3 = add <8 x i16> %2, %2
779     ret <8 x i16> %3
782 ; CHECK-LABEL: test_v16i8_f128:
783 define <16 x i8> @test_v16i8_f128(fp128 %p) {
784 ; CHECK: rev64 v{{[0-9]+}}.16b
785 ; CHECK: ext
786     %1 = fadd fp128 %p, %p
787     %2 = bitcast fp128 %1 to <16 x i8>
788     %3 = add <16 x i8> %2, %2
789     ret <16 x i8> %3
792 ; CHECK-LABEL: test_v16i8_v2f64:
793 define <16 x i8> @test_v16i8_v2f64(<2 x double> %p) {
794 ; CHECK: ext
795 ; CHECK: rev64 v{{[0-9]+}}.16b
796 ; CHECK: ext
797     %1 = fadd <2 x double> %p, %p
798     %2 = bitcast <2 x double> %1 to <16 x i8>
799     %3 = add <16 x i8> %2, %2
800     ret <16 x i8> %3
803 ; CHECK-LABEL: test_v16i8_v2i64:
804 define <16 x i8> @test_v16i8_v2i64(<2 x i64> %p) {
805 ; CHECK: ext
806 ; CHECK: rev64 v{{[0-9]+}}.16b
807 ; CHECK: ext
808     %1 = add <2 x i64> %p, %p
809     %2 = bitcast <2 x i64> %1 to <16 x i8>
810     %3 = add <16 x i8> %2, %2
811     ret <16 x i8> %3
814 ; CHECK-LABEL: test_v16i8_v4f32:
815 define <16 x i8> @test_v16i8_v4f32(<4 x float> %p) {
816 ; CHECK: rev64 v{{[0-9]+}}.4s
817 ; CHECK: ext
818 ; CHECK: rev64 v{{[0-9]+}}.16b
819 ; CHECK: ext
820     %1 = fadd <4 x float> %p, %p
821     %2 = bitcast <4 x float> %1 to <16 x i8>
822     %3 = add <16 x i8> %2, %2
823     ret <16 x i8> %3
826 ; CHECK-LABEL: test_v16i8_v4i32:
827 define <16 x i8> @test_v16i8_v4i32(<4 x i32> %p) {
828 ; CHECK: rev64 v{{[0-9]+}}.4s
829 ; CHECK: ext
830 ; CHECK: rev64 v{{[0-9]+}}.16b
831 ; CHECK: ext
832     %1 = add <4 x i32> %p, %p
833     %2 = bitcast <4 x i32> %1 to <16 x i8>
834     %3 = add <16 x i8> %2, %2
835     ret <16 x i8> %3
838 ; CHECK-LABEL: test_v16i8_v8i16:
839 define <16 x i8> @test_v16i8_v8i16(<8 x i16> %p) {
840 ; CHECK: rev64 v{{[0-9]+}}.8h
841 ; CHECK: ext
842 ; CHECK: rev64 v{{[0-9]+}}.16b
843 ; CHECK: ext
844     %1 = add <8 x i16> %p, %p
845     %2 = bitcast <8 x i16> %1 to <16 x i8>
846     %3 = add <16 x i8> %2, %2
847     ret <16 x i8> %3