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

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-stable/] [gcc-4.5.1/] [gcc/] [testsuite/] [gcc.dg/] [sms-6.c] - Diff between revs 816 and 826

Only display areas with differences | Details | Blame | View Log

Rev 816 Rev 826
/* { dg-do run } */
/* { dg-do run } */
/* { dg-options "-O2 -fmodulo-sched -fdump-rtl-sms" } */
/* { dg-options "-O2 -fmodulo-sched -fdump-rtl-sms" } */
 
 
extern void abort (void);
extern void abort (void);
 
 
__attribute__ ((noinline))
__attribute__ ((noinline))
void foo (int * __restrict__ a, int * __restrict__ b, int * __restrict__ c)
void foo (int * __restrict__ a, int * __restrict__ b, int * __restrict__ c)
{
{
   int i;
   int i;
   for(i = 0; i < 100; i+=4)
   for(i = 0; i < 100; i+=4)
     {
     {
       a[i] = b[i] * c[i];
       a[i] = b[i] * c[i];
       a[i+1] = b[i+1] * c[i+1];
       a[i+1] = b[i+1] * c[i+1];
       a[i+2] = b[i+2] * c[i+2];
       a[i+2] = b[i+2] * c[i+2];
       a[i+3] = b[i+3] * c[i+3];
       a[i+3] = b[i+3] * c[i+3];
     }
     }
}
}
 
 
 
 
int a[100], b[100], c[100];
int a[100], b[100], c[100];
int main()
int main()
{
{
#if (__SIZEOF_INT__ <= 2)
#if (__SIZEOF_INT__ <= 2)
  int i;
  int i;
  long res;
  long res;
#else
#else
  int i, res;
  int i, res;
#endif  
#endif  
  for(i = 0; i < 100; i++)
  for(i = 0; i < 100; i++)
    {
    {
      b[i] = c[i] = i;
      b[i] = c[i] = i;
    }
    }
  foo(a, b, c);
  foo(a, b, c);
 
 
  res = 0;
  res = 0;
  for(i = 0; i < 100; i++)
  for(i = 0; i < 100; i++)
    {
    {
      res += a[i];
      res += a[i];
    }
    }
  if(res != 328350)
  if(res != 328350)
    abort();
    abort();
 
 
  return 0;
  return 0;
}
}
 
 
/* { dg-final { scan-rtl-dump-times "SMS succeeded" 1 "sms"  { target spu-*-* } } } */
/* { dg-final { scan-rtl-dump-times "SMS succeeded" 1 "sms"  { target spu-*-* } } } */
/* { dg-final { scan-rtl-dump-times "SMS succeeded" 3  "sms" { target powerpc*-*-* } } } */
/* { dg-final { scan-rtl-dump-times "SMS succeeded" 3  "sms" { target powerpc*-*-* } } } */
/* { dg-final { cleanup-rtl-dump "sms" } } */
/* { dg-final { cleanup-rtl-dump "sms" } } */
 
 
 
 

powered by: WebSVN 2.1.0

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