Fortran part to C/C++/libgomp
commit
r13-724-gb43836914bdc2a37563cf31359b2c4803bfe4374
gcc/fortran/
PR c/105378
* openmp.cc (gfc_match_omp_taskwait): Accept nowait.
gcc/testsuite/
PR c/105378
* gfortran.dg/gomp/taskwait-depend-nowait-1.f90: New.
libgomp/
PR c/105378
* libgomp.texi (OpenMP 5.1): Set 'taskwait nowait' to 'Y'.
* testsuite/libgomp.fortran/taskwait-depend-nowait-1.f90: New.
new_st.ext.omp_clauses = NULL;
return MATCH_YES;
}
- return match_omp (EXEC_OMP_TASKWAIT, omp_mask (OMP_CLAUSE_DEPEND));
+ return match_omp (EXEC_OMP_TASKWAIT,
+ omp_mask (OMP_CLAUSE_DEPEND) | OMP_CLAUSE_NOWAIT);
}
--- /dev/null
+subroutine foo (p)
+ integer :: p(*)
+ !$omp taskwait depend(iterator(i = 1:17) , in : p(i)) nowait depend(out : p(32))
+end
+
+subroutine bar (p)
+ implicit none
+ integer :: p(*)
+ !$omp taskwait depend(mutexinoutset : p(1)) nowait ! { dg-error "'mutexinoutset' kind in 'depend' clause on a 'taskwait' construct" }
+end
+
+subroutine baz
+ !$omp taskwait nowait ! { dg-error "'taskwait' construct with 'nowait' clause but no 'depend' clauses" }
+end
@code{target} regions @tab N @tab
@item @code{interop} directive @tab N @tab
@item @code{omp_interop_t} object support in runtime routines @tab N @tab
-@item @code{nowait} clause in @code{taskwait} directive @tab N @tab
+@item @code{nowait} clause in @code{taskwait} directive @tab Y @tab
@item Extensions to the @code{atomic} directive @tab Y @tab
@item @code{seq_cst} clause on a @code{flush} construct @tab Y @tab
@item @code{inoutset} argument to the @code{depend} clause @tab Y @tab
--- /dev/null
+program main
+ implicit none
+ integer :: a(0:63), b = 1
+ !$omp parallel num_threads (4)
+ block
+ !$omp single
+ block
+ integer :: i
+ !$omp taskwait depend(in: a) nowait
+ !$omp taskwait depend(in: a) nowait
+ !$omp taskwait
+ !$omp taskgroup
+ block
+ !$omp taskwait depend(in: a) nowait
+ !$omp taskwait depend(in: a) nowait
+ end block
+ do i = 0, 63
+ !$omp task depend(in: a) shared(a)
+ block
+ a(i) = i
+ end block
+ end do
+ !$omp taskwait depend(inout: a) nowait
+ do i = 0, 63
+ !$omp task depend(inoutset: a) shared(a)
+ block
+ if (a(i) /= i) then
+ error stop
+ else
+ a(i) = 2 * i + 1
+ end if
+ end block
+ end do
+ !$omp taskwait nowait depend(out: a) depend(in: b)
+ !$omp taskwait depend(inout: b)
+ do i = 0, 63
+ if (a(i) /= 2 * i + 1) &
+ error stop
+ end do
+ end block
+ end block
+end program