[Bug middle-end/24716] [4.1 Regression] Wrong code generated when optimising

bonzini at gcc dot gnu dot org gcc-bugzilla@gcc.gnu.org
Wed Nov 9 08:20:00 GMT 2005



------- Comment #7 from bonzini at gcc dot gnu dot org  2005-11-09 08:20 -------
Reduced testcase

/* { dg-do run } */
/* { dg-options "-O -fdump-tree-dom3" } */

int Link[] = { -1 };
int W[] = { 2 };

extern void abort (void);

int f (int k, int p)
{
  int pdest, j, D1361;
  j = 0;
  pdest = 0;
  for (;;) {
    if (pdest > 2)
      do
        j--, pdest++;
      while (j > 2);

    if (j == 1)
      break;

    while (pdest > p)
      if (j == p)
        pdest++;

    do
      {
        D1361 = W[k];
        do
          if (D1361 != 0)
            pdest = 1, W[k] = D1361 = 0;
        while (p < 1);
    } while (k > 0);

    do
      {
        p = 0;
        k = Link[k];
        while (p < j)
          if (k != -1)
            pdest++, p++;
      }
    while (k != -1);
    j = 1;
  }

  /* The correct return value should be pdest (1 in the call from main).
     DOM3 is mistaken and propagates a 0 here.  */
  return pdest;
}

int main ()
{
  if (!f (0, 2))
    abort ();
  return 0;
}

/* { dg-final { scan-tree-dump-times "return 0" 1 "dom3" } } */
/* { dg-final { cleanup-tree-dump "dom3" } } */


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=24716



More information about the Gcc-bugs mailing list