| /* { dg-do run } */ |
| /* { dg-options "-O2 -floop-interchange -fdump-tree-linterchange-details" } */ |
| /* { dg-require-effective-target size20plus } */ |
| /* { dg-skip-if "too big data segment" { visium-*-* } } */ |
| |
| /* Copied from graphite/interchange-5.c */ |
| |
| #define DEBUG 0 |
| #if DEBUG |
| #include <stdio.h> |
| #endif |
| |
| #define N 100 |
| #define M 1111 |
| int A[N][M]; |
| |
| static int __attribute__((noinline)) |
| foo (void) |
| { |
| int i, j; |
| |
| for( i = 0; i < M; i++) |
| for( j = 0; j < N; j++) |
| A[j][i] = 5 * A[j][i]; |
| |
| return A[0][0] + A[N-1][M-1]; |
| } |
| |
| extern void abort (); |
| |
| static void __attribute__((noinline)) |
| init (int i) |
| { |
| int j; |
| |
| for (j = 0; j < M; j++) |
| A[i][j] = 2; |
| } |
| |
| int |
| main (void) |
| { |
| int i, j, res; |
| |
| for (i = 0; i < N; i++) |
| init (i); |
| |
| res = foo (); |
| |
| #if DEBUG |
| fprintf (stderr, "res = %d \n", res); |
| #endif |
| |
| if (res != 20) |
| abort (); |
| |
| return 0; |
| } |
| |
| /* { dg-final { scan-tree-dump-times "Loop_pair<outer:., inner:.> is interchanged" 1 "linterchange"} } */ |