2018-01-16 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-strided-store-u32-i2.c
bloba081d4e396e36a4633eb224d927543c7379d3108
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 16
8 int a[N*2];
9 int b[N] = {0,2,4,6,8,10,12,14,16,18,20,22,24,26,28,30};
10 int c[N] = {1,3,5,7,9,11,13,15,17,19,21,23,25,27,29,31};
12 __attribute__ ((noinline)) int
13 main1 (void)
15 int i;
17 /* Strided access pattern. */
18 for (i = 0; i < N/2; i++)
20 a[i*2] = b[i] + c[i];
21 a[i*2+1] = b[i] * c[i];
24 /* Check results. */
25 for (i = 0; i < N/2; i++)
27 if (a[i*2] != b[i] + c[i]
28 || a[i*2+1] != b[i] * c[i])
29 abort();
32 return 0;
35 int main (void)
37 check_vect ();
38 return main1 ();
41 /* Needs interleaving support. */
42 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target { vect_interleave || vect_strided2 } } } } */
43 /* { dg-final { scan-tree-dump-times "vectorized 0 loops" 1 "vect" { xfail { vect_interleave || vect_strided2 } } } } */