Wolfgang Thaller 6fbf4226da gcc-9.1
2019-06-20 20:10:10 +02:00

66 lines
1.1 KiB
C

typedef __SIZE_TYPE__ size_t;
extern
#ifdef __cplusplus
"C"
#endif
void abort (void);
int *q;
void
bar (int *p, int *r, int *t, int s, size_t u)
{
#pragma omp task in_reduction (*: p[0], q[0], r[s - 1], t[0:u + 1])
{
*p *= 4;
*q *= 5;
r[s - 1] *= 6;
t[0] *= 8;
t[1] *= 9;
}
}
void
foo (int *p, int *r, int *t, int s, size_t u)
{
int *p2 = p;
#pragma omp taskgroup task_reduction (*: p[0], q[0], r[s], t[0:u + 1])
{
p = (int *) 0;
s++;
bar (p2, r, t, s, u);
r++;
#pragma omp taskwait
#pragma omp task in_reduction (*: p2[0], q[0], r[s - 2], t[0:u + 1])
{
*p2 *= 2;
*q *= 3;
r[s - 2] *= 7;
t[0] *= 10;
t[1] *= 11;
}
u = (~(size_t) 0) / 4;
s++;
p2 = (int *) 0;
q = (int *) 0;
r = (int *) 0;
t = (int *) 0;
}
}
int
main ()
{
int a = 1, b = 1, c[2] = { 1, 0 }, d[3] = { 1, 1, -1 };
volatile int zero;
zero = 0;
q = &b;
#pragma omp parallel num_threads (2)
#pragma omp master
foo (&a, &c[0], &d[0], zero, zero + 1);
if (a != 8 || b != 15 || c[0] != 42 || c[1] != 0
|| d[0] != 80 || d[1] != 99 || d[2] != -1)
abort ();
return 0;
}