https://gcc.gnu.org/bugzilla/show_bug.cgi?id=67465
Bug ID: 67465 Summary: wrong code at -O3 on x86_64-linux-gnu Product: gcc Version: 6.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 5.2.x. Different from PR 67464, -fno-tree-vectorize makes the bug disappear. $ 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/6.0.0/lto-wrapper Target: x86_64-pc-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 6.0.0 20150905 (experimental) [trunk revision 227508] (GCC) $ $ gcc-trunk -O2 small.c; ./a.out $ gcc-trunk -O3 -fno-tree-vectorize small.c; ./a.out $ gcc-5.2 -O3 small.c; ./a.out $ $ gcc-trunk -O3 small.c $ ./a.out Aborted $ ------------------------------------------ int a, b, c, d, e, h; int fn1 (int p1) { { int g[2]; for (int i = 0; i < 1; i++) g[i] = 0; if (g[0] < c) { a = (unsigned) (1 ^ p1) % 2; return 0; } } return 0; } void fn2 () { for (h = 0; h < 1; h++) { for (int j = 0; j < 2; j++) { for (b = 1; b; b = 0) a = 1; for (; b < 1; b++) ; if (e) continue; a = 2; } fn1 (h); short k = -16; d = k > a; } } int main () { fn2 (); if (a != 2) __builtin_abort (); return 0; }