2018-01-16 Richard Biener <rguenther@suse.de>
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / slp-8.c
blobe9ea0ef0d6b32d23977d728c943bac05dc982b2d
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 32
8 int ib[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45,0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45};
10 int main1 ()
12 int i;
13 float fa[N];
15 /* int -> float */
16 for (i = 0; i < N/4; i++)
18 fa[4*i] = (float) ib[4*i];
19 fa[4*i + 1] = (float) ib[4*i + 1];
20 fa[4*i + 2] = (float) ib[4*i + 2];
21 fa[4*i + 3] = (float) ib[4*i + 3];
24 /* check results: */
25 for (i = 0; i < N/4; i++)
27 if (fa[4*i] != (float) ib[4*i]
28 || fa[4*i + 1] != (float) ib[4*i + 1]
29 || fa[4*i + 2] != (float) ib[4*i + 2]
30 || fa[4*i + 3] != (float) ib[4*i + 3])
31 abort ();
34 return 0;
37 int main (void)
39 check_vect ();
41 return main1 ();
44 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 1 "vect" { target powerpc*-*-* i?86-*-* x86_64-*-* } } } */
45 /* { dg-final { scan-tree-dump-times "vectorizing stmts using SLP" 1 "vect" { target powerpc*-*-* i?86-*-* x86_64-*-* } } } */