aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-tailcall.c
diff options
context:
space:
mode:
authorJan Hubicka <jh@suse.cz>2004-09-15 16:15:36 +0200
committerJan Hubicka <hubicka@gcc.gnu.org>2004-09-15 14:15:36 +0000
commit87527e4bcd88f740b1079d9dc751f3d637d066a9 (patch)
tree9c8803068628a83f91ddacdcb2905f0a538b5feb /gcc/tree-tailcall.c
parentfe7139acb17eb96793ceb975f16f82b9b17d5a27 (diff)
downloadgcc-87527e4bcd88f740b1079d9dc751f3d637d066a9.zip
gcc-87527e4bcd88f740b1079d9dc751f3d637d066a9.tar.gz
gcc-87527e4bcd88f740b1079d9dc751f3d637d066a9.tar.bz2
tree-ssa.c (verify_flow_sensitive_alias_info): Do not walk dead nodes.
* tree-ssa.c (verify_flow_sensitive_alias_info): Do not walk dead nodes. * tree-tailcall.c (eliminate_tail_call): Release SSA name. From-SVN: r87554
Diffstat (limited to 'gcc/tree-tailcall.c')
-rw-r--r--gcc/tree-tailcall.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/tree-tailcall.c b/gcc/tree-tailcall.c
index cfe9dfa..e1c1f67 100644
--- a/gcc/tree-tailcall.c
+++ b/gcc/tree-tailcall.c
@@ -686,12 +686,14 @@ eliminate_tail_call (struct tailcall *t)
bsi_next (&bsi);
while (!bsi_end_p (bsi))
{
+ tree t = bsi_stmt (bsi);
/* Do not remove the return statement, so that redirect_edge_and_branch
sees how the block ends. */
- if (TREE_CODE (bsi_stmt (bsi)) == RETURN_EXPR)
+ if (TREE_CODE (t) == RETURN_EXPR)
break;
bsi_remove (&bsi);
+ release_defs (t);
}
/* Replace the call by a jump to the start of function. */
@@ -775,6 +777,7 @@ eliminate_tail_call (struct tailcall *t)
}
bsi_remove (&t->call_bsi);
+ release_defs (call);
}
/* Optimizes the tailcall described by T. If OPT_TAILCALLS is true, also