https://gcc.gnu.org/bugzilla/show_bug.cgi?id=61434
Bug ID: 61434 Summary: wrong code at -O3 on x86_64-linux Product: gcc Version: unknown Status: UNCONFIRMED Severity: normal Priority: P3 Component: tree-optimization Assignee: unassigned at gcc dot gnu.org Reporter: su at cs dot ucdavis.edu The current gcc trunk miscompiles the following code on x86_64-linux at -O3 in both 32-bit and 64-bit modes. This is a regression from 4.9.x. The issue seems to be in the tree vectorizer as the reported test does not fail with -fno-tree-vectorize. $ 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 20140606 (experimental) [trunk revision 211299] (GCC) $ $ gcc-trunk -O2 small.c; a.out $ gcc-trunk -fno-tree-vectorize -O3 small.c; a.out $ gcc-4.9.0 -O3 small.c; a.out $ $ gcc-trunk -O3 small.c $ a.out Aborted (core dumped) $ ----------------------------- int a, b[2], c, d, e, f, g; struct { int f1:1; int f2:1; } w; void fn1 (int p1, int p2) { // does nothing } int main () { b[1] = 1; for (; f < 1; f++) { w.f2 = 0; if (w.f1) fn1 (e++, a++ && d++); } for (; g < 1; g++) c = b[a]; if (c != 0) __builtin_abort (); return 0; }