! 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