aboutsummaryrefslogtreecommitdiff
path: root/gcc/trans-mem.c
diff options
context:
space:
mode:
authorRichard Henderson <rth@redhat.com>2016-01-26 09:29:02 -0800
committerRichard Henderson <rth@gcc.gnu.org>2016-01-26 09:29:02 -0800
commitffc445f48618c0bdd51146e9a59cdc5c293f24ec (patch)
treee6bd983d58381ccf42b88e0d9a4c3958c5abece9 /gcc/trans-mem.c
parentdcbc08799695068b5beee1e5b89daacac23cfc0d (diff)
downloadgcc-ffc445f48618c0bdd51146e9a59cdc5c293f24ec.zip
gcc-ffc445f48618c0bdd51146e9a59cdc5c293f24ec.tar.gz
gcc-ffc445f48618c0bdd51146e9a59cdc5c293f24ec.tar.bz2
re PR middle-end/60908 (compiler bug related to trans-mem.c)
PR middle-end/60908 * trans-mem.c (tm_region_init): Mark entry block as visited. testsuite/ * gcc.dg/tm/pr60908.c: New test. From-SVN: r232839
Diffstat (limited to 'gcc/trans-mem.c')
-rw-r--r--gcc/trans-mem.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/gcc/trans-mem.c b/gcc/trans-mem.c
index b204760..500071f 100644
--- a/gcc/trans-mem.c
+++ b/gcc/trans-mem.c
@@ -2039,16 +2039,17 @@ tm_region_init (struct tm_region *region)
struct tm_region *old_region;
auto_vec<tm_region *> bb_regions;
- all_tm_regions = region;
- bb = single_succ (ENTRY_BLOCK_PTR_FOR_FN (cfun));
-
/* We could store this information in bb->aux, but we may get called
through get_all_tm_blocks() from another pass that may be already
using bb->aux. */
bb_regions.safe_grow_cleared (last_basic_block_for_fn (cfun));
+ all_tm_regions = region;
+ bb = single_succ (ENTRY_BLOCK_PTR_FOR_FN (cfun));
queue.safe_push (bb);
+ bitmap_set_bit (visited_blocks, bb->index);
bb_regions[bb->index] = region;
+
do
{
bb = queue.pop ();