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