aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-ssa-ter.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2010-12-16 22:44:02 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2010-12-16 22:44:02 +0100
commitbcdae749d017a08b7298f86dd732b91edb84c2bd (patch)
treea6b941ced8b02130c5e8c8bcf0b55996d0d50ca7 /gcc/tree-ssa-ter.c
parent94406344b56752b35b729e97a85ce2a922ad6338 (diff)
downloadgcc-bcdae749d017a08b7298f86dd732b91edb84c2bd.zip
gcc-bcdae749d017a08b7298f86dd732b91edb84c2bd.tar.gz
gcc-bcdae749d017a08b7298f86dd732b91edb84c2bd.tar.bz2
re PR tree-optimization/43655 (-ftree-ter causes FAIL: g++.old-deja/g++.law/temps5.C execution test)
PR tree-optimization/43655 * tree-ssa-ter.c (is_replaceable_p): Don't use gimple_references_memory_p for -O0, instead check for load by looking at rhs. * g++.dg/opt/pr43655.C: New test. From-SVN: r167955
Diffstat (limited to 'gcc/tree-ssa-ter.c')
-rw-r--r--gcc/tree-ssa-ter.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/gcc/tree-ssa-ter.c b/gcc/tree-ssa-ter.c
index 7bd7669..47954cf 100644
--- a/gcc/tree-ssa-ter.c
+++ b/gcc/tree-ssa-ter.c
@@ -416,7 +416,9 @@ is_replaceable_p (gimple stmt)
return false;
/* Without alias info we can't move around loads. */
- if (gimple_references_memory_p (stmt) && !optimize)
+ if (!optimize
+ && gimple_assign_single_p (stmt)
+ && !is_gimple_val (gimple_assign_rhs1 (stmt)))
return false;
/* Float expressions must go through memory if float-store is on. */