http://gcc.gnu.org/bugzilla/show_bug.cgi?id=60404
Bug ID: 60404
Summary: wrong code by LTO on x86_64-linux-gnu
Product: gcc
Version: 4.9.0
Status: UNCONFIRMED
Severity: normal
Priority: P3
Component: lto
Assignee: unassigned at gcc dot gnu.org
Reporter: su at cs dot ucdavis.edu
The current gcc trunk miscompiles the following code when using LTO on
x86_64-linux-gnu in both 32-bit and 64-bit modes.
This is a regression from 4.8.x.
$ gcc-trunk -v
Using built-in specs.
COLLECT_GCC=gcc-trunk
COLLECT_LTO_WRAPPER=/usr/local/gcc-trunk/libexec/gcc/x86_64-unknown-linux-gnu/4.9.0/lto-wrapper
Target: x86_64-unknown-linux-gnu
Configured with: ../gcc-trunk/configure --prefix=/usr/local/gcc-trunk
--enable-languages=c,c++ --disable-werror --enable-multilib
Thread model: posix
gcc version 4.9.0 20140303 (experimental) [trunk revision 208268] (GCC)
$
$ gcc-trunk -flto -O1 -c fn1.c
$ gcc-trunk -flto -O1 -c fn2.c
$ gcc-trunk -flto -O1 -c main.c
$ gcc-trunk -flto -O0 fn1.o fn2.o main.o
$ a.out
1
$
$ gcc-4.8.2 -flto -O1 -c fn1.c
$ gcc-4.8.2 -flto -O1 -c fn2.c
$ gcc-4.8.2 -flto -O1 -c main.c
$ gcc-4.8.2 -flto -O0 fn1.o fn2.o main.o
$ a.out
0
$
$ gcc-trunk -O0 fn1.c fn2.c main.c
$ a.out
0
$
$ cat fn1.c
void
fn1 (int p)
{
}
$ cat fn2.c
extern int b;
extern void fn1 (int);
void
fn2 (int p)
{
b = p++;
fn1 (p);
}
$ cat main.c
int printf (const char *, ...);
extern void fn2 (int);
int a[1];
int b;
int
main ()
{
fn2 (0);
printf ("%d\n", a[b]);
return 0;
}
$