annotate gcc/testsuite/c-c++-common/tm/20111206.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do compile } */
kono
parents:
diff changeset
2 /* { dg-options "-fgnu-tm -O2" } */
kono
parents:
diff changeset
3 /* This test case triggered block sharing between the two transactions. */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 void func1 (void) __attribute__ ((transaction_callable, used));
kono
parents:
diff changeset
6 long func2 (void) __attribute__ ((transaction_callable, used));
kono
parents:
diff changeset
7 unsigned long rand (void);
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 void client_run (void)
kono
parents:
diff changeset
10 {
kono
parents:
diff changeset
11 long types[100];
kono
parents:
diff changeset
12 long i;
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 for (i = 0; i < 100; i++)
kono
parents:
diff changeset
15 {
kono
parents:
diff changeset
16 long action = rand ();
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 switch (action)
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 case 0:
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 __transaction_relaxed
kono
parents:
diff changeset
23 {
kono
parents:
diff changeset
24 long bill = func2 ();
kono
parents:
diff changeset
25 if (bill >= 0)
kono
parents:
diff changeset
26 {
kono
parents:
diff changeset
27 func1 ();
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30 break;
kono
parents:
diff changeset
31 }
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 case 1:
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 long n;
kono
parents:
diff changeset
36 __transaction_relaxed
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 for (n = 0; n < 100; n++)
kono
parents:
diff changeset
39 {
kono
parents:
diff changeset
40 long t = types[n];
kono
parents:
diff changeset
41 switch (t)
kono
parents:
diff changeset
42 {
kono
parents:
diff changeset
43 case 0:
kono
parents:
diff changeset
44 func1 ();
kono
parents:
diff changeset
45 break;
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47 }
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49 break;
kono
parents:
diff changeset
50 }
kono
parents:
diff changeset
51 }
kono
parents:
diff changeset
52 }
kono
parents:
diff changeset
53 }