Merge to HEAD at tree-cleanup-merge-20041024 .
[official-gcc.git] / gcc / testsuite / gcc.dg / vect / vect-62.c
blob28154c1f2c3004cad28dc8a8885d1b23eab0311f
1 /* { dg-do run { target powerpc*-*-* } } */
2 /* { dg-do run { target i?86-*-* x86_64-*-* } } */
3 /* { dg-options "-O2 -ftree-vectorize -fdump-tree-vect-stats -maltivec" { target powerpc*-*-* } } */
4 /* { dg-options "-O2 -ftree-vectorize -fdump-tree-vect-stats -msse2" { target i?86-*-* x86_64-*-* } } */
6 #include <stdarg.h>
7 #include "tree-vect.h"
9 #define N 16
11 int main1 ()
13 int i, j;
14 int ib[N] = {0,3,6,9,12,15,18,21,24,27,30,33,36,39,42,45};
15 int ia[N][4][N+8];
17 /* Multidimensional array. Aligned. The "inner" dimensions
18 are invariant in the inner loop. Store. */
19 for (i = 0; i < N; i++)
21 for (j = 0; j < N; j++)
23 ia[i][1][j+8] = ib[i];
27 /* check results: */
28 for (i = 0; i < N; i++)
30 for (j = 0; j < N; j++)
32 if (ia[i][1][j+8] != ib[i])
33 abort();
37 /* Multidimensional array. Aligned. The "inner" dimensions
38 are invariant in the inner loop. Store. */
39 for (i = 0; i < N; i++)
41 for (j = 0; j < N; j++)
43 ia[i][1][8] = ib[i];
47 /* check results: */
48 for (i = 0; i < N; i++)
50 for (j = 0; j < N; j++)
52 if (ia[i][1][8] != ib[i])
53 abort();
58 return 0;
61 int main (void)
63 check_vect ();
65 return main1 ();
68 /* { dg-final { scan-tree-dump-times "vectorized 2 loops" 1 "vect" } } */