llvm-capstone/flang/test/Semantics/OpenACC/acc-routine-validity.f90
Ivan Zhechev 6c1ac141d3 [Flang] Ported test_errors.sh to Python
To enable Flang testing on Windows, shell scripts have to be ported to Python. In this patch the "test_errors.sh" script is ported to python ("test_errors.py"). The RUN line of existing tests was changed to make use of the python script.

Used python regex in place of awk/sed.

Reviewed By: Meinersbur

Differential Revision: https://reviews.llvm.org/D107575
2021-09-06 08:19:42 +00:00

80 lines
1.9 KiB
Fortran

! RUN: %python %S/../test_errors.py %s %flang -fopenacc
! Check OpenACC clause validity for the following construct and directive:
! 2.15.1 routine
module openacc_routine_validity
implicit none
!$acc routine(sub3) seq
!$acc routine(fct2) vector
!ERROR: At least one of GANG, SEQ, VECTOR, WORKER clause must appear on the ROUTINE directive
!$acc routine(sub3)
!ERROR: ROUTINE directive without name must appear within the specification part of a subroutine or function definition, or within an interface body for a subroutine or function in an interface block
!$acc routine seq
!ERROR: No function or subroutine declared for 'dummy'
!$acc routine(dummy) seq
contains
subroutine sub1(a)
real :: a(:)
!ERROR: At least one of GANG, SEQ, VECTOR, WORKER clause must appear on the ROUTINE directive
!$acc routine
end subroutine sub1
subroutine sub2(a)
real :: a(:)
!ERROR: Clause NOHOST is not allowed after clause DEVICE_TYPE on the ROUTINE directive
!$acc routine seq device_type(*) nohost
end subroutine sub2
subroutine sub3(a)
real :: a(:)
end subroutine sub3
subroutine sub4(a)
real :: a(:)
!$acc routine seq
end subroutine sub4
subroutine sub5(a)
real :: a(:)
!$acc routine(sub5) seq
end subroutine sub5
function fct1(a)
integer :: fct1
real :: a(:)
!$acc routine vector nohost
end function fct1
function fct2(a)
integer :: fct2
real :: a(:)
end function fct2
function fct3(a)
integer :: fct3
real :: a(:)
!$acc routine seq bind(fct2)
end function fct3
function fct4(a)
integer :: fct4
real :: a(:)
!$acc routine seq bind("_fct4")
end function fct4
subroutine sub6(a)
real :: a(:)
!ERROR: No function or subroutine declared for 'dummy_sub'
!$acc routine seq bind(dummy_sub)
end subroutine sub6
end module openacc_routine_validity