re PR tree-optimization/10528 (Unexpected loop un-optimization when removing a field of a class)

PR tree-opt/10528
        * tree-inline.c (copy_body_r): Recompute bits for ADDR_EXPR,
        after copying its argument.

From-SVN: r87423
This commit is contained in:
Richard Henderson 2004-09-12 19:28:19 -07:00 committed by Richard Henderson
parent 40b7c2f8d2
commit 84cce55d0e
2 changed files with 16 additions and 0 deletions

View File

@ -1,3 +1,9 @@
2004-09-13 Richard Henderson <rth@redhat.com>
PR tree-opt/10528
* tree-inline.c (copy_body_r): Recompute bits for ADDR_EXPR,
after copying its argument.
2004-09-13 Joseph S. Myers <jsm@polyomino.org.uk>
* c-common.c, c-decl.c, c-lex.c, c-objc-common.c, c-opts.c,

View File

@ -619,6 +619,16 @@ copy_body_r (tree *tp, int *walk_subtrees, void *data)
TREE_OPERAND (*tp, 1) = TREE_OPERAND (*tp, 3);
TREE_OPERAND (*tp, 3) = NULL_TREE;
}
/* Variable substitution need not be simple. In particular, the
INDIRECT_REF substitution above. Make sure that TREE_CONSTANT
and friends are up-to-date. */
else if (TREE_CODE (*tp) == ADDR_EXPR)
{
walk_tree (&TREE_OPERAND (*tp, 0), copy_body_r, id, NULL);
recompute_tree_invarant_for_addr_expr (*tp);
*walk_subtrees = 0;
}
}
/* Keep iterating. */