! PR c/81887
! { dg-do compile }
! { dg-options "-fno-openmp -fopenmp-simd -fdump-tree-gimple" }
! { dg-final { scan-tree-dump-times "#pragma omp simd" 2 "gimple" } }
! { dg-final { scan-tree-dump-times "#pragma omp ordered simd\[ \t]*\[\n\r]" 2 "gimple" } }
! { dg-final { scan-tree-dump-times "#pragma omp" 4 "gimple" } }
subroutine f1 (x)
  integer :: i, x(100)
  !$omp simd
  do i = 2, 101
    !$omp ordered simd
    x(i / 2) = i
    !$omp end ordered
  end do
end subroutine
subroutine f2 (x)
  integer :: i, x(100)
  !$omp parallel do simd ordered
  do i = 2, 101
    !$omp ordered threads simd
    x(i / 2) = i
    !$omp end ordered
  end do
end subroutine
subroutine f3 (x)
  integer :: i, x(100)
  !$omp parallel do ordered
  do i = 2, 101
    !$omp ordered
    x(i / 2) = i
    !$omp end ordered
  end do
end subroutine
subroutine f4 (x)
  integer :: i, x(100)
  !$omp parallel do ordered
  do i = 2, 101
    !$omp ordered threads
    x(i / 2) = i
    !$omp end ordered
  end do
end subroutine
subroutine f5(x, n)
  integer :: i, j, k, n, x(100,100,100)
  !$omp parallel do ordered(3)
  do i = 1, n
    do j = 1, n
      do k = 1, n
	!$omp ordered depend(sink:i-8,j-2,k+2) depend(sink:i, j-1,k) depend(sink:i-4,j-3,k+6) depend(sink:i-6,j-4,k-6)
	x(i, j, k) = i + j + k
	!$omp ordered depend(source)
      end do
    end do
  end do
  !$omp end parallel do
end subroutine