aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/optimize.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2001-01-28 11:35:45 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2001-01-28 11:35:45 +0100
commit6001735ea0da3d5d89a8f249a79fc8198ff28513 (patch)
tree94c342ca0fab35fea5547deab7b00d988fa3f612 /gcc/cp/optimize.c
parent666bd4e75249b156c8fa42c38f0c4edd0000ea91 (diff)
downloadgcc-6001735ea0da3d5d89a8f249a79fc8198ff28513.zip
gcc-6001735ea0da3d5d89a8f249a79fc8198ff28513.tar.gz
gcc-6001735ea0da3d5d89a8f249a79fc8198ff28513.tar.bz2
optimize.c (copy_body_r): If MODIFY_EXPR has both arguments identical and they would be replaced with...
* optimize.c (copy_body_r): If MODIFY_EXPR has both arguments identical and they would be replaced with constant, remove MODIFY_EXPR from the tree. * g++.old-deja/g++.other/inline18.C: New test. From-SVN: r39317
Diffstat (limited to 'gcc/cp/optimize.c')
-rw-r--r--gcc/cp/optimize.c20
1 files changed, 20 insertions, 0 deletions
diff --git a/gcc/cp/optimize.c b/gcc/cp/optimize.c
index 46f1c85..7a7a27c 100644
--- a/gcc/cp/optimize.c
+++ b/gcc/cp/optimize.c
@@ -338,6 +338,26 @@ copy_body_r (tp, walk_subtrees, data)
TREE_OPERAND (*tp, 1) = TREE_OPERAND (*tp, 3);
TREE_OPERAND (*tp, 3) = NULL_TREE;
}
+ else if (TREE_CODE (*tp) == MODIFY_EXPR
+ && TREE_OPERAND (*tp, 0) == TREE_OPERAND (*tp, 1)
+ && nonstatic_local_decl_p (TREE_OPERAND (*tp, 0))
+ && DECL_CONTEXT (TREE_OPERAND (*tp, 0)) == fn)
+ {
+ /* Assignments like a = a; don't generate any rtl code
+ and don't count as variable modification. Avoid
+ keeping bogosities like 0 = 0. */
+ tree decl = TREE_OPERAND (*tp, 0), value;
+ splay_tree_node n;
+
+ n = splay_tree_lookup (id->decl_map, (splay_tree_key) decl);
+ if (n)
+ {
+ value = (tree) n->value;
+ STRIP_TYPE_NOPS (value);
+ if (TREE_CONSTANT (value) || TREE_READONLY_DECL_P (value))
+ *tp = value;
+ }
+ }
}
/* Keep iterating. */