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

Subversion Repositories openrisc

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [gcc.c-torture/] [execute/] [20071220-1.c] - Diff between revs 297 and 338

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

Rev 297 Rev 338
/* PR tree-optimization/29484 */
/* PR tree-optimization/29484 */
 
 
extern void abort (void);
extern void abort (void);
 
 
void *__attribute__((noinline))
void *__attribute__((noinline))
baz (void **lab)
baz (void **lab)
{
{
  asm volatile ("" : "+r" (lab));
  asm volatile ("" : "+r" (lab));
  return *lab;
  return *lab;
}
}
 
 
static inline
static inline
int bar (void)
int bar (void)
{
{
  static void *b[] = { &&addr };
  static void *b[] = { &&addr };
  void *p = baz (b);
  void *p = baz (b);
  goto *p;
  goto *p;
addr:
addr:
  return 17;
  return 17;
}
}
 
 
int __attribute__((noinline))
int __attribute__((noinline))
f1 (void)
f1 (void)
{
{
  return bar ();
  return bar ();
}
}
 
 
int __attribute__((noinline))
int __attribute__((noinline))
f2 (void)
f2 (void)
{
{
  return bar ();
  return bar ();
}
}
 
 
int
int
main (void)
main (void)
{
{
  if (f1 () != 17 || f1 () != 17 || f2 () != 17 || f2 () != 17)
  if (f1 () != 17 || f1 () != 17 || f2 () != 17 || f2 () != 17)
    abort ();
    abort ();
  return 0;
  return 0;
}
}
 
 

powered by: WebSVN 2.1.0

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