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/] [20020310-1.c] - Rev 298

Compare with Previous | Blame | View Log

/* PR optimization/5844
   This testcase was miscompiled because of an rtx sharing bug.  */
/* { dg-do run } */
/* { dg-options "-O2" } */
/* { dg-options "-O2 -mtune=i586" { target { { i?86-*-* x86_64-*-* } && ilp32 } } } */
 
struct A
{
  struct A *a;
  int b;
};
 
struct B
{
  struct A *c;
  unsigned int d;
};
 
struct A p = { &p, -1 };
struct B q = { &p, 0 };
 
extern void abort (void);
extern void exit (int);
 
struct B *
foo (void)
{
  return &q;
}
 
void
bar (void)
{
  struct B *e = foo ();
  struct A *f = e->c;
  int g = f->b;
 
  if (++g == 0)
    {
      e->d++;
      e->c = f->a;
    }
 
  f->b = g;
}
 
int
main ()
{
  bar ();
  if (p.b != 0 || q.d != 1 || q.c != &p)
    abort ();
  exit (0);
}
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

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