! RUN: %python %S/../test_errors.py %s %flang -fopenacc -pedantic ! Check OpenACC clause validity for the following construct and directive: ! 2.6.5 Data ! 2.14.6 Enter Data ! 2.14.7 Exit Data program openacc_data_validity implicit none type atype real(8), dimension(10) :: arr real(8) :: s end type atype integer :: i, j, b, gang_size, vector_size, worker_size integer, parameter :: N = 256 integer, dimension(N) :: c logical, dimension(N) :: d, e integer :: async1 integer :: wait1, wait2 real :: reduction_r logical :: reduction_l real(8), dimension(N, N) :: aa, bb, cc real(8), dimension(:), allocatable :: dd real(8), pointer :: p logical :: ifCondition = .TRUE. type(atype) :: t type(atype), dimension(10) :: ta real(8), dimension(N) :: a, f, g, h !ERROR: At least one of ATTACH, COPYIN, CREATE clause must appear on the ENTER DATA directive !$acc enter data !ERROR: Modifier is not allowed for the COPYIN clause on the ENTER DATA directive !$acc enter data copyin(zero: i) !ERROR: Only the ZERO modifier is allowed for the CREATE clause on the ENTER DATA directive !$acc enter data create(readonly: i) !ERROR: COPYOUT clause is not allowed on the ENTER DATA directive !$acc enter data copyin(i) copyout(i) !$acc enter data create(aa) if(.TRUE.) !$acc enter data create(a(1:10)) !$acc enter data create(t%arr) !$acc enter data create(t%arr(2:4)) !ERROR: At most one IF clause can appear on the ENTER DATA directive !$acc enter data create(aa) if(.TRUE.) if(ifCondition) !$acc enter data create(aa) if(ifCondition) !$acc enter data create(aa) async !ERROR: At most one ASYNC clause can appear on the ENTER DATA directive !$acc enter data create(aa) async async !$acc enter data create(aa) async(async1) !$acc enter data create(aa) async(1) !$acc enter data create(aa) wait(1) !$acc enter data create(aa) wait(wait1) !$acc enter data create(aa) wait(wait1, wait2) !$acc enter data create(aa) wait(wait1) wait(wait2) !ERROR: Argument `bb` on the ATTACH clause must be a variable or array with the POINTER or ALLOCATABLE attribute !$acc enter data attach(bb) !ERROR: At least one of COPYOUT, DELETE, DETACH clause must appear on the EXIT DATA directive !$acc exit data !ERROR: Modifier is not allowed for the COPYOUT clause on the EXIT DATA directive !$acc exit data copyout(zero: i) !$acc exit data delete(aa) !$acc exit data delete(aa) finalize !ERROR: At most one FINALIZE clause can appear on the EXIT DATA directive !$acc exit data delete(aa) finalize finalize !ERROR: Argument `cc` on the DETACH clause must be a variable or array with the POINTER or ALLOCATABLE attribute !$acc exit data detach(cc) !ERROR: Argument on the DETACH clause must be a variable or array with the POINTER or ALLOCATABLE attribute !$acc exit data detach(/i/) !$acc exit data copyout(bb) !$acc exit data delete(aa) if(.TRUE.) !$acc exit data delete(aa) if(ifCondition) !ERROR: At most one IF clause can appear on the EXIT DATA directive !$acc exit data delete(aa) if(ifCondition) if(.TRUE.) !$acc exit data delete(aa) async !ERROR: At most one ASYNC clause can appear on the EXIT DATA directive !$acc exit data delete(aa) async async !$acc exit data delete(aa) async(async1) !$acc exit data delete(aa) async(1) !$acc exit data delete(aa) wait(1) !$acc exit data delete(aa) wait(wait1) !$acc exit data delete(aa) wait(wait1, wait2) !$acc exit data delete(aa) wait(wait1) wait(wait2) !ERROR: Only the ZERO modifier is allowed for the COPYOUT clause on the DATA directive !$acc data copyout(readonly: i) !$acc end data !ERROR: At most one IF clause can appear on the DATA directive !$acc data copy(i) if(.true.) if(.true.) !$acc end data !ERROR: At least one of COPYOUT, DELETE, DETACH clause must appear on the EXIT DATA directive !$acc exit data !PORTABILITY: At least one of ATTACH, COPY, COPYIN, COPYOUT, CREATE, DEFAULT, DEVICEPTR, NO_CREATE, PRESENT clause should appear on the DATA directive !$acc data !$acc end data !$acc data copy(aa) if(.true.) !$acc end data !$acc data copy(aa) if(ifCondition) !$acc end data !$acc data copy(aa, bb, cc) !$acc end data !$acc data copyin(aa) copyin(readonly: bb) copyout(cc) !$acc end data !$acc data copyin(readonly: aa, bb) copyout(zero: cc) !$acc end data !$acc data create(aa, bb(:,:)) create(zero: cc(:,:)) !$acc end data !$acc data no_create(aa) present(bb, cc) !$acc end data !$acc data deviceptr(aa) attach(dd, p) !$acc end data !$acc data copy(aa, bb) default(none) !$acc end data !$acc data copy(aa, bb) default(present) !$acc end data !ERROR: At most one DEFAULT clause can appear on the DATA directive !$acc data copy(aa, bb) default(none) default(present) !$acc end data !ERROR: At most one IF clause can appear on the DATA directive !$acc data copy(aa) if(.true.) if(ifCondition) !$acc end data !$acc data copyin(i) !ERROR: Unmatched PARALLEL directive !$acc end parallel !$acc data copy(aa) async !$acc end data !$acc data copy(aa) wait !$acc end data !$acc data copy(aa) device_type(default) wait !$acc end data do i = 1, 100 !$acc data copy(aa) !ERROR: CYCLE to construct outside of DATA construct is not allowed if (i == 10) cycle !$acc end data end do !$acc data copy(aa) do i = 1, 100 if (i == 10) cycle end do !$acc end data end program openacc_data_validity module mod1 type :: t1 integer :: a contains procedure :: t1_proc end type contains subroutine t1_proc(this) class(t1) :: this end subroutine subroutine sub4(t) type(t1) :: t !ERROR: Only variables are allowed in data clauses on the DATA directive !$acc data copy(t%t1_proc) !$acc end data end subroutine subroutine sub5() integer, parameter :: iparam = 1024 !$acc data copyin(iparam) !$acc end data end subroutine end module