1 /* { dg-require-effective-target size32plus } */
2 
3 #define DEBUG 0
4 #if DEBUG
5 #include <stdio.h>
6 #endif
7 
8 #define N 200
9 
10 int A[N][N], B[N][N], C[N][N];
11 
12 static int __attribute__((noinline))
matmult(void)13 matmult (void)
14 {
15   int i, j, k;
16 
17   /* Loops J and K should be interchanged.  */
18   for (i = 0; i < N; i++)
19     for (j = 0; j < N; j++)
20       {
21         A[i][j] = 0;
22         for (k = 0; k < N; k++)
23           A[i][j] += B[i][k] * C[k][j];
24       }
25 
26   return A[0][0] + A[N-1][N-1];
27 }
28 
29 extern void abort ();
30 
31 int
main(void)32 main (void)
33 {
34   int i, j, res;
35 
36   for (i = 0; i < N; i++)
37     for (j = 0; j < N; j++)
38       {
39 	A[i][j] = 0;
40 	B[i][j] = i - j;
41 	C[i][j] = i + j;
42       }
43 
44   res = matmult ();
45 
46 #if DEBUG
47   fprintf (stderr, "res = %d \n", res);
48 #endif
49 
50   if (res != 2626800)
51     abort ();
52 
53   return 0;
54 }
55 
56 /* { dg-final { scan-tree-dump "tiled by" "graphite" } } */
57