diff --git a/gcc/ChangeLog b/gcc/ChangeLog index d146a2efe08e..335436f56e7d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2009-08-12 Andrey Belevantsev + + PR rtl-optimization/41033 + * alias.c (nonoverlapping_component_refs_p): Punt when strict + aliasing is disabled. + 2009-08-11 Adam Nemet * config/mips/predicates.md (qi_mask_operand, hi_mask_operand, diff --git a/gcc/alias.c b/gcc/alias.c index fc259b8ef2df..442be827a75e 100644 --- a/gcc/alias.c +++ b/gcc/alias.c @@ -1980,6 +1980,9 @@ nonoverlapping_component_refs_p (const_tree x, const_tree y) { const_tree fieldx, fieldy, typex, typey, orig_y; + if (!flag_strict_aliasing) + return false; + do { /* The comparison has to be done at a common type, since we don't diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index a6e5bea1d3c3..11309d89c98b 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2009-08-12 Richard Guenther + + PR rtl-optimization/41033 + * gcc.dg/pr41033.c: New test. + 2009-08-11 Janus Weil PR fortran/41022 diff --git a/gcc/testsuite/gcc.dg/pr41033.c b/gcc/testsuite/gcc.dg/pr41033.c new file mode 100644 index 000000000000..5043be2d1191 --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr41033.c @@ -0,0 +1,24 @@ +/* { dg-options "-O1 -fno-strict-aliasing" } */ +/* PR rtl-optimization/41033 */ + +struct X { + int i; + int j; +}; + +int foo(struct X *p, struct X *q) +{ + p->j = 1; + q->i = 0; + return p->j; +} + +extern void abort (void); + +int main() +{ + struct X x; + if (foo (&x, (struct X *)&x.j) != 0) + abort (); + return 0; +}