mirror of
https://github.com/autc04/Retro68.git
synced 2024-12-11 03:52:59 +00:00
54 lines
1.4 KiB
C
54 lines
1.4 KiB
C
/* { dg-do run } */
|
|
|
|
#ifndef NONMONOTONIC_TYPE
|
|
#include <omp.h>
|
|
#include <stdlib.h>
|
|
#define NONMONOTONIC_TYPE int
|
|
#define NONMONOTONIC_END(n) n
|
|
#endif
|
|
|
|
int a[73];
|
|
|
|
int
|
|
main ()
|
|
{
|
|
NONMONOTONIC_TYPE i;
|
|
#pragma omp parallel for schedule(nonmonotonic: dynamic)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp parallel for schedule(nonmonotonic: dynamic, 5)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp parallel for schedule(nonmonotonic: guided)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp parallel for schedule(nonmonotonic: guided, 7)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp parallel
|
|
{
|
|
int cnt = omp_get_num_threads ();
|
|
int thr = omp_get_thread_num ();
|
|
if (thr < 73)
|
|
a[thr]++;
|
|
#pragma omp barrier
|
|
#pragma omp for schedule(nonmonotonic: dynamic)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp for schedule(nonmonotonic: dynamic, 7)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp for schedule(nonmonotonic: guided)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp for schedule(nonmonotonic: guided, 5)
|
|
for (i = 0; i < NONMONOTONIC_END (73); i++)
|
|
a[i]++;
|
|
#pragma omp single private (i)
|
|
for (i = 0; i < 73; i++)
|
|
if (a[i] != 8 + (i < cnt))
|
|
abort ();
|
|
}
|
|
return 0;
|
|
}
|