annotate gcc/testsuite/c-c++-common/simulate-thread/bitfields-4.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do link } */
kono
parents:
diff changeset
2 /* { dg-options "--param allow-store-data-races=0" } */
kono
parents:
diff changeset
3 /* { dg-final { simulate-thread } } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 #include <stdio.h>
kono
parents:
diff changeset
6 #include <stdlib.h>
kono
parents:
diff changeset
7 #include "../../gcc.dg/simulate-thread/simulate-thread.h"
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 struct bits
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 char a;
kono
parents:
diff changeset
12 int b:7;
kono
parents:
diff changeset
13 int c:9;
kono
parents:
diff changeset
14 unsigned char d;
kono
parents:
diff changeset
15 } *p;
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 static int global = 0;
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 void simulate_thread_other_threads()
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 global++;
kono
parents:
diff changeset
22 p->d = global % 256;
kono
parents:
diff changeset
23 }
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 int simulate_thread_step_verify()
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 if (p->d != global % 256)
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 printf("FAIL: invalid intermediate result\n");
kono
parents:
diff changeset
30 return 1;
kono
parents:
diff changeset
31 }
kono
parents:
diff changeset
32 return 0;
kono
parents:
diff changeset
33 }
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 int simulate_thread_final_verify()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 if (p->c != 55)
kono
parents:
diff changeset
38 {
kono
parents:
diff changeset
39 printf("FAIL: invalid final result\n");
kono
parents:
diff changeset
40 return 1;
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 return 0;
kono
parents:
diff changeset
43 }
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 /* Store into <c> should not clobber <d>. */
kono
parents:
diff changeset
46 /* We should not use a 32-bit move to store into p->, but a smaller move. */
kono
parents:
diff changeset
47 __attribute__((noinline))
kono
parents:
diff changeset
48 void simulate_thread_main()
kono
parents:
diff changeset
49 {
kono
parents:
diff changeset
50 p -> c = 55;
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 int main()
kono
parents:
diff changeset
55 {
kono
parents:
diff changeset
56 p = (struct bits *) calloc (1, sizeof (struct bits));
kono
parents:
diff changeset
57 simulate_thread_main();
kono
parents:
diff changeset
58 simulate_thread_done();
kono
parents:
diff changeset
59 return 0;
kono
parents:
diff changeset
60 }