libcpp, c, middle-end: Optimize initializers using #embed in C
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / no-tree-pre-slp-29.c
blob8491d5f0070233af5c0baf64f9123d270fe1d51c
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include "tree-vect.h"
6 #define N 8
8 unsigned short in2[N*8] = {0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63};
10 int
11 main1 (unsigned short *in)
13 int i;
14 unsigned short out[N*8];
16 for (i = 0; i < N; i++)
18 out[i*4] = in[i*4];
19 out[i*4 + 1] = in[i*4 + 1];
20 out[i*4 + 2] = in[i*4 + 2];
21 out[i*4 + 3] = in[i*4 + 3];
24 /* check results: */
25 #pragma GCC novector
26 for (i = 0; i < N; i++)
28 if (out[i*4] != in[i*4]
29 || out[i*4 + 1] != in[i*4 + 1]
30 || out[i*4 + 2] != in[i*4 + 2]
31 || out[i*4 + 3] != in[i*4 + 3])
32 abort ();
35 return 0;
38 int
39 main2 (unsigned short * __restrict__ in, unsigned short * __restrict__ out)
41 int i;
43 for (i = 0; i < N; i++)
45 out[i*4] = in[i*4];
46 out[i*4 + 1] = in[i*4 + 1];
47 out[i*4 + 2] = in[i*4 + 2];
48 out[i*4 + 3] = in[i*4 + 3];
51 /* check results: */
52 #pragma GCC novector
53 for (i = 0; i < N; i++)
55 if (out[i*4] != in[i*4]
56 || out[i*4 + 1] != in[i*4 + 1]
57 || out[i*4 + 2] != in[i*4 + 2]
58 || out[i*4 + 3] != in[i*4 + 3])
59 abort ();
62 return 0;
65 int main (void)
67 unsigned short out[N*8];
69 check_vect ();
71 main1 (&in2[5]);
72 main2 (&in2[3], &out[3]);
74 return 0;
77 /* { dg-final { scan-tree-dump-times "vectorized 1 loops" 2 "vect" } } */
78 /* { dg-final { scan-tree-dump-times "vectorizing stmts using SLP" 2 "vect" } } */