summaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authormatz <matz@138bc75d-0d04-0410-961f-82ee72b054a4>2010-11-26 16:51:39 +0000
committermatz <matz@138bc75d-0d04-0410-961f-82ee72b054a4>2010-11-26 16:51:39 +0000
commit0d63aa16f49c5afb74d2572d84163c07d48874d8 (patch)
tree4d51b8434dfcafe81793e2040b84ada057bdbbc5 /gcc
parent1171c3e495fa7d149696c7c65fde6336eaf5dac3 (diff)
downloadgcc-0d63aa16f49c5afb74d2572d84163c07d48874d8.tar.gz
* tree-ssa-copy.c (fini_copy_prop): Don't DCE when we have loops.
* passes.c (init_optimization_passes): Remove superfluous copy-prop pass. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@167184 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/passes.c1
-rw-r--r--gcc/tree-ssa-copy.c4
3 files changed, 10 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 810590c5e13..7e996ca0f50 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2010-11-26 Michael Matz <matz@suse.de>
+
+ * tree-ssa-copy.c (fini_copy_prop): Don't DCE when we have loops.
+
+ * passes.c (init_optimization_passes): Remove superfluous
+ copy-prop pass.
+
2010-11-26 Richard Guenther <rguenther@suse.de>
PR lto/46648
diff --git a/gcc/passes.c b/gcc/passes.c
index b5cb2aca300..38cc570a39d 100644
--- a/gcc/passes.c
+++ b/gcc/passes.c
@@ -897,7 +897,6 @@ init_optimization_passes (void)
NEXT_PASS (pass_graphite);
{
struct opt_pass **p = &pass_graphite.pass.sub;
- NEXT_PASS (pass_copy_prop);
NEXT_PASS (pass_graphite_transforms);
NEXT_PASS (pass_copy_prop);
NEXT_PASS (pass_dce_loop);
diff --git a/gcc/tree-ssa-copy.c b/gcc/tree-ssa-copy.c
index 68370336a76..d552c3ab61b 100644
--- a/gcc/tree-ssa-copy.c
+++ b/gcc/tree-ssa-copy.c
@@ -775,7 +775,9 @@ fini_copy_prop (void)
duplicate_ssa_name_ptr_info (copy_of[i].value, SSA_NAME_PTR_INFO (var));
}
- substitute_and_fold (get_value, NULL, true);
+ /* Don't do DCE if we have loops. That's the simplest way to not
+ destroy the scev cache. */
+ substitute_and_fold (get_value, NULL, !current_loops);
free (copy_of);
}