From: rguenth Date: Mon, 19 May 2014 14:33:31 +0000 (+0000) Subject: 2014-05-19 Richard Biener X-Git-Tag: upstream/5.3.0~8351 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=22499a394f2e3f244a0a32fbe40e10ad5dc984d8;p=platform%2Fupstream%2Flinaro-gcc.git 2014-05-19 Richard Biener PR tree-optimization/61221 * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): Do nothing for unreachable blocks. * tree-ssa-sccvn.c (cond_dom_walker::before_dom_children): Improve unreachability detection. * gcc.dg/torture/pr61221.c: New testcase. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@210614 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 90eca0c..1cac5d2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,5 +1,13 @@ 2014-05-19 Richard Biener + PR tree-optimization/61221 + * tree-ssa-pre.c (eliminate_dom_walker::before_dom_children): + Do nothing for unreachable blocks. + * tree-ssa-sccvn.c (cond_dom_walker::before_dom_children): + Improve unreachability detection. + +2014-05-19 Richard Biener + PR tree-optimization/61209 * tree-ssa-sccvn.c (visit_phi): Avoid setting expr to VN_TOP. diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 83b4264..bb657c1 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,10 @@ 2014-05-19 Richard Biener + PR tree-optimization/61221 + * gcc.dg/torture/pr61221.c: New testcase. + +2014-05-19 Richard Biener + PR tree-optimization/61209 * gfortran.dg/pr61209.f90: New testcase. diff --git a/gcc/testsuite/gcc.dg/torture/pr61221.c b/gcc/testsuite/gcc.dg/torture/pr61221.c new file mode 100644 index 0000000..2524382 --- /dev/null +++ b/gcc/testsuite/gcc.dg/torture/pr61221.c @@ -0,0 +1,32 @@ +/* { dg-do compile } */ + +void __assert_fail (void); + +int **a, b, c, e, *j; +short *d, **f; + +int * +foo () +{ + *a = j; + if (!(1 & e)) + __assert_fail (); + return 0; +} + +void +bar () +{ + int *g = &b; + short **h = &d; + if ((f = &d) != h) + for (; b;) + { + int i = 1; + if (i) + g = foo (); + c = 0; + } + if (!g) + __assert_fail (); +} diff --git a/gcc/tree-ssa-pre.c b/gcc/tree-ssa-pre.c index f634f5e..e487d28 100644 --- a/gcc/tree-ssa-pre.c +++ b/gcc/tree-ssa-pre.c @@ -4010,6 +4010,15 @@ eliminate_dom_walker::before_dom_children (basic_block b) /* Mark new bb. */ el_avail_stack.safe_push (NULL_TREE); + /* If this block is not reachable do nothing. */ + edge_iterator ei; + edge e; + FOR_EACH_EDGE (e, ei, b->preds) + if (e->flags & EDGE_EXECUTABLE) + break; + if (!e) + return; + for (gsi = gsi_start_phis (b); !gsi_end_p (gsi);) { gimple stmt, phi = gsi_stmt (gsi); diff --git a/gcc/tree-ssa-sccvn.c b/gcc/tree-ssa-sccvn.c index bd60372..fc00682 100644 --- a/gcc/tree-ssa-sccvn.c +++ b/gcc/tree-ssa-sccvn.c @@ -4177,11 +4177,13 @@ cond_dom_walker::before_dom_children (basic_block bb) if (fail) return; - /* If any of the predecessor edges are still marked as possibly - executable consider this block reachable. */ + /* If any of the predecessor edges that do not come from blocks dominated + by us are still marked as possibly executable consider this block + reachable. */ bool reachable = bb == ENTRY_BLOCK_PTR_FOR_FN (cfun); FOR_EACH_EDGE (e, ei, bb->preds) - reachable |= (e->flags & EDGE_EXECUTABLE); + if (!dominated_by_p (CDI_DOMINATORS, e->src, bb)) + reachable |= (e->flags & EDGE_EXECUTABLE); /* If the block is not reachable all outgoing edges are not executable. */