gcc/libgomp/testsuite/libgomp.c-c++-common/monotonic-1.c
Tom de Vries 92243e7cea [libgomp, testsuite] Move tests to libgomp.c-c++-common
2018-05-02  Tom de Vries  <tom@codesourcery.com>

	PR testsuite/83791
	* testsuite/libgomp.c++/udr-9.C: Update.
	* testsuite/libgomp.c++/atomic-16.C: Remove.
	* testsuite/libgomp.c++/cancel-taskgroup-2.C: Remove.
	* testsuite/libgomp.c++/loop-13.C: Remove.
	* testsuite/libgomp.c++/loop-14.C: Remove.
	* testsuite/libgomp.c++/loop-15.C: Remove.
	* testsuite/libgomp.c++/monotonic-1.C: Remove.
	* testsuite/libgomp.c++/monotonic-2.C: Remove.
	* testsuite/libgomp.c++/nonmonotonic-1.C: Remove.
	* testsuite/libgomp.c++/nonmonotonic-2.C: Remove.
	* testsuite/libgomp.c++/ordered-1.C: Remove.
	* testsuite/libgomp.c++/pr45784.C: Remove.
	* testsuite/libgomp.c++/pr64824.C: Remove.
	* testsuite/libgomp.c++/pr64868.C: Remove.
	* testsuite/libgomp.c++/pr66199-1.C: Remove.
	* testsuite/libgomp.c++/pr66199-2.C: Remove.
	* testsuite/libgomp.c++/pr66199-3.C: Remove.
	* testsuite/libgomp.c++/pr66199-4.C: Remove.
	* testsuite/libgomp.c++/pr66199-5.C: Remove.
	* testsuite/libgomp.c++/pr66199-6.C: Remove.
	* testsuite/libgomp.c++/pr66199-7.C: Remove.
	* testsuite/libgomp.c++/pr66199-8.C: Remove.
	* testsuite/libgomp.c++/pr66199-9.C: Remove.
	* testsuite/libgomp.c++/pr69389.C: Remove.
	* testsuite/libgomp.c++/simd10.C: Remove.
	* testsuite/libgomp.c++/simd11.C: Remove.
	* testsuite/libgomp.c++/simd12.C: Remove.
	* testsuite/libgomp.c++/simd13.C: Remove.
	* testsuite/libgomp.c++/target-1.C: Remove.
	* testsuite/libgomp.c++/target-3.C: Remove.
	* testsuite/libgomp.c++/target-4.C: Remove.
	* testsuite/libgomp.c++/target-5.C: Remove.
	* testsuite/libgomp.c++/taskgroup-1.C: Remove.
	* testsuite/libgomp.c++/taskloop-1.C: Remove.
	* testsuite/libgomp.c++/taskloop-2.C: Remove.
	* testsuite/libgomp.c++/taskloop-3.C: Remove.
	* testsuite/libgomp.c++/taskloop-4.C: Remove.
	* testsuite/libgomp.c++/udr-9.C: Remove.
	* testsuite/libgomp.c++/for-10.C: Remove.
	* testsuite/libgomp.c++/for-11.C: Remove.
	* testsuite/libgomp.c++/for-12.C: Remove.
	* testsuite/libgomp.c++/for-13.C: Remove.
	* testsuite/libgomp.c++/for-14.C: Remove.
	* testsuite/libgomp.c++/for-9.C: Remove.
	* testsuite/libgomp.c/atomic-18.c: Move ...
	* testsuite/libgomp.c-c++-common/atomic-18.c: ... here.
	* testsuite/libgomp.c/cancel-taskgroup-2.c: Move ...
	* testsuite/libgomp.c-c++-common/cancel-taskgroup-2.c: here.
	* testsuite/libgomp.c/loop-13.c: Move ...
	* testsuite/libgomp.c-c++-common/loop-13.c: ... here.
	* testsuite/libgomp.c/loop-14.c: Move ...
	* testsuite/libgomp.c-c++-common/loop-14.c: ... here.
	* testsuite/libgomp.c/loop-15.c: Remove.
	* testsuite/libgomp.c-c++-common/loop-15.c: New test.
	* testsuite/libgomp.c/monotonic-1.c: Move ...
	* testsuite/libgomp.c-c++-common/monotonic-1.c: ... here.
	* testsuite/libgomp.c/monotonic-2.c: Move ...
	* testsuite/libgomp.c-c++-common/monotonic-2.c: ... here.
	* testsuite/libgomp.c/nonmonotonic-1.c: Move ...
	* testsuite/libgomp.c-c++-common/nonmonotonic-1.c: ... here.
	* testsuite/libgomp.c/nonmonotonic-2.c: Move ...
	* testsuite/libgomp.c-c++-common/nonmonotonic-2.c: ... here.
	* testsuite/libgomp.c/ordered-4.c: Move ...
	* testsuite/libgomp.c-c++-common/ordered-4.c: ... here.
	* testsuite/libgomp.c/pr45784.c: Move ...
	* testsuite/libgomp.c-c++-common/pr45784.c: ... here.
	* testsuite/libgomp.c/pr64824.c: Move ...
	* testsuite/libgomp.c-c++-common/pr64824.c: ... here.
	* testsuite/libgomp.c/pr64868.c: Move ...
	* testsuite/libgomp.c-c++-common/pr64868.c: ... here.
	* testsuite/libgomp.c/pr66199-1.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-1.c: ... here.
	* testsuite/libgomp.c/pr66199-2.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-2.c: ... here.
	* testsuite/libgomp.c/pr66199-3.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-3.c: ... here.
	* testsuite/libgomp.c/pr66199-4.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-4.c: ... here.
	* testsuite/libgomp.c/pr66199-5.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-5.c: ... here.
	* testsuite/libgomp.c/pr66199-6.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-6.c: ... here.
	* testsuite/libgomp.c/pr66199-7.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-7.c: ... here.
	* testsuite/libgomp.c/pr66199-8.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-8.c: ... here.
	* testsuite/libgomp.c/pr66199-9.c: Move ...
	* testsuite/libgomp.c-c++-common/pr66199-9.c: ... here.
	* testsuite/libgomp.c/pr69389.c: Move ...
	* testsuite/libgomp.c-c++-common/pr69389.c: ... here.
	* testsuite/libgomp.c/simd-14.c: Move ...
	* testsuite/libgomp.c-c++-common/simd-14.c: ... here.
	* testsuite/libgomp.c/simd-15.c: Move ...
	* testsuite/libgomp.c-c++-common/simd-15.c: ... here.
	* testsuite/libgomp.c/simd-16.c: Move ...
	* testsuite/libgomp.c-c++-common/simd-16.c: ... here.
	* testsuite/libgomp.c/simd-17.c: Move ...
	* testsuite/libgomp.c-c++-common/simd-17.c: ... here.
	* testsuite/libgomp.c/target-1.c: Move ...
	* testsuite/libgomp.c-c++-common/target-1.c: ... here.
	* testsuite/libgomp.c/target-10.c: Move ...
	* testsuite/libgomp.c-c++-common/target-10.c: ... here.
	* testsuite/libgomp.c/target-13.c: Move ...
	* testsuite/libgomp.c-c++-common/target-13.c: ... here.
	* testsuite/libgomp.c/target-2.c: Move ...
	* testsuite/libgomp.c-c++-common/target-2.c: ... here.
	* testsuite/libgomp.c/taskgroup-1.c: Move ...
	* testsuite/libgomp.c-c++-common/taskgroup-1.c: ... here.
	* testsuite/libgomp.c/taskloop-1.c: Move ...
	* testsuite/libgomp.c-c++-common/taskloop-1.c: ... here.
	* testsuite/libgomp.c/taskloop-2.c: Move ...
	* testsuite/libgomp.c-c++-common/taskloop-2.c: ... here.
	* testsuite/libgomp.c/taskloop-3.c: Move ...
	* testsuite/libgomp.c-c++-common/taskloop-3.c: ... here.
	* testsuite/libgomp.c/taskloop-4.c: Move ...
	* testsuite/libgomp.c-c++-common/taskloop-4.c: ... here.
	* testsuite/libgomp.c/udr-1.c: Move ...
	* testsuite/libgomp.c-c++-common/udr-1.c: ... here.
	* testsuite/libgomp.c/for-1.c: Move ...
	* testsuite/libgomp.c-c++-common/for-1.c: ... here.
	* testsuite/libgomp.c/for-1.h: Move ...
	* testsuite/libgomp.c-c++-common/for-1.h: ... here.
	* testsuite/libgomp.c/for-2.c: Move ...
	* testsuite/libgomp.c-c++-common/for-2.c: ... here.
	* testsuite/libgomp.c/for-2.h: Move ...
	* testsuite/libgomp.c-c++-common/for-2.h: ... here.
	* testsuite/libgomp.c/for-3.c: Move ...
	* testsuite/libgomp.c-c++-common/for-3.c: ... here.
	* testsuite/libgomp.c/for-4.c: Move ...
	* testsuite/libgomp.c-c++-common/for-4.c: ... here.
	* testsuite/libgomp.c/for-5.c: Move ...
	* testsuite/libgomp.c-c++-common/for-5.c: ... here.
	* testsuite/libgomp.c/for-6.c: Move ...
	* testsuite/libgomp.c-c++-common/for-6.c: ... here.

