blob: c230240de57bcf3d7a8e77ea89fed63f20e668da (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
/* { dg-do compile } */
/* { dg-options "-fgnu-tm -O3 -fdump-tree-tmmark" } */
/* Like memopt-12.c but the phi is inside a look which causes
it to be converted into a COND_EXPR. */
extern int test(void) __attribute__((transaction_safe));
extern void *malloc (__SIZE_TYPE__) __attribute__((malloc,transaction_safe));
struct large { int foo[500]; };
int f(int j)
{
int *p1, *p2, *p3;
p1 = malloc (sizeof (*p1)*5000);
__transaction_atomic {
_Bool t;
int i = 1;
*p1 = 0;
p2 = malloc (sizeof (*p2)*6000);
*p2 = 1;
t = test();
for (i = 0;i < j;i++)
{
/* p3 = PHI (p1, p2) */
if (t)
p3 = p1;
else
p3 = p2;
/* Since both p1 and p2 are thread-private, we can inherit the
logging already done. No ITM_W* instrumentation necessary. */
*p3 = 555;
}
}
return p3[something()];
}
/* { dg-final { scan-tree-dump-times "ITM_WU" 0 "tmmark" } } */
/* { dg-final { cleanup-tree-dump "tmmark" } } */
|