annotate gcc/testsuite/gcc.dg/tm/opt-1.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
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 -O" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 extern void usleep (int) __attribute__((transaction_pure));
kono
parents:
diff changeset
5 extern int rand(void) __attribute__((pure, transaction_pure));
kono
parents:
diff changeset
6 extern int printf (const char *, ...);
kono
parents:
diff changeset
7 extern void *malloc (__SIZE_TYPE__) __attribute__((malloc));
kono
parents:
diff changeset
8 extern void xyzzy (void * (*)(void *));
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 typedef struct
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 int id;
kono
parents:
diff changeset
13 } parm;
kono
parents:
diff changeset
14
kono
parents:
diff changeset
15 int gvar;
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 void *hello(void *arg)
kono
parents:
diff changeset
18 {
kono
parents:
diff changeset
19 parm *p=(parm *)arg;
kono
parents:
diff changeset
20 int tmp = p->id;
kono
parents:
diff changeset
21 int tmp3;
kono
parents:
diff changeset
22 printf ("Thread reads %d.\n", tmp);
kono
parents:
diff changeset
23 __transaction_atomic
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 int tmp2 = gvar;
kono
parents:
diff changeset
26 usleep ((int) (10.0*rand()/(10+1.0))/100);
kono
parents:
diff changeset
27 gvar = tmp + tmp2;
kono
parents:
diff changeset
28 tmp3 = gvar;
kono
parents:
diff changeset
29 }
kono
parents:
diff changeset
30 printf("tmp3 = %d\n", tmp3);
kono
parents:
diff changeset
31 return 0;
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 int
kono
parents:
diff changeset
35 main()
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 int i, n = rand();
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 for (i=0; i<n; i++)
kono
parents:
diff changeset
40 xyzzy (hello);
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 return 0;
kono
parents:
diff changeset
43 }