OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [gcc.dg/] [tree-ssa/] [loop-3.c] - Rev 300

Go to most recent revision | Compare with Previous | Blame | View Log

/* A test for strength reduction and induction variable elimination.
   Target is restricted to x86 type architectures, so that we may
   assume something about memory addressing modes.  */
 
/* { dg-do compile { target { { i?86-*-* x86_64-*-* } && nonpic } } } */
/* { dg-options "-O1 -fdump-tree-optimized" } */
 
int arr_base[100];
 
int foo(int);
 
void xxx(void)
{
  long iter;
 
  for (iter = 0; iter < 100; iter++)
    arr_base[iter] = foo (iter);
}
 
/* Access to arr_base[iter].y should not be strength reduced, since
   we have a memory mode including multiplication by 4.  */
 
/* { dg-final { scan-tree-dump-times "MEM" 1 "optimized" } } */
/* { dg-final { scan-tree-dump-times "step:" 1 "optimized" } } */
 
/* And original induction variable should be preserved.  */
 
/* { dg-final { scan-tree-dump-times "int iter" 1 "optimized" } } */
 
/* { dg-final { cleanup-tree-dump "optimized" } } */
 

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.