1 /* PR target/66560 */
2 /* { dg-do compile } */
3 /* { dg-options "-O2 -mavx" } */
4
5 typedef double v4df __attribute__((vector_size(32)));
6 typedef long long v4di __attribute__((vector_size(32)));
foo1(v4df x,v4df y)7 v4df foo1 (v4df x, v4df y)
8 {
9 v4df tem0 = x - y;
10 v4df tem1 = x + y;
11 return __builtin_shuffle (tem0, tem1, (v4di) { 0, 5, 2, 7 });
12 }
13
foo2(v4df x,v4df y)14 v4df foo2 (v4df x, v4df y)
15 {
16 v4df tem0 = x - y;
17 v4df tem1 = y + x;
18 return __builtin_shuffle (tem0, tem1, (v4di) { 0, 5, 2, 7 });
19 }
20
foo3(v4df x,v4df y)21 v4df foo3 (v4df x, v4df y)
22 {
23 v4df tem0 = x + y;
24 v4df tem1 = x - y;
25 return __builtin_shuffle (tem0, tem1, (v4di) { 4, 1, 6, 3 });
26 }
27
foo4(v4df x,v4df y)28 v4df foo4 (v4df x, v4df y)
29 {
30 v4df tem0 = y + x;
31 v4df tem1 = x - y;
32 return __builtin_shuffle (tem0, tem1, (v4di) { 4, 1, 6, 3 });
33 }
34
35 /* { dg-final { scan-assembler-times "vaddsubpd" 4 } } */
36