1 /* { dg-require-effective-target vect_int } */
12 void foo (short * __restrict__ dst
, short * __restrict__ src
, int h
,
17 for (i
= 0; i
< h
; i
++)
19 dst
[0] += A
*src
[0] + src
[stride
];
20 dst
[1] += A
*src
[1] + src
[1+stride
];
21 dst
[2] += A
*src
[2] + src
[2+stride
];
22 dst
[3] += A
*src
[3] + src
[3+stride
];
23 dst
[4] += A
*src
[4] + src
[4+stride
];
24 dst
[5] += A
*src
[5] + src
[5+stride
];
25 dst
[6] += A
*src
[6] + src
[6+stride
];
26 dst
[7] += A
*src
[7] + src
[7+stride
];
29 asm volatile ("" ::: "memory");
40 for (i
= 0; i
< N
; i
++)
49 for (i
= 0; i
< N
/2; i
++)
51 if (dst
[i
] != A
* i
+ i
+ 8)
58 /* Exclude POWER8 (only POWER cpu for which vect_element_align is true)
59 because loops have vectorized before SLP gets a shot. */
60 /* { dg-final { scan-tree-dump-times "optimized: basic block" 1 "slp1" { target { vect_element_align && { ! powerpc*-*-* } } } } } */