subroutine foo (n) integer i, n !$omp do ordered do i = 1, 8, n !$omp ordered doacross(source:) !$omp ordered doacross(sink: i - 2) end do end subroutine bar (n) integer :: i, j, n !$omp do collapse(2) ordered(2) do i = 1, 8, n do j = 1, 8, n !$omp ordered doacross(source:omp_cur_iteration) !$omp ordered doacross(sink: i - 2, j + 2) end do end do end subroutine baz () integer :: i, j !$omp do ordered(1) do i = 1, 64 !$omp ordered ! { dg-error "'ordered' construct without 'doacross' or 'depend' clauses must not have the same binding region as 'ordered' construct with those clauses" } !$omp end ordered !$omp ordered doacross(source:) !$omp ordered doacross(sink: i - 1) end do !$omp do ordered do i = 1, 64 !$omp ordered doacross(source: omp_cur_iteration ) !$omp ordered doacross(sink: i - 1) !$omp ordered threads ! { dg-error "'ordered' construct without 'doacross' or 'depend' clauses must not have the same binding region as 'ordered' construct with those clauses" } !$omp end ordered end do !$omp do ordered(2) do i = 1, 64 do j = 1, 64 !$omp ordered ! { dg-error "'ordered' construct without 'doacross' or 'depend' clauses binds to loop where 'collapse' argument 1 is different from 'ordered' argument 2" } !$omp end ordered end do end do !$omp do ordered(2) collapse(1) do i = 1, 8 do j = 1, 8 !$omp ordered threads ! { dg-error "'ordered' construct without 'doacross' or 'depend' clauses binds to loop where 'collapse' argument 1 is different from 'ordered' argument 2" } !$omp end ordered end do end do end subroutine qux () integer :: i, j j = 0 !$omp do ordered linear(j) do i = 1, 64 j = j + 1 !$omp ordered !$omp end ordered end do !$omp do ordered linear(j) ! { dg-error "'linear' clause may not be specified together with 'ordered' clause if stand-alone 'ordered' construct is nested in it" } do i = 1, 64 j = j + 1 !$omp ordered doacross(source:) !$omp ordered doacross(sink:i-1) end do !$omp do ordered(1) linear(j) do i = 1, 64 j = j + 1 !$omp ordered !$omp end ordered end do !$omp do ordered(1) linear(j) ! { dg-error "'linear' clause may not be specified together with 'ordered' clause if stand-alone 'ordered' construct is nested in it" } do i = 1, 64 j = j + 1 !$omp ordered doacross(source:) !$omp ordered doacross(sink:i-1) end do end