diff options
author | Richard Biener <rguenther@suse.de> | 2016-05-24 12:40:01 +0000 |
---|---|---|
committer | Richard Biener <rguenth@gcc.gnu.org> | 2016-05-24 12:40:01 +0000 |
commit | 30fd2977745d53f282d1560212e3bea07943a937 (patch) | |
tree | 38872e66995c95e8cbb549b062945e2448f38ed6 /gcc/tree-ssa-dce.c | |
parent | 37923729c5ab013459a7eeeba5ce53fca75759fe (diff) | |
download | gcc-30fd2977745d53f282d1560212e3bea07943a937.zip gcc-30fd2977745d53f282d1560212e3bea07943a937.tar.gz gcc-30fd2977745d53f282d1560212e3bea07943a937.tar.bz2 |
re PR tree-optimization/71253 (ICE during loop distribution w/ -O2 -ftree-loop-distribution)
2016-05-24 Richard Biener <rguenther@suse.de>
PR tree-optimization/71253
* cfganal.h (control_dependences): Make robust against edge
and BB removal.
(control_dependences::control_dependences): Remove edge_list argument.
(control_dependences::get_edge): Remove.
(control_dependences::get_edge_src): Add.
(control_dependences::get_edge_dest): Likewise.
(control_dependences::m_el): Make a vector of edge src/dest index.
* cfganal.c (control_dependences::find_control_dependence): Adjust.
(control_dependences::control_dependences): Likewise.
(control_dependences::~control_dependence): Likewise.
(control_dependences::get_edge): Remove.
(control_dependences::get_edge_src): Add.
(control_dependences::get_edge_dest): Likewise.
* tree-ssa-dce.c (mark_control_dependent_edges_necessary): Use
get_edge_src.
(perform_tree_ssa_dce): Adjust.
* tree-loop-distribution.c (create_edge_for_control_dependence): Use
get_edge_src.
(pass_loop_distribution::execute): Adjust. Do loop destroying
conditional on changed.
* gcc.dg/torture/pr71253.c: New testcase.
From-SVN: r236636
Diffstat (limited to 'gcc/tree-ssa-dce.c')
-rw-r--r-- | gcc/tree-ssa-dce.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/gcc/tree-ssa-dce.c b/gcc/tree-ssa-dce.c index 75aaee9..954fc67 100644 --- a/gcc/tree-ssa-dce.c +++ b/gcc/tree-ssa-dce.c @@ -339,7 +339,7 @@ mark_control_dependent_edges_necessary (basic_block bb, bool ignore_self) EXECUTE_IF_SET_IN_BITMAP (cd->get_edges_dependent_on (bb->index), 0, edge_number, bi) { - basic_block cd_bb = cd->get_edge (edge_number)->src; + basic_block cd_bb = cd->get_edge_src (edge_number); if (ignore_self && cd_bb == bb) { @@ -1577,7 +1577,7 @@ perform_tree_ssa_dce (bool aggressive) { /* Compute control dependence. */ calculate_dominance_info (CDI_POST_DOMINATORS); - cd = new control_dependences (create_edge_list ()); + cd = new control_dependences (); visited_control_parents = sbitmap_alloc (last_basic_block_for_fn (cfun)); |