Viewing file: loop-interchange-14.c (1.01 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/* PR tree-optimization/83337 */ /* { dg-do run { target int32plus } } */ /* { dg-options "-O2 -floop-interchange -fdump-tree-linterchange-details" } */ /* { 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 struct S { int a : 3; int b : 17; int c : 12; }; struct S 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].b = 5 * A[j][i].b;
return A[0][0].b + A[N-1][M-1].b; }
extern void abort ();
static void __attribute__((noinline)) init (int i) { int j;
for (j = 0; j < M; j++) A[i][j].b = 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"} } */
|