https://gcc.gnu.org/bugzilla/show_bug.cgi?id=71661

            Bug ID: 71661
           Summary: wrong code at -O3 on x86_64-linux-gnu (in both 32-bit
                    and 64-bit modes)
           Product: gcc
           Version: 7.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: tree-optimization
          Assignee: unassigned at gcc dot gnu.org
          Reporter: su at cs dot ucdavis.edu
  Target Milestone: ---

The current gcc trunk miscompiles the following code on x86_64-linux-gnu at -O3
in both 32-bit and 64-bit modes.

This is a regression from 6.1.x.

It should be different from PR 71550, which seems to have become latent for the
latest trunk. 


$ gcc-trunk -v
Using built-in specs.
COLLECT_GCC=gcc-trunk
COLLECT_LTO_WRAPPER=/usr/local/gcc-trunk/libexec/gcc/x86_64-pc-linux-gnu/7.0.0/lto-wrapper
Target: x86_64-pc-linux-gnu
Configured with: ../gcc-source-trunk/configure --enable-languages=c,c++,lto
--prefix=/usr/local/gcc-trunk --disable-bootstrap
Thread model: posix
gcc version 7.0.0 20160625 (experimental) [trunk revision 237780] (GCC) 
$ 
$ gcc-trunk -O2 small.c; ./a.out
$ gcc-6.1 -O3 small.c; ./a.out
$ 
$ gcc-trunk -O3 small.c  
$ ./a.out
Segmentation fault (core dumped)
$ 
$ gcc-trunk -O3 pr71550.c; ./a.out
$ gcc-trunk -O0 pr71550.c; ./a.out
$ 


------------------------------------


int a, b;

void
fn1 ()
{
  unsigned c = 0;
  int d;
  b = a;
  if (a < 0)
    goto L1;
  for (; a < 1; a++)
    d = 0;
  for (; d < 2; d++)
    {
      for (c = 0; c < 3; c++)
      L1:
        a = 2;
    }
}

int
main ()
{
  fn1 ();
  return 0;
}

Reply via email to