/* { dg-require-effective-target vect_int } */ #include "tree-vect.h" int a[256], b[256]; void __attribute__((noinline)) foo (void) { int i; for (i = 0; i < 32; ++i) { b[i*8+0] = a[i*8+0]; b[i*8+1] = a[i*8+0]; b[i*8+2] = a[i*8+3]; b[i*8+3] = a[i*8+3]; b[i*8+4] = a[i*8+4]; b[i*8+5] = a[i*8+6]; b[i*8+6] = a[i*8+4]; b[i*8+7] = a[i*8+6]; } } int main () { int i; check_vect (); for (i = 0; i < 256; ++i) { a[i] = i; __asm__ volatile (""); } foo (); for (i = 0; i < 32; ++i) if (b[i*8+0] != i*8+0 || b[i*8+1] != i*8+0 || b[i*8+2] != i*8+3 || b[i*8+3] != i*8+3 || b[i*8+4] != i*8+4 || b[i*8+5] != i*8+6 || b[i*8+6] != i*8+4 || b[i*8+7] != i*8+6) abort (); return 0; } /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target vect_perm } } } */ /* SLP fails for variable-length SVE because the load size is greater than the minimum vector size. */ /* { dg-final { scan-tree-dump-times "vectorizing stmts using SLP" 1 "vect" { target vect_perm xfail { aarch64_sve && vect_variable_length } } } } */