Commit e82f5749 by Roger Sayle Committed by Roger Sayle

ifcvt.c (find_if_case_1): Avoid creating an empty forwarder block...


	* ifcvt.c (find_if_case_1): Avoid creating an empty forwarder block,
	if deleting the then-block allows the test-block to fallthru to the
	else-block.

From-SVN: r92919
parent f8f5c4b3
2005-01-04 Roger Sayle <roger@eyesopen.com>
* ifcvt.c (find_if_case_1): Avoid creating an empty forwarder block,
if deleting the then-block allows the test-block to fallthru to the
else-block.
2005-01-04 Andrew Pinski <pinskia@physics.uc.edu> 2005-01-04 Andrew Pinski <pinskia@physics.uc.edu>
PR c/19152 PR c/19152
......
...@@ -2927,7 +2927,21 @@ find_if_case_1 (basic_block test_bb, edge then_edge, edge else_edge) ...@@ -2927,7 +2927,21 @@ find_if_case_1 (basic_block test_bb, edge then_edge, edge else_edge)
else_bb->global_live_at_start, else_bb->global_live_at_start,
then_bb->global_live_at_end); then_bb->global_live_at_end);
new_bb = redirect_edge_and_branch_force (FALLTHRU_EDGE (test_bb), else_bb);
/* We can avoid creating a new basic block if then_bb is immediately
followed by else_bb, i.e. deleting then_bb allows test_bb to fall
thru to else_bb. */
if (then_bb->next_bb == else_bb
&& then_bb->prev_bb == test_bb)
{
redirect_edge_succ (FALLTHRU_EDGE (test_bb), else_bb);
new_bb = 0;
}
else
new_bb = redirect_edge_and_branch_force (FALLTHRU_EDGE (test_bb),
else_bb);
then_bb_index = then_bb->index; then_bb_index = then_bb->index;
delete_basic_block (then_bb); delete_basic_block (then_bb);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment