From: jakub Date: Thu, 3 Jun 2010 12:07:18 +0000 (+0000) Subject: PR debug/44375 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=56a6836ff548b1df6ed077fd426c479c2e5143c8;p=thirdparty%2Fgcc.git PR debug/44375 * tree-cfg.c (gimple_can_merge_blocks_p): For -O0 return false if merging the bbs would lead to goto_locus location being lost from the IL. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@160219 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8e4aed8a338d..61cf4d76c32d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2010-06-03 Jakub Jelinek + + PR debug/44375 + * tree-cfg.c (gimple_can_merge_blocks_p): For -O0 + return false if merging the bbs would lead to goto_locus + location being lost from the IL. + 2010-06-03 Jan Hubicka Jakub Jelinek diff --git a/gcc/tree-cfg.c b/gcc/tree-cfg.c index 7db5192a2ea8..eca3ed018ce7 100644 --- a/gcc/tree-cfg.c +++ b/gcc/tree-cfg.c @@ -1475,6 +1475,23 @@ gimple_can_merge_blocks_p (basic_block a, basic_block b) && name_mappings_registered_p ()) return false; + /* When not optimizing, don't merge if we'd lose goto_locus. */ + if (!optimize + && single_succ_edge (a)->goto_locus != UNKNOWN_LOCATION) + { + location_t goto_locus = single_succ_edge (a)->goto_locus; + gimple_stmt_iterator prev, next; + prev = gsi_last_nondebug_bb (a); + next = gsi_after_labels (b); + if (!gsi_end_p (next) && is_gimple_debug (gsi_stmt (next))) + gsi_next_nondebug (&next); + if ((gsi_end_p (prev) + || gimple_location (gsi_stmt (prev)) != goto_locus) + && (gsi_end_p (next) + || gimple_location (gsi_stmt (next)) != goto_locus)) + return false; + } + return true; }