| /* { dg-do compile } */ |
| /* { dg-additional-options "-fno-tree-loop-vectorize" } */ |
| |
| int a[4], b[4], c[400], d[400]; |
| |
| void f1() |
| { |
| int a0 = a[0] - b[0]; |
| int a1 = a[1] + b[1]; |
| int a2 = a[2] - b[2]; |
| int a3 = a[3] + b[3]; |
| int b0 = a0; |
| int b1 = a1; |
| int b2 = a2; |
| int b3 = a3; |
| for (int i = 0; i < 100; ++i) |
| { |
| a0 += c[i * 4 + 1]; |
| a1 += c[i * 4 + 0]; |
| a2 += c[i * 4 + 3]; |
| a3 += c[i * 4 + 2]; |
| b0 ^= d[i * 4 + 3]; |
| b1 ^= d[i * 4 + 2]; |
| b2 ^= d[i * 4 + 1]; |
| b3 ^= d[i * 4 + 0]; |
| } |
| a[0] = a0 ^ b0; |
| a[1] = a1 ^ b1; |
| a[2] = a2 ^ b2; |
| a[3] = a3 ^ b3; |
| } |
| |
| /* { dg-final { scan-tree-dump-times "add new stmt: \[^\\n\\r\]* = VEC_PERM_EXPR" 4 "slp1" { target { vect_int && vect_perm } } } } */ |
| /* { dg-final { scan-tree-dump "duplicating permutation node" "slp1" { target { vect_int && vect_perm } } } } */ |