Merge -r 127928:132243 from trunk
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / no-vfa-vect-dv-2.c
blob1a49ef26911adf98803072f24851c57c949fa7ad
1 /* { dg-require-effective-target vect_int } */
3 #include <stdarg.h>
4 #include <signal.h>
5 #include "tree-vect.h"
7 #define N 64
8 #define MAX 42
10 extern void abort(void);
12 int main ()
14 int A[N];
15 int B[N];
16 int C[N];
17 int D[N];
18 int E[N] = {0,1,2,0};
20 int i, j;
22 check_vect ();
24 for (i = 0; i < N; i++)
26 A[i] = i;
27 B[i] = i;
28 C[i] = i;
29 D[i] = i;
32 /* Vectorizable */
33 for (i = 0; i < N-20; i++)
35 A[i] = A[i+20];
38 /* check results: */
39 for (i = 0; i < N-20; i++)
41 if (A[i] != D[i+20])
42 abort ();
45 /* Vectorizable */
46 for (i = 0; i < 16; i++)
48 B[i] = B[i] + 5;
51 /* check results: */
52 for (i = 0; i < 16; i++)
54 if (B[i] != C[i] + 5)
55 abort ();
58 /* Not vectorizable */
59 for (i = 0; i < 4; i++)
61 C[i+3] = C[i];
64 /* check results: */
65 for (i = 0; i < 4; i++)
67 if (C[i] != E[i])
68 abort ();
71 return 0;
75 /* The initialization induction loop (with aligned access) is also vectorized. */
76 /* { dg-final { scan-tree-dump-times "vectorized 3 loops" 1 "vect" } } */
77 /* { dg-final { scan-tree-dump-times "accesses have the same alignment." 2 "vect" } } */
78 /* { dg-final { cleanup-tree-dump "vect" } } */