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:
parent
40b7c2f8d2
commit
84cce55d0e
@ -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,
|
||||
|
@ -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. */
|
||||
|
Loading…
Reference in New Issue
Block a user