(root)/
gcc-13.2.0/
gcc/
testsuite/
gfortran.dg/
gomp/
cancel-1.f90
! { dg-additional-options "-cpp" }

subroutine f1
  !$omp cancel parallel			! { dg-error "orphaned" }
  !$omp cancel do			! { dg-error "orphaned" }
  !$omp cancel sections			! { dg-error "orphaned" }
  !$omp cancel taskgroup			! { dg-error "orphaned" }
  !$omp cancellation point parallel	! { dg-error "orphaned" }
  !$omp cancellation point do		! { dg-error "orphaned" }
  !$omp cancellation point sections	! { dg-error "orphaned" }
  !$omp cancellation point taskgroup	! { dg-error "orphaned" }
end

subroutine f2
  integer :: i, j
  j = 0
  !$omp parallel
    !$omp cancel parallel
    !$omp cancel do			! { dg-error "not closely nested inside" }
    !$omp cancel sections			! { dg-error "not closely nested inside" }
    !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
    !$omp cancellation point parallel
    !$omp cancellation point do		! { dg-error "not closely nested inside" }
    !$omp cancellation point sections	! { dg-error "not closely nested inside" }
    !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }

    !$omp master
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end master

    !$omp masked
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end masked

    !$omp scope
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end scope

    !$omp single
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end single

    !$omp critical
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end critical

    !$omp taskgroup
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end taskgroup

    !$omp task
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "construct not closely nested inside of .taskgroup. region" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "construct not closely nested inside of .taskgroup. region" }
    !$omp end task

    !$omp taskgroup
    !$omp task
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup
    !$omp end task
    !$omp end taskgroup

    !$omp taskloop
    do i = 0, 9
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup
        !$omp task
          !$omp cancellation point taskgroup
          !$omp cancel taskgroup
        !$omp end task
    end do
    !$omp taskloop nogroup
    do i = 0, 9
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup		! { dg-error "construct not closely nested inside of .taskgroup. region" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup! { dg-error "construct not closely nested inside of .taskgroup. region" }
        !$omp task
          !$omp cancellation point taskgroup! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp cancel taskgroup		! { dg-error "construct not closely nested inside of .taskgroup. region" }
        !$omp end task
    end do
    !$omp taskgroup
      !$omp task
        !$omp task
          !$omp cancellation point taskgroup
          !$omp cancel taskgroup
        !$omp end task
      !$omp end task
      !$omp taskloop nogroup
      do i = 0, 9
          !$omp task
            !$omp cancellation point taskgroup
            !$omp cancel taskgroup
          !$omp end task
          !$omp cancellation point taskgroup
          !$omp cancel taskgroup
      end do
    !$omp end taskgroup

    !$omp taskgroup
      !$omp parallel
        !$omp task
          !$omp cancel taskgroup		! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
        !$omp end task
        !$omp taskloop
        do i = 0, 9
            !$omp cancel taskgroup
            !$omp cancellation point taskgroup
        end do
        !$omp taskloop nogroup
        do i = 0, 9
            !$omp cancel taskgroup	     ! { dg-error "construct not closely nested inside of .taskgroup. region" }
            !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
        end do
      !$omp end parallel
      !$omp target
        !$omp task
          !$omp cancel taskgroup		! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
        !$omp end task
      !$omp end target
      !$omp target
      !$omp teams
      !$omp distribute
      do i = 0, 9
          !$omp task
            !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp end task
      end do
      !$omp end distribute
      !$omp end teams
      !$omp end target
      !$omp target data map(i)
        !$omp task
          !$omp cancel taskgroup
          !$omp cancellation point taskgroup
        !$omp end task
      !$omp end target data
    !$omp end taskgroup

    !$omp taskloop
    do i = 0, 9
        !$omp parallel
          !$omp task
            !$omp cancel taskgroup	     ! { dg-error "construct not closely nested inside of .taskgroup. region" }
            !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp end task
        !$omp end parallel
        !$omp target
          !$omp task
            !$omp cancel taskgroup	     ! { dg-error "construct not closely nested inside of .taskgroup. region" }
            !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
          !$omp end task
        !$omp end target
        !$omp target
        !$omp teams
        !$omp distribute
        do j = 0, 9
            !$omp task
              !$omp cancel taskgroup	! { dg-error "construct not closely nested inside of .taskgroup. region" }
              !$omp cancellation point taskgroup ! { dg-error "construct not closely nested inside of .taskgroup. region" }
            !$omp end task
        end do
        !$omp end distribute
        !$omp end teams
        !$omp end target
        !$omp target data map(i)
          !$omp task
            !$omp cancel taskgroup
            !$omp cancellation point taskgroup
          !$omp end task
        !$omp end target data
    end do

    !$omp do
    do i = 0, 9
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
    end do

    !$omp do ordered
    do i = 0, 9
      !$omp ordered
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
      !$omp end ordered
    end do
    !$omp end do
    !$omp sections
      !$omp section
      block
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
      end block
      !$omp section
      block
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
      end block
    !$omp target data map(j)
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target data
    !$omp target
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target
  !$omp end sections
  !$omp end parallel
  !$omp target data map(j)
    !$omp cancel parallel			! { dg-error "not closely nested inside" }
    !$omp cancel do			! { dg-error "not closely nested inside" }
    !$omp cancel sections			! { dg-error "not closely nested inside" }
    !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
    !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
    !$omp cancellation point do		! { dg-error "not closely nested inside" }
    !$omp cancellation point sections	! { dg-error "not closely nested inside" }
    !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
  !$omp end target data
  !$omp target
    !$omp cancel parallel			! { dg-error "not closely nested inside" }
    !$omp cancel do			! { dg-error "not closely nested inside" }
    !$omp cancel sections			! { dg-error "not closely nested inside" }
    !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
    !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
    !$omp cancellation point do		! { dg-error "not closely nested inside" }
    !$omp cancellation point sections	! { dg-error "not closely nested inside" }
    !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
  !$omp end target
  !$omp target teams
    !$omp cancel parallel			! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancel do			! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancel sections			! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancel taskgroup		! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancellation point parallel	! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancellation point do		! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancellation point sections	! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
    !$omp cancellation point taskgroup	! { dg-error "only .distribute., .parallel. or .loop. regions are allowed to be strictly nested" }
  !$omp end target teams
  !$omp target teams distribute
  do i = 0, 9
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
  end do
  !$omp end target teams distribute
  !$omp do
  do i = 0, 9
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
  end do
  !$omp do
  do i = 0, 9
    !$omp target data map(j)
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target data
  end do
  !$omp do
  do i = 0, 9
    !$omp target
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target
  end do
  !$omp do ordered
  do i = 0, 9
    !$omp ordered
      !$omp target data map(j)
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
      !$omp end target data
    !$omp end ordered
  end do
  do i = 0, 9
    !$omp ordered
      !$omp target
        !$omp cancel parallel		! { dg-error "not closely nested inside" }
        !$omp cancel do			! { dg-error "not closely nested inside" }
        !$omp cancel sections		! { dg-error "not closely nested inside" }
        !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
        !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
        !$omp cancellation point do	! { dg-error "not closely nested inside" }
        !$omp cancellation point sections	! { dg-error "not closely nested inside" }
        !$omp cancellation point taskgroup! { dg-error "not closely nested inside" }
      !$omp end target
    !$omp end ordered
  end do
  !$omp sections
    !$omp section
    block
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    end block
    !$omp section
    block
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    end block
  !$omp end sections
  !$omp sections
    !$omp target data map(j)
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target data
    !$omp section
    !$omp target data map(j)
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target data
  !$omp end sections
  !$omp sections
    !$omp target
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target
    !$omp section
    !$omp target
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end target
  !$omp end sections
  !$omp task
    !$omp cancel parallel			! { dg-error "not closely nested inside" }
    !$omp cancel do			! { dg-error "not closely nested inside" }
    !$omp cancel sections			! { dg-error "not closely nested inside" }
    !$omp cancel taskgroup
    !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
    !$omp cancellation point do		! { dg-error "not closely nested inside" }
    !$omp cancellation point sections	! { dg-error "not closely nested inside" }
    !$omp cancellation point taskgroup
    !$omp taskgroup
      !$omp cancel parallel		! { dg-error "not closely nested inside" }
      !$omp cancel do			! { dg-error "not closely nested inside" }
      !$omp cancel sections		! { dg-error "not closely nested inside" }
      !$omp cancel taskgroup		! { dg-error "not closely nested inside" }
      !$omp cancellation point parallel	! { dg-error "not closely nested inside" }
      !$omp cancellation point do	! { dg-error "not closely nested inside" }
      !$omp cancellation point sections	! { dg-error "not closely nested inside" }
      !$omp cancellation point taskgroup	! { dg-error "not closely nested inside" }
    !$omp end taskgroup
  !$omp end task
end

subroutine f3
  integer i
  !$omp do
  do i = 0, 9
      !$omp cancel do		! { dg-warning "nowait" }
  end do
  !$omp end do nowait
  !$omp sections
    !$omp section
    block
      !$omp cancel sections	! { dg-warning "nowait" }
    end block
    !$omp section
    block
      !$omp cancel sections	! { dg-warning "nowait" }
    end block
  !$omp end sections nowait
  !$omp do ordered
  do i = 0, 9
      !$omp cancel do		! { dg-warning "ordered" }
      !$omp ordered
      !$omp end ordered
  end do
end


subroutine f4
!  if (.false.) then
!$omp cancellation point do ! { dg-error "orphaned 'cancellation point' construct" }
!  end if
end