https://gcc.gnu.org/bugzilla/show_bug.cgi?id=64853
Bug ID: 64853
Summary: wrong code at -Os and above on x86_64-linux-gnu
Product: gcc
Version: 5.0
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 -Os and
above in both 32-bit and 64-bit modes.
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/5.0.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 5.0.0 20150128 (experimental) [trunk revision 220198] (GCC)
$
$ gcc-trunk -O1 small.c; ./a.out
$ gcc-4.9 -Os small.c; ./a.out
$
$ gcc-trunk -Os small.c
$ ./a.out
Aborted (core dumped)
$
---------------------------------
struct S
{
int f1;
};
static struct S a = { 1 };
char b;
static unsigned char *c = &b;
int d, e, f;
int
fn1 (int p)
{
return 0 ? 0 : p - 1;
}
static int
fn2 (struct S p)
{
int g = 200;
for (e = 4; e; e = fn1 (e))
{
for (; d; d++)
;
*c &= p.f1 & g;
g = --*c;
if (f)
return 0;
}
return 0;
}
int
main ()
{
fn2 (a);
if (b != 0)
__builtin_abort ();
return 0;
}