aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorDaniel Berlin <dberlin@dberlin.org>2005-01-22 16:48:23 +0000
committerDaniel Berlin <dberlin@gcc.gnu.org>2005-01-22 16:48:23 +0000
commit111e0c9f4b0027d393f46fb8a5805fa2ac68283a (patch)
tree0a76779a7881d888f227491e074bdc5063b828ae /gcc
parent6aa9e91ac15db486a9edfd04bc40d9d7c2c57245 (diff)
downloadgcc-111e0c9f4b0027d393f46fb8a5805fa2ac68283a.zip
gcc-111e0c9f4b0027d393f46fb8a5805fa2ac68283a.tar.gz
gcc-111e0c9f4b0027d393f46fb8a5805fa2ac68283a.tar.bz2
re PR tree-optimization/19038 (tree-ssa causing loops to have more than one BB)
2005-01-20 Daniel Berlin <dberlin@dberlin.org> Fix PR tree-optimization/19038 * tree-ssa-dom.c (cprop_operand): Don't replace loop invaeriant copies with loop variant ones. From-SVN: r94069
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/tree-ssa-dom.c8
2 files changed, 14 insertions, 0 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 73db887..1a9d9e6 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2005-01-20 Daniel Berlin <dberlin@dberlin.org>
+
+ Fix PR tree-optimization/19038
+ * tree-ssa-dom.c (cprop_operand): Don't replace loop invaeriant
+ copies with loop variant ones.
+
2005-01-22 Kazu Hirata <kazu@cs.umass.edu>
* cfganal.c, real.h, reorg.c, timevar.def, tree-ssa-ccp.c,
diff --git a/gcc/tree-ssa-dom.c b/gcc/tree-ssa-dom.c
index 35847ec..6814798 100644
--- a/gcc/tree-ssa-dom.c
+++ b/gcc/tree-ssa-dom.c
@@ -2819,6 +2819,14 @@ cprop_operand (tree stmt, use_operand_p op_p)
extensions. */
else if (!may_propagate_copy (op, val))
return false;
+
+ /* Do not propagate copies if the propagated value is at a deeper loop
+ depth than the propagatee. Otherwise, this may move loop variant
+ variables outside of their loops and prevent coalescing
+ opportunities. If the value was loop invariant, it will be hoisted
+ by LICM and exposed for copy propagation. */
+ if (loop_depth_of_name (val) > loop_depth_of_name (op))
+ return false;
/* Dump details. */
if (dump_file && (dump_flags & TDF_DETAILS))