blob: 371ddf5639ddefd6dfa34ea6d2f271c99e373c04 (
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
44
45
46
47
48
|
#include <stdlib.h>
#include <unistd.h>
int
main ()
{
int a[48], b = 1;
#pragma omp parallel num_threads (4)
{
#pragma omp barrier
#pragma omp single
{
int i;
for (i = 0; i < 48; ++i)
#pragma omp task depend(in: a) shared(a)
a[i] = i;
for (i = 0; i < 32; ++i)
{
#pragma omp taskwait depend(inout: a) nowait
}
#pragma omp taskwait
for (i = 0; i < 48; ++i)
if (a[i] != i)
abort ();
for (i = 0; i < 48; ++i)
#pragma omp task depend(in: a) shared(a)
a[i] = 2 * i + 1;
#pragma omp taskgroup
{
#pragma omp taskwait depend(inoutset: a) nowait
#pragma omp taskgroup
{
#pragma omp taskwait depend(inoutset: a) nowait
}
}
for (i = 0; i < 48; ++i)
if (a[i] != 2 * i + 1)
abort ();
#pragma omp task depend(in: a) shared(a)
usleep (5000);
#pragma omp taskgroup
{
#pragma omp taskwait depend(inout: a) nowait
}
}
}
return 0;
}
|