llvm-project/flang/test/Semantics/omp-declarative-directive.f90

73 lines
1.8 KiB
Fortran

! RUN: %S/test_errors.sh %s %t %flang -fopenmp
! REQUIRES: shell
! Check OpenMP declarative directives
!TODO: all internal errors
! enable declare-reduction example after name resolution
! 2.8.2 declare-simd
subroutine declare_simd_1(a, b)
real(8), intent(inout) :: a, b
!$omp declare simd(declare_simd_1) aligned(a)
a = 3.14 + b
end subroutine declare_simd_1
module m1
abstract interface
subroutine sub(x,y)
integer, intent(in)::x
integer, intent(in)::y
end subroutine sub
end interface
end module m1
subroutine declare_simd_2
use m1
procedure (sub) sub1
!ERROR: NOTINBRANCH and INBRANCH clauses are mutually exclusive and may not appear on the same DECLARE SIMD directive
!$omp declare simd(sub1) inbranch notinbranch
procedure (sub), pointer::p
p=>sub1
call p(5,10)
end subroutine declare_simd_2
subroutine sub1 (x,y)
integer, intent(in)::x, y
print *, x+y
end subroutine sub1
! 2.10.6 declare-target
! 2.15.2 threadprivate
module m2
contains
subroutine foo
!$omp declare target
!$omp declare target (foo, N, M)
!$omp declare target to(Q, S) link(R)
!ERROR: MAP clause is not allowed on the DECLARE TARGET directive
!$omp declare target map(from:Q)
integer, parameter :: N=10000, M=1024
integer :: i
real :: Q(N, N), R(N,M), S(M,M)
!$omp threadprivate(i)
end subroutine foo
end module m2
! 2.16 declare-reduction
! subroutine declare_red_1()
! use omp_lib
! integer :: my_var
! !$omp declare reduction (my_add_red : integer : omp_out = omp_out + omp_in) initializer (omp_priv=0)
! my_var = 0
! !$omp parallel reduction (my_add_red : my_var) num_threads(4)
! my_var = omp_get_thread_num() + 1
! !$omp end parallel
! print *, "sum of thread numbers is ", my_var
! end subroutine declare_red_1
end