gcc/libgomp/testsuite/libgomp.fortran/is_device_ptr-3.f90
Tobias Burnus 96ff97ff65 OpenMP/Fortran: Fix handling of optional is_device_ptr + bind(C) [PR108546]
For is_device_ptr, optional checks should only be done before calling
libgomp, afterwards they are NULL either because of absent or, by
chance, because it is unallocated or unassociated (for pointers/allocatables).

Additionally, it fixes an issue with explicit mapping for 'type(c_ptr)'.

	PR middle-end/108546

gcc/fortran/ChangeLog:

	* trans-openmp.cc (gfc_trans_omp_clauses): Fix mapping of
	type(C_ptr) variables.

gcc/ChangeLog:

	* omp-low.cc (lower_omp_target): Remove optional handling
	on the receiver side, i.e. inside target (data), for
	use_device_ptr.

libgomp/ChangeLog:

	* testsuite/libgomp.fortran/is_device_ptr-3.f90: New test.
	* testsuite/libgomp.fortran/use_device_ptr-optional-4.f90: New test.
2023-03-01 13:53:09 +01:00

47 lines
1.1 KiB
Fortran

module m
use iso_c_binding
implicit none
contains
subroutine s(x,y,z)
type(c_ptr), optional :: x
integer, pointer, optional :: y
integer, allocatable, optional :: z
logical is_present, is_null
is_present = present(x)
if (is_present) &
is_null = .not. c_associated(x)
!$omp target is_device_ptr(x) has_device_addr(y) has_device_addr(z)
if (is_present) then
if (is_null) then
if (c_associated(x)) stop 1
if (associated(y)) stop 2
if (allocated(z)) stop 3
else
if (.not. c_associated(x, c_loc(y))) stop 4
if (y /= 7) stop 5
if (z /= 9) stop 6
end if
end if
!$omp end target
end
end
use m
implicit none
integer, pointer :: p
integer, allocatable :: a
p => null()
call s()
!$omp target data map(p,a) use_device_addr(p,a)
call s(c_null_ptr, p, a)
!$omp end target data
allocate(p,a)
p = 7
a = 9
!$omp target data map(p,a) use_device_addr(p,a)
call s(c_loc(p), p, a)
!$omp end target data
deallocate(p,a)
end