summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2016-01-26 17:29:02 +0000
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2016-01-26 17:29:02 +0000
commitc3f86f60ff2d39426712a8fbb067881cb03d199d (patch)
treee6bd983d58381ccf42b88e0d9a4c3958c5abece9
parent2796d5412754f6791f483403b029c88b3f27c839 (diff)
downloadgcc-c3f86f60ff2d39426712a8fbb067881cb03d199d.tar.gz
PR middle-end/60908
* trans-mem.c (tm_region_init): Mark entry block as visited. testsuite/ * gcc.dg/tm/pr60908.c: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@232839 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.dg/tm/pr60908.c15
-rw-r--r--gcc/trans-mem.c7
4 files changed, 28 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index f030101656c..fef8cfe7f99 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2016-01-26 Richard Henderson <rth@redhat.com>
+
+ PR middle-end/60908
+ * trans-mem.c (tm_region_init): Mark entry block as visited.
+
2016-01-26 David Malcolm <dmalcolm@redhat.com>
PR other/69006
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 18aa8af737f..3e40014eeb0 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2016-01-26 Richard Henderson <rth@redhat.com>
+
+ * gcc.dg/tm/pr60908.c: New test.
+
2016-01-26 David Malcolm <dmalcolm@redhat.com>
PR other/69006
diff --git a/gcc/testsuite/gcc.dg/tm/pr60908.c b/gcc/testsuite/gcc.dg/tm/pr60908.c
new file mode 100644
index 00000000000..773438ddbe6
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/tm/pr60908.c
@@ -0,0 +1,15 @@
+/* { dg-do compile } */
+/* { dg-options "-fgnu-tm" } */
+
+int t, v;
+
+int
+foo (void)
+{
+ while (1)
+ {
+ __transaction_atomic { v++; }
+ if (t)
+ return 0;
+ }
+}
diff --git a/gcc/trans-mem.c b/gcc/trans-mem.c
index b2047600dcb..500071f94f1 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 ();