gcc/libgomp/testsuite/libgomp.fortran/class-firstprivate-3.f90
Tobias Burnus 0e3b3b77e1 OpenMP/Fortran: Handle polymorphic scalars in data-sharing FIRSTPRIVATE [PR86470]
gcc/fortran/ChangeLog:

	PR fortran/86470
	* trans-expr.c (gfc_copy_class_to_class): Add unshare_expr.
	* trans-openmp.c (gfc_is_polymorphic_nonptr,
	gfc_is_unlimited_polymorphic_nonptr): New.
	(gfc_omp_clause_copy_ctor, gfc_omp_clause_dtor): Handle
	polymorphic scalars.

libgomp/ChangeLog:

	PR fortran/86470
	* testsuite/libgomp.fortran/class-firstprivate-1.f90: New test.
	* testsuite/libgomp.fortran/class-firstprivate-2.f90: New test.
	* testsuite/libgomp.fortran/class-firstprivate-3.f90: New test.

gcc/testsuite/ChangeLog:

	PR fortran/86470
	* gfortran.dg/gomp/class-firstprivate-1.f90: New test.
	* gfortran.dg/gomp/class-firstprivate-2.f90: New test.
	* gfortran.dg/gomp/class-firstprivate-3.f90: New test.
	* gfortran.dg/gomp/class-firstprivate-4.f90: New test.
2021-05-24 16:50:51 +02:00

335 lines
7.5 KiB
Fortran

! FIRSTPRIVATE: CLASS(*) + derived types
program select_type_openmp
implicit none
type t
end type t
type, extends(t) :: t_int
integer :: i
end type
type, extends(t) :: t_char1
character(len=:, kind=1), allocatable :: str
end type
type, extends(t) :: t_char4
character(len=:, kind=4), allocatable :: str
end type
class(*), allocatable :: val1, val1a, val2, val3
call sub() ! local var
call sub2(val1, val1a, val2, val3) ! allocatable args
allocate(val1, source=t_int(7))
allocate(val1a, source=t_int(7))
allocate(val2, source=t_char1("abcdef"))
allocate(val3, source=t_char4(4_"zyx4"))
call sub3(val1, val1a, val2, val3) ! nonallocatable vars
deallocate(val1, val1a, val2, val3)
contains
subroutine sub()
class(*), allocatable :: val1, val1a, val2, val3
allocate(val1a, source=t_int(7))
allocate(val2, source=t_char1("abcdef"))
allocate(val3, source=t_char4(4_"zyx4"))
if (allocated(val1)) stop 1
!$OMP PARALLEL firstprivate(val1, val1a, val2, val3)
if (allocated(val1)) stop 2
if (.not.allocated(val1a)) stop 3
if (.not.allocated(val2)) stop 4
if (.not.allocated(val3)) stop 5
allocate(val1, source=t_int(7))
select type (val1)
type is (t_int)
if (val1%i /= 7) stop 6
val1%i = 8
class default
stop 7
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 7) stop 8
val1a%i = 8
class default
stop 9
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 10
if (val2%str /= "abcdef") stop 11
val2%str = "123456"
class default
stop 12
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 13
if (val3%str /= 4_"zyx4") stop 14
val3%str = 4_"AbCd"
class default
stop 15
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 16
if (val3%str /= 4_"AbCd") stop 17
val3%str = 4_"1ab2"
class default
stop 18
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 19
if (val2%str /= "123456") stop 20
val2%str = "A2C4E6"
class default
stop 21
end select
select type (val1)
type is (t_int)
if (val1%i /= 8) stop 22
val1%i = 9
class default
stop 23
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 8) stop 24
val1a%i = 9
class default
stop 25
end select
!$OMP END PARALLEL
if (allocated(val1)) stop 26
if (.not. allocated(val1a)) stop 27
if (.not. allocated(val2)) stop 28
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 29
if (val2%str /= "abcdef") stop 30
class default
stop 31
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 32
if (val3%str /= 4_"zyx4") stop 33
class default
stop 34
end select
deallocate(val1a,val2, val3)
end subroutine sub
subroutine sub2(val1, val1a, val2, val3)
class(*), allocatable :: val1, val1a, val2, val3
optional :: val1a
allocate(val1a, source=t_int(7))
allocate(val2, source=t_char1("abcdef"))
allocate(val3, source=t_char4(4_"zyx4"))
if (allocated(val1)) stop 35
!$OMP PARALLEL firstprivate(val1, val1a, val2, val3)
if (allocated(val1)) stop 36
if (.not.allocated(val1a)) stop 37
if (.not.allocated(val2)) stop 38
if (.not.allocated(val3)) stop 39
allocate(val1, source=t_int(7))
select type (val1)
type is (t_int)
if (val1%i /= 7) stop 40
val1%i = 8
class default
stop 41
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 7) stop 42
val1a%i = 8
class default
stop 43
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 44
if (val2%str /= "abcdef") stop 45
val2%str = "123456"
class default
stop 46
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 47
if (val3%str /= 4_"zyx4") stop 48
val3%str = "AbCd"
class default
stop 49
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 50
if (val3%str /= 4_"AbCd") stop 51
val3%str = 4_"1ab2"
class default
stop 52
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 53
if (val2%str /= "123456") stop 54
val2%str = "A2C4E6"
class default
stop 55
end select
select type (val1)
type is (t_int)
if (val1%i /= 8) stop 56
val1%i = 9
class default
stop 57
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 8) stop 58
val1a%i = 9
class default
stop 59
end select
!$OMP END PARALLEL
if (allocated(val1)) stop 60
if (.not. allocated(val1a)) stop 61
if (.not. allocated(val2)) stop 62
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 63
if (val2%str /= "abcdef") stop 64
class default
stop 65
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 66
if (val3%str /= 4_"zyx4") stop 67
val3%str = 4_"AbCd"
class default
stop 68
end select
deallocate(val1a, val2, val3)
end subroutine sub2
subroutine sub3(val1, val1a, val2, val3)
class(*) :: val1, val1a, val2, val3
optional :: val1a
!$OMP PARALLEL firstprivate(val1, val1a, val2, val3)
select type (val1)
type is (t_int)
if (val1%i /= 7) stop 69
val1%i = 8
class default
stop 70
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 7) stop 71
val1a%i = 8
class default
stop 72
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 73
if (val2%str /= "abcdef") stop 74
val2%str = "123456"
class default
stop 75
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 76
if (val3%str /= 4_"zyx4") stop 77
val3%str = 4_"AbCd"
class default
stop 78
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 79
if (val3%str /= 4_"AbCd") stop 80
val3%str = 4_"1ab2"
class default
stop 81
end select
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 82
if (val2%str /= "123456") stop 83
val2%str = "A2C4E6"
class default
stop 84
end select
select type (val1)
type is (t_int)
if (val1%i /= 8) stop 85
val1%i = 9
class default
stop 86
end select
select type (val1a)
type is (t_int)
if (val1a%i /= 8) stop 87
val1a%i = 9
class default
stop 88
end select
!$OMP END PARALLEL
select type (val2)
type is (t_char1)
if (len(val2%str) /= 6) stop 89
if (val2%str /= "abcdef") stop 90
class default
stop 91
end select
select type (val3)
type is (t_char4)
if (len(val3%str) /= 4) stop 92
if (val3%str /= 4_"zyx4") stop 93
val3%str = 4_"AbCd"
class default
stop 94
end select
end subroutine sub3
end program select_type_openmp