aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorAndrew MacLeod <amacleod@redhat.com>2015-01-14 13:58:35 +0000
committerAndrew Macleod <amacleod@gcc.gnu.org>2015-01-14 13:58:35 +0000
commit8673b6713e9457187cc9ecbefe949fb2393cb057 (patch)
tree80e4f051bc5ec02d383c65782ba5694b86b0f3aa /gcc
parent4b54ab976e5b0fd88580927adc6b8d5f2bd89044 (diff)
downloadgcc-8673b6713e9457187cc9ecbefe949fb2393cb057.zip
gcc-8673b6713e9457187cc9ecbefe949fb2393cb057.tar.gz
gcc-8673b6713e9457187cc9ecbefe949fb2393cb057.tar.bz2
re PR middle-end/59448 (Code generation doesn't respect C11 address-dependency)
2015-01-14 Andrew MacLeod <amacleod@redhat.com> PR middle-end/59448 * builtins.c (get_memmodel): Promote consume to acquire always. * testsuite/gcc.dg/atomic-invalid.c: Remove obselete test for illegal consume in an atomic_exchange. From-SVN: r219601
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/builtins.c5
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gcc.dg/atomic-invalid.c2
4 files changed, 16 insertions, 2 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 43d6a1a..a8dc1d3 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2015-01-14 Andrew MacLeod <amacleod@redhat.com>
+
+ PR middle-end/59448
+ * builtins.c (get_memmodel): Promote consume to acquire always.
+
2014-01-14 Ilya Tocar <ilya.tocar@intel.com>
PR target/64386
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 9280704..c8b1940 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -5365,6 +5365,11 @@ get_memmodel (tree exp)
return MEMMODEL_SEQ_CST;
}
+ /* Workaround for Bugzilla 59448. GCC doesn't track consume properly, so
+ be conservative and promote consume to acquire. */
+ if (val == MEMMODEL_CONSUME)
+ val = MEMMODEL_ACQUIRE;
+
return (enum memmodel) val;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index d39b2d7..3df2a2c 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+2015-01-14 Andrew MacLeod <amacleod@redhat.com>
+
+ PR middle-end/59448
+ * gcc.dg/atomic-invalid.c: Remove obselete test for illegal consume in
+ an atomic_exchange.
+
2014-01-14 Ilya Tocar <ilya.tocar@intel.com>
PR target/64386
diff --git a/gcc/testsuite/gcc.dg/atomic-invalid.c b/gcc/testsuite/gcc.dg/atomic-invalid.c
index 4d040e1..6404ae8 100644
--- a/gcc/testsuite/gcc.dg/atomic-invalid.c
+++ b/gcc/testsuite/gcc.dg/atomic-invalid.c
@@ -17,8 +17,6 @@ main ()
__atomic_compare_exchange_n (&i, &e, 1, 0, __ATOMIC_SEQ_CST, __ATOMIC_RELEASE); /* { dg-error "invalid failure memory" } */
__atomic_compare_exchange_n (&i, &e, 1, 1, __ATOMIC_SEQ_CST, __ATOMIC_ACQ_REL); /* { dg-error "invalid failure memory" } */
- __atomic_exchange_n (&i, 1, __ATOMIC_CONSUME); /* { dg-error "invalid memory model" } */
-
__atomic_load_n (&i, __ATOMIC_RELEASE); /* { dg-error "invalid memory model" } */
__atomic_load_n (&i, __ATOMIC_ACQ_REL); /* { dg-error "invalid memory model" } */