From: Jan Hubicka Date: Thu, 8 Feb 2007 22:04:22 +0000 (+0100) Subject: tree-cfg.c (bsi_replace): Shortcut when replacing the statement with the same one... X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ff39b79b8fe48e0f47c2798b71732250264baaa7;p=platform%2Fupstream%2Fgcc.git tree-cfg.c (bsi_replace): Shortcut when replacing the statement with the same one; always update histograms. * tree-cfg.c (bsi_replace): Shortcut when replacing the statement with the same one; always update histograms. From-SVN: r121724 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 0c7db90..3a51bb5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2007-02-08 Jan Hubicka + + * tree-cfg.c (bsi_replace): Shortcut when replacing the statement with + the same one; always update histograms. + 2007-02-08 Diego Novillo * passes.c (init_optimization_passes): Tidy comment. diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index d979459..e3e2134 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -2840,6 +2840,8 @@ bsi_replace (const block_stmt_iterator *bsi, tree stmt, bool update_eh_info) int eh_region; tree orig_stmt = bsi_stmt (*bsi); + if (stmt == orig_stmt) + return; SET_EXPR_LOCUS (stmt, EXPR_LOCUS (orig_stmt)); set_bb_for_stmt (stmt, bsi->bb); @@ -2852,11 +2854,11 @@ bsi_replace (const block_stmt_iterator *bsi, tree stmt, bool update_eh_info) { remove_stmt_from_eh_region (orig_stmt); add_stmt_to_eh_region (stmt, eh_region); - gimple_duplicate_stmt_histograms (cfun, stmt, cfun, orig_stmt); - gimple_remove_stmt_histograms (cfun, orig_stmt); } } + gimple_duplicate_stmt_histograms (cfun, stmt, cfun, orig_stmt); + gimple_remove_stmt_histograms (cfun, orig_stmt); delink_stmt_imm_use (orig_stmt); *bsi_stmt_ptr (*bsi) = stmt; mark_stmt_modified (stmt);