aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/torture/pr79244.c13
-rw-r--r--gcc/tree-vrp.c16
4 files changed, 38 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 2e52f20..41df9bb 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2017-01-27 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/79244
+ * tree-vrp.c (remove_range_assertions): Forcefully propagate
+ out SSA names even if abnormal.
+
2017-01-27 Jakub Jelinek <jakub@redhat.com>
* realmpfr.h: Poison MPFR_RND{N,Z,U,D}.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 4f3104b..525a7c7 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2017-01-27 Richard Biener <rguenther@suse.de>
+
+ PR tree-optimization/79244
+ * gcc.dg/torture/pr79244.c: New testcase.
+
2017-01-27 Jakub Jelinek <jakub@redhat.com>
* g++.dg/cilk-plus/CK/fib-opr-overload.cc (main): Change
diff --git a/gcc/testsuite/gcc.dg/torture/pr79244.c b/gcc/testsuite/gcc.dg/torture/pr79244.c
new file mode 100644
index 0000000..05143cd
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/torture/pr79244.c
@@ -0,0 +1,13 @@
+/* { dg-do compile } */
+
+long buf[5];
+int bar (void);
+
+int
+foo (int x)
+{
+ int y = __builtin_setjmp (buf);
+ while (x != 3 && x && x && x != 2)
+ x = bar ();
+ return y;
+}
diff --git a/gcc/tree-vrp.c b/gcc/tree-vrp.c
index d7d7a0d..e023244 100644
--- a/gcc/tree-vrp.c
+++ b/gcc/tree-vrp.c
@@ -6974,8 +6974,20 @@ remove_range_assertions (void)
}
}
- /* Propagate the RHS into every use of the LHS. */
- replace_uses_by (lhs, var);
+ /* Propagate the RHS into every use of the LHS. For SSA names
+ also propagate abnormals as it merely restores the original
+ IL in this case (an replace_uses_by would assert). */
+ if (TREE_CODE (var) == SSA_NAME)
+ {
+ imm_use_iterator iter;
+ use_operand_p use_p;
+ gimple *use_stmt;
+ FOR_EACH_IMM_USE_STMT (use_stmt, iter, lhs)
+ FOR_EACH_IMM_USE_ON_STMT (use_p, iter)
+ SET_USE (use_p, var);
+ }
+ else
+ replace_uses_by (lhs, var);
/* And finally, remove the copy, it is not needed. */
gsi_remove (&si, true);