From: Richard Biener Date: Fri, 12 Dec 2014 13:26:15 +0000 (+0000) Subject: re PR tree-optimization/64280 (ICE in replace_uses_by, at tree-cfg.c:1789) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=8c7b90945f6b13adea05b75d01f17225fb135bac;p=gcc.git re PR tree-optimization/64280 (ICE in replace_uses_by, at tree-cfg.c:1789) 2014-12-12 Richard Biener PR middle-end/64280 * tree-cfg.c (replace_uses_by): Guard assert properly. * g++.dg/torture/pr64280.C: New testcase. From-SVN: r218668 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 85eceaf5659..95f885bc435 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2014-12-12 Richard Biener + + PR middle-end/64280 + * tree-cfg.c (replace_uses_by): Guard assert properly. + 2014-12-12 Anthony Green * config/moxie/moxie.md: Add use of zex instruction. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e4eb34b5702..5b485a97708 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-12-12 Richard Biener + + PR middle-end/64280 + * g++.dg/torture/pr64280.C: New testcase. + 2014-12-12 Jakub Jelinek PR rtl-optimization/64255 diff --git a/gcc/testsuite/g++.dg/torture/pr64280.C b/gcc/testsuite/g++.dg/torture/pr64280.C new file mode 100644 index 00000000000..6ea31481bd5 --- /dev/null +++ b/gcc/testsuite/g++.dg/torture/pr64280.C @@ -0,0 +1,42 @@ +// { dg-do compile } + +class A +{ +public: + A (); +}; +class B +{ +public: + B (int); + operator void *() { return m_fn1 () ? 0 : this; } + int m_fn1 (); +}; +typedef int jmp_buf[]; +struct C +{ + jmp_buf cond_; +}; +class F +{ + C what_; + bool m_fn2 (); +}; +int _setjmp (int[]); +void longjmp (); +class D +{ +public: + D () { longjmp (); } +}; +bool +F::m_fn2 () +{ + B a (0); + if (a) + if (_setjmp (what_.cond_)) + return 0; + else + D (); + A b; +} diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index 6aca58d27d6..0ae4bd76f40 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -1781,7 +1781,8 @@ replace_uses_by (tree name, tree val) { e = gimple_phi_arg_edge (as_a (stmt), PHI_ARG_INDEX_FROM_USE (use)); - if (e->flags & EDGE_ABNORMAL) + if (e->flags & EDGE_ABNORMAL + && !SSA_NAME_OCCURS_IN_ABNORMAL_PHI (val)) { /* This can only occur for virtual operands, since for the real ones SSA_NAME_OCCURS_IN_ABNORMAL_PHI (name))