From-SVN: r259851
2018-05-02 17:53:43 +00:00

304 lines
4.9 KiB
C

/* { dg-do run } */
#ifndef MONOTONIC_TYPE
#include <omp.h>
#include <stdlib.h>
#define MONOTONIC_TYPE int
#define MONOTONIC_UNDEF -1
#define MONOTONIC_END(n) n
#endif
int
main ()
{
MONOTONIC_TYPE i;
#pragma omp parallel
{
int cnt = omp_get_num_threads ();
int thr = omp_get_thread_num ();
MONOTONIC_TYPE l = MONOTONIC_UNDEF;
int c = 0;
int n = 0;
#pragma omp for nowait schedule(static, 5)
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if (cnt == 1)
abort ();
if (n != 5)
abort ();
n = 1;
c++;
}
if (n == 1)
{
if ((i % 5) != 0)
abort ();
if ((i / 5) % cnt != thr)
abort ();
}
l = i;
}
if (cnt == 1)
{
if (n != 73 || l != 73 - 1 || c != 1)
abort ();
}
else if (thr > 73 / 5)
{
if (l != MONOTONIC_UNDEF || c != 0 || n != 0)
abort ();
}
else if (thr == 73 / 5)
{
if (l != 73 - 1 || c != 1 || n != 73 % 5)
abort ();
}
else if (c == 0)
abort ();
else if (l == 73 - 1)
{
if (thr != (73 / 5) % cnt || n != 73 % 5)
abort ();
}
else if ((n % 5) != 0)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for schedule( monotonic: static, 7) nowait
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if (cnt == 1)
abort ();
if (n != 7)
abort ();
n = 1;
c++;
}
if (n == 1)
{
if ((i % 7) != 0)
abort ();
if ((i / 7) % cnt != thr)
abort ();
}
l = i;
}
if (cnt == 1)
{
if (n != 73 || l != 73 - 1 || c != 1)
abort ();
}
else if (thr > 73 / 7)
{
if (l != MONOTONIC_UNDEF || c != 0 || n != 0)
abort ();
}
else if (thr == 73 / 7)
{
if (l != 73 - 1 || c != 1 || n != 73 % 7)
abort ();
}
else if (c == 0)
abort ();
else if (l == 73 - 1)
{
if (thr != (73 / 7) % cnt || n != 73 % 7)
abort ();
}
else if ((n % 7) != 0)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for nowait schedule(static)
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
abort ();
l = i;
}
if (c > 1)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for nowait schedule(monotonic,simd:static)
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
abort ();
l = i;
}
if (c > 1)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for schedule(monotonic : dynamic, 5) nowait
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if ((n % 5) != 0 || n == 0)
abort ();
n = 1;
c++;
}
l = i;
}
if (l == 73 - 1)
{
if (n % 5 != 73 % 5)
abort ();
}
else if (l == MONOTONIC_UNDEF)
{
if (n != 0 || c != 0)
abort ();
}
else if ((n % 5) != 0 || n == 0)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for nowait schedule(dynamic, 7) ordered(1)
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if ((n % 7) != 0 || n == 0)
abort ();
n = 1;
c++;
}
#pragma omp ordered depend(source)
if (MONOTONIC_UNDEF > 0)
{
#pragma omp ordered depend(sink: i)
}
else
{
#pragma omp ordered depend(sink: i - 1)
}
l = i;
}
if (l == 73 - 1)
{
if (n % 7 != 73 % 7)
abort ();
}
else if (l == MONOTONIC_UNDEF)
{
if (n != 0 || c != 0)
abort ();
}
else if ((n % 7) != 0 || n == 0)
abort ();
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for schedule (monotonic :guided , 7) nowait
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if (n < 7)
abort ();
n = 1;
c++;
}
l = i;
}
l = MONOTONIC_UNDEF;
c = 0;
n = 0;
#pragma omp for nowait schedule(guided, 7) ordered
for (i = 0; i < MONOTONIC_END (73); i++)
{
if (l == MONOTONIC_UNDEF)
{
n = 1;
c++;
}
else if (l == i - 1)
n++;
else
{
if (l >= i)
abort ();
if (n < 7)
abort ();
n = 1;
c++;
}
#pragma omp ordered
l = i;
}
}
return 0;
}