From: law Date: Fri, 9 Oct 2015 05:09:56 +0000 (+0000) Subject: [PATCH] [5/n] Fix minor SSA_NAME leaks X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c05c1b41d370b14bc94421f138d13e76831253d1;p=thirdparty%2Fgcc.git [PATCH] [5/n] Fix minor SSA_NAME leaks * value-prof.c (gimple_ic): Add missing calls to unlink_stmt_vdef and release_ssa_name in two places. (gimple_stringop_fixed_value): Similarly. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@228632 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8ba160389a59..a1b9d1ba4899 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -5,6 +5,10 @@ 2015-10-08 Jeff Law + * value-prof.c (gimple_ic): Add missing calls to unlink_stmt_vdef + and release_ssa_name in two places. + (gimple_stringop_fixed_value): Similarly. + * tree-ssa-loop-im.c (rewrite_bittest): Add missing call to release_defs. diff --git a/gcc/value-prof.c b/gcc/value-prof.c index 90211ef37955..ddf121596972 100644 --- a/gcc/value-prof.c +++ b/gcc/value-prof.c @@ -1384,6 +1384,11 @@ gimple_ic (gcall *icall_stmt, struct cgraph_node *direct_call, cond_stmt = gimple_build_cond (EQ_EXPR, tmp1, tmp0, NULL_TREE, NULL_TREE); gsi_insert_before (&gsi, cond_stmt, GSI_SAME_STMT); + if (TREE_CODE (gimple_vdef (icall_stmt)) == SSA_NAME) + { + unlink_stmt_vdef (icall_stmt); + release_ssa_name (gimple_vdef (icall_stmt)); + } gimple_set_vdef (icall_stmt, NULL_TREE); gimple_set_vuse (icall_stmt, NULL_TREE); update_stmt (icall_stmt); @@ -1472,6 +1477,11 @@ gimple_ic (gcall *icall_stmt, struct cgraph_node *direct_call, { gimple *copy; + if (TREE_CODE (gimple_vdef (iretbnd_stmt)) == SSA_NAME) + { + unlink_stmt_vdef (iretbnd_stmt); + release_ssa_name (gimple_vdef (iretbnd_stmt)); + } gimple_set_vdef (iretbnd_stmt, NULL_TREE); gimple_set_vuse (iretbnd_stmt, NULL_TREE); update_stmt (iretbnd_stmt); @@ -1698,6 +1708,11 @@ gimple_stringop_fixed_value (gcall *vcall_stmt, tree icall_size, int prob, cond_stmt = gimple_build_cond (EQ_EXPR, tmp1, tmp0, NULL_TREE, NULL_TREE); gsi_insert_before (&gsi, cond_stmt, GSI_SAME_STMT); + if (TREE_CODE (gimple_vdef (vcall_stmt)) == SSA_NAME) + { + unlink_stmt_vdef (vcall_stmt); + release_ssa_name (gimple_vdef (vcall_stmt)); + } gimple_set_vdef (vcall_stmt, NULL); gimple_set_vuse (vcall_stmt, NULL); update_stmt (vcall_stmt);