From 38f50ab65ae67aa9896ca7a18a80d77b4648a0b0 Mon Sep 17 00:00:00 2001 From: Richard Biener Date: Fri, 27 Jan 2017 12:24:54 +0000 Subject: [PATCH] re PR tree-optimization/79244 (ice in replace_uses_by, at tree-cfg.c:1866) 2017-01-27 Richard Biener PR tree-optimization/79244 * tree-vrp.c (remove_range_assertions): Forcefully propagate out SSA names even if abnormal. * gcc.dg/torture/pr79244.c: New testcase. From-SVN: r244973 --- gcc/ChangeLog | 6 ++++++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gcc.dg/torture/pr79244.c | 13 +++++++++++++ gcc/tree-vrp.c | 16 ++++++++++++++-- 4 files changed, 38 insertions(+), 2 deletions(-) create mode 100644 gcc/testsuite/gcc.dg/torture/pr79244.c 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 + + PR tree-optimization/79244 + * tree-vrp.c (remove_range_assertions): Forcefully propagate + out SSA names even if abnormal. + 2017-01-27 Jakub Jelinek * 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 + + PR tree-optimization/79244 + * gcc.dg/torture/pr79244.c: New testcase. + 2017-01-27 Jakub Jelinek * 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); -- 2.7.4