http://gcc.gnu.org/bugzilla/show_bug.cgi?id=60418
--- Comment #4 from Richard Biener <rguenth at gcc dot gnu.org> --- (In reply to H.J. Lu from comment #0) > Since r208165, 435.gromacs in SPEC CPU 2006 is miscompiled on x32 with > > -mx32 -O3 -funroll-loops -ffast-math -fwhole-program -flto=jobserver > -fuse-linker-plugin > > The failure is > > Running 435.gromacs ref peak lto default > > *** Miscompare of gromacs.out; for details see > > /export/project/git/gcc-regression/spec/2006/spec/benchspec/CPU2006/435.grom > acs/run/run_peak_ref_lto.0000/gromacs.out.mis > > cat > /export/project/git/gcc-regression/spec/2006/spec/benchspec/CPU2006/435. > gromacs/run/run_peak_ref_lto.0000/gromacs.out.mis > 0002: 3.07684e+02 > 3.03594e+02 > > The result of 3.03594e+02 is outside of tolerance for 3.07684e+02. > I added a static counter in tree_forwarder_block_p for the number of > times returned true above and return false if it is between getenv("from") > and getenv("to"). I noticed that as more basic blocks get removed, > the deviation is getting bigger. One removed basic block has That's odd. What's the code generation difference in the end for the minimal range {to, from} that still shows a difference of the result?