diff options
author | Jan Hubicka <jh@suse.cz> | 2004-09-15 16:15:36 +0200 |
---|---|---|
committer | Jan Hubicka <hubicka@gcc.gnu.org> | 2004-09-15 14:15:36 +0000 |
commit | 87527e4bcd88f740b1079d9dc751f3d637d066a9 (patch) | |
tree | 9c8803068628a83f91ddacdcb2905f0a538b5feb /gcc/tree-tailcall.c | |
parent | fe7139acb17eb96793ceb975f16f82b9b17d5a27 (diff) | |
download | gcc-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.c | 5 |
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 |