Files
clang-p2996/flang/test/Semantics/OpenMP/ordered03.f90
Sergio Afonso e0e93c3f76 [Frontend][OpenMP] Follow compound construct clause restrictions (#107853)
This patch removes from the list of allowed clauses for a handful of
compound constructs those that are specifically disallowed by the OpenMP
spec. In particular, the following restrictions are followed:
- (regarding combined constructs) If _directive-name-A_ is `target`, the
`copyin` clause must not be specified.
- (regarding composite constructs) If _directive-name-A_ is
`distribute`, the `ordered` clause must not be specified.

These restrictions are listed in the OpenMP Specification version 5.2,
sections 17.4 and 17.5. Since it's a similar case as PR #90754, I'm
adding people involved in that decision as reviewers here.
2024-09-16 15:02:11 +01:00

124 lines
4.8 KiB
Fortran

! RUN: %python %S/../test_errors.py %s %flang -fopenmp
! OpenMP Version 5.1
! Check OpenMP construct validity for the following directives:
! 2.19.9 Ordered Construct
subroutine sub1()
integer :: i, j, N = 10
real :: arrayA(10), arrayB(10)
real, external :: foo, bar
!$omp do ordered(1)
do i = 1, N
!$omp ordered depend(source)
arrayA(i) = foo(i)
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end do
!$omp do ordered(1)
do i = 1, N
!$omp target
do j = 1, N
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
arrayA(i) = foo(i)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end target
end do
!$omp end do
!$omp target
!$omp parallel do ordered(1)
do i = 1, N
!$omp ordered depend(source)
arrayA(i) = foo(i)
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end parallel do
!$omp end target
!$omp target parallel do ordered(1)
do i = 1, N
!$omp ordered depend(source)
arrayA(i) = foo(i)
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end target parallel do
!ERROR: ORDERED clause is not allowed on the TARGET TEAMS DISTRIBUTE PARALLEL DO directive
!$omp target teams distribute parallel do ordered(1)
do i = 1, N
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
arrayA(i) = foo(i)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end target teams distribute parallel do
!$omp do ordered
do i = 1, N
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
arrayA(i) = foo(i)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end do
!$omp parallel do ordered
do i = 1, N
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
arrayA(i) = foo(i)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end parallel do
!$omp target parallel do ordered
do i = 1, N
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
arrayA(i) = foo(i)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
arrayB(i) = bar(i - 1)
end do
!$omp end target parallel do
!$omp do ordered(1)
do i = 1, N
!ERROR: The number of variables in DEPEND(SINK: vec) clause does not match the parameter specified in ORDERED clause
!$omp ordered depend(sink: i - 1) depend(sink: i - 1, j)
arrayB(i) = bar(i - 1, j)
end do
!$omp end do
!$omp do ordered(2)
do i = 1, N
do j = 1, N
!ERROR: The number of variables in DEPEND(SINK: vec) clause does not match the parameter specified in ORDERED clause
!$omp ordered depend(sink: i - 1) depend(sink: i - 1, j)
arrayB(i) = foo(i - 1) + bar(i - 1, j)
end do
end do
!$omp end do
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(source)
!ERROR: An ORDERED construct with the DEPEND clause must be closely nested in a worksharing-loop (or parallel worksharing-loop) construct with ORDERED clause with a parameter
!$omp ordered depend(sink: i - 1)
end