https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61184
Bug ID: 61184 Summary: wrong code (that hangs) by LTO on x86_64-linux-gnu Product: gcc Version: 4.10.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. The generated code hangs. This is a regression from 4.9.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.10.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.10.0 20140513 (experimental) [trunk revision 210350] (GCC) $ $ gcc-trunk -flto -O0 -c foo.c $ gcc-trunk -flto -O0 -c main.c $ gcc-trunk -flto -Os foo.o main.o $ a.out ^C $ $ gcc-4.9.0 -flto -O0 -c foo.c $ gcc-4.9.0 -flto -O0 -c main.c $ gcc-4.9.0 -flto -Os foo.o main.o $ a.out $ $ cat foo.c short a; void foo (void) { for (a = 0; a >= 0; a++) ; } $ cat main.c extern void foo (void); int main () { foo (); return 0; } $