summaryrefslogtreecommitdiff
path: root/gcc/cfghooks.c
diff options
context:
space:
mode:
authorebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2011-04-11 21:54:59 +0000
committerebotcazou <ebotcazou@138bc75d-0d04-0410-961f-82ee72b054a4>2011-04-11 21:54:59 +0000
commit895fb8da30779c9c467bc8b60b762f98fbdceb1a (patch)
tree9f9cb58db1a8bade729a25b50f4547753e25bf92 /gcc/cfghooks.c
parentba2558f803a3fab9216552431ff4e00e50f2a0de (diff)
downloadgcc-895fb8da30779c9c467bc8b60b762f98fbdceb1a.tar.gz
* cfghooks.c (redirect_edge_and_branch_force): Localize variable.
(force_nonfallthru): Do not alter the loop nest if no basic block was created. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@172281 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/cfghooks.c')
-rw-r--r--gcc/cfghooks.c31
1 files changed, 14 insertions, 17 deletions
diff --git a/gcc/cfghooks.c b/gcc/cfghooks.c
index 34685f4444a..c4c51cc4404 100644
--- a/gcc/cfghooks.c
+++ b/gcc/cfghooks.c
@@ -388,7 +388,6 @@ basic_block
redirect_edge_and_branch_force (edge e, basic_block dest)
{
basic_block ret, src = e->src;
- struct loop *loop;
if (!cfg_hooks->redirect_edge_and_branch_force)
internal_error ("%s does not support redirect_edge_and_branch_force",
@@ -398,6 +397,7 @@ redirect_edge_and_branch_force (edge e, basic_block dest)
rescan_loop_exit (e, false, true);
ret = cfg_hooks->redirect_edge_and_branch_force (e, dest);
+
if (ret != NULL && dom_info_available_p (CDI_DOMINATORS))
set_immediate_dominator (CDI_DOMINATORS, ret, src);
@@ -405,8 +405,9 @@ redirect_edge_and_branch_force (edge e, basic_block dest)
{
if (ret != NULL)
{
- loop = find_common_loop (single_pred (ret)->loop_father,
- single_succ (ret)->loop_father);
+ struct loop *loop
+ = find_common_loop (single_pred (ret)->loop_father,
+ single_succ (ret)->loop_father);
add_bb_to_loop (ret, loop);
}
else if (find_edge (src, dest) == e)
@@ -882,30 +883,26 @@ tidy_fallthru_edges (void)
basic_block
force_nonfallthru (edge e)
{
- basic_block ret, src = e->src, dest = e->dest;
- struct loop *loop;
+ basic_block ret, src = e->src;
if (!cfg_hooks->force_nonfallthru)
internal_error ("%s does not support force_nonfallthru",
cfg_hooks->name);
- if (current_loops != NULL)
- rescan_loop_exit (e, false, true);
-
ret = cfg_hooks->force_nonfallthru (e);
- if (ret != NULL && dom_info_available_p (CDI_DOMINATORS))
- set_immediate_dominator (CDI_DOMINATORS, ret, src);
-
- if (current_loops != NULL)
+ if (ret != NULL)
{
- if (ret != NULL)
+ if (dom_info_available_p (CDI_DOMINATORS))
+ set_immediate_dominator (CDI_DOMINATORS, ret, src);
+
+ if (current_loops != NULL)
{
- loop = find_common_loop (single_pred (ret)->loop_father,
- single_succ (ret)->loop_father);
+ struct loop *loop
+ = find_common_loop (single_pred (ret)->loop_father,
+ single_succ (ret)->loop_father);
+ rescan_loop_exit (e, false, true);
add_bb_to_loop (ret, loop);
}
- else if (find_edge (src, dest) == e)
- rescan_loop_exit (e, true, false);
}
return ret;