aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c
diff options
context:
space:
mode:
authorAldy Hernandez <aldyh@redhat.com>2012-09-07 16:00:07 +0000
committerAldy Hernandez <aldyh@gcc.gnu.org>2012-09-07 16:00:07 +0000
commitc294eb47b25bcf24bacfbcdecedda5651124f54c (patch)
tree3085fbec07c3acbff698efa8be5b579522208fbb /gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c
parentb12b5029cbf1a802565598511dd073f1afbe2840 (diff)
downloadgcc-c294eb47b25bcf24bacfbcdecedda5651124f54c.zip
gcc-c294eb47b25bcf24bacfbcdecedda5651124f54c.tar.gz
gcc-c294eb47b25bcf24bacfbcdecedda5651124f54c.tar.bz2
re PR testsuite/54184 (gcc.dg/pr52558-1.c failure)
PR testsuite/54184 * gcc.dg/pr52558-1.c: Delete. * gcc.dg/simulate-thread/speculative-store-2.c: New. From-SVN: r191079
Diffstat (limited to 'gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c')
-rw-r--r--gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c b/gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c
new file mode 100644
index 0000000..d4d28f5
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/simulate-thread/speculative-store-2.c
@@ -0,0 +1,74 @@
+/* { dg-do link } */
+/* { dg-options "--param allow-store-data-races=0 -O2" } */
+/* { dg-final { simulate-thread } } */
+
+#include <stdio.h>
+#include <stdlib.h>
+
+#include "simulate-thread.h"
+
+/* Test that speculative stores do not happen for --param
+ allow-store-data-races=0. */
+
+int count, insns;
+
+struct obj {
+ int data;
+ struct obj *next;
+} *q;
+
+void simulate_thread_other_threads ()
+{
+ ++insns;
+ ++count;
+}
+
+int simulate_thread_step_verify ()
+{
+ return 0;
+}
+
+int simulate_thread_final_verify ()
+{
+ /* If count != insns, someone must have cached `count' and stored a
+ racy value into it. */
+ if (count != insns)
+ {
+ printf("FAIL: count was incorrectly cached\n");
+ return 1;
+ }
+ return 0;
+}
+
+/* Test that `count' is not written to unless p->data > 0. */
+
+__attribute__((noinline))
+void simulate_thread_main()
+{
+ struct obj *p;
+ for (p = q; p; p = p->next)
+ if (p->data > 0)
+ count++;
+}
+
+struct obj *
+insert(struct obj *head, int data)
+{
+ struct obj *t = (struct obj *) malloc (sizeof (struct obj));
+ t->next = head;
+ t->data = data;
+ return t;
+}
+
+int main()
+{
+ q = insert (0, 0);
+ q = insert (q, 0);
+ q = insert (q, 0);
+ q = insert (q, 0);
+ q = insert (q, 0);
+
+ simulate_thread_main ();
+ simulate_thread_done ();
+ return 0;
+}