123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329 |
- ! { dg-do run }
- ! Don't cycle by default through all options, just test -O0 and -O2,
- ! as this is quite large test.
- ! { dg-skip-if "" { ! run_expensive_tests } { "*" } { "-O0" "-O2" } }
- module m
- type dl
- integer :: a, b
- integer, allocatable :: c(:,:)
- integer :: d, e
- integer, allocatable :: f
- end type
- type dt
- integer :: g
- type (dl), allocatable :: h(:)
- integer :: i
- type (dl) :: j(2, 2)
- type (dl), allocatable :: k
- end type
- contains
- subroutine ver_dl (obj, val, c, cl1, cu1, cl2, cu2, f)
- type (dl), intent (in) :: obj
- integer, intent (in) :: val, cl1, cu1, cl2, cu2
- logical, intent (in) :: c, f
- if ((c .neqv. allocated (obj%c)) .or. (f .neqv. allocated (obj%f))) call abort
- if (c) then
- if (lbound (obj%c, 1) /= cl1 .or. ubound (obj%c, 1) /= cu1) call abort
- if (lbound (obj%c, 2) /= cl2 .or. ubound (obj%c, 2) /= cu2) call abort
- end if
- if (val /= 0) then
- if (obj%a /= val .or. obj%b /= val) call abort
- if (obj%d /= val .or. obj%e /= val) call abort
- if (c) then
- if (any (obj%c /= val)) call abort
- end if
- if (f) then
- if (obj%f /= val) call abort
- end if
- end if
- end subroutine ver_dl
- subroutine ver_dt (obj, val, h, hl, hu, k, c, cl1, cu1, cl2, cu2, f)
- type (dt), intent (in) :: obj
- integer, intent (in) :: val, hl, hu, cl1, cu1, cl2, cu2
- logical, intent (in) :: h, k, c, f
- integer :: i, j
- if ((h .neqv. allocated (obj%h)) .or. (k .neqv. allocated (obj%k))) call abort
- if (h) then
- if (lbound (obj%h, 1) /= hl .or. ubound (obj%h, 1) /= hu) call abort
- do i = hl, hu
- call ver_dl (obj%h(i), val, c, cl1, cu1, cl2, cu2, f)
- end do
- end if
- do i = 1, 2
- do j = 1, 2
- call ver_dl (obj%j(i, j), val, c, cl1, cu1, cl2, cu2, f)
- end do
- end do
- if (k) call ver_dl (obj%k, val, c, cl1, cu1, cl2, cu2, f)
- if (val /= 0) then
- if (obj%g /= val .or. obj%i /= val) call abort
- end if
- end subroutine ver_dt
- subroutine alloc_dl (obj, val, c, cl1, cu1, cl2, cu2, f)
- type (dl), intent (inout) :: obj
- integer, intent (in) :: val, cl1, cu1, cl2, cu2
- logical, intent (in) :: c, f
- if (val /= 0) then
- obj%a = val
- obj%b = val
- obj%d = val
- obj%e = val
- end if
- if (allocated (obj%c)) deallocate (obj%c)
- if (c) then
- allocate (obj%c(cl1:cu1, cl2:cu2))
- if (val /= 0) obj%c = val
- end if
- if (f) then
- if (.not.allocated (obj%f)) allocate (obj%f)
- if (val /= 0) obj%f = val
- else
- if (allocated (obj%f)) deallocate (obj%f)
- end if
- end subroutine alloc_dl
- subroutine alloc_dt (obj, val, h, hl, hu, k, c, cl1, cu1, cl2, cu2, f)
- type (dt), intent (inout) :: obj
- integer, intent (in) :: val, hl, hu, cl1, cu1, cl2, cu2
- logical, intent (in) :: h, k, c, f
- integer :: i, j
- if (val /= 0) then
- obj%g = val
- obj%i = val
- end if
- if (allocated (obj%h)) deallocate (obj%h)
- if (h) then
- allocate (obj%h(hl:hu))
- do i = hl, hu
- call alloc_dl (obj%h(i), val, c, cl1, cu1, cl2, cu2, f)
- end do
- end if
- do i = 1, 2
- do j = 1, 2
- call alloc_dl (obj%j(i, j), val, c, cl1, cu1, cl2, cu2, f)
- end do
- end do
- if (k) then
- if (.not.allocated (obj%k)) allocate (obj%k)
- call alloc_dl (obj%k, val, c, cl1, cu1, cl2, cu2, f)
- else
- if (allocated (obj%k)) deallocate (obj%k)
- end if
- end subroutine alloc_dt
- end module m
- use m
- type (dt) :: y
- call foo (y)
- contains
- subroutine foo (y)
- use m
- type (dt) :: x, y, z(-3:-3,2:3)
- logical, parameter :: F = .false.
- logical, parameter :: T = .true.
- logical :: l
- call ver_dt (x, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (y, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,2), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,3), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- !$omp parallel private (x, y, z)
- call ver_dt (x, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (y, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (y, 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- call ver_dt (y, 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- call ver_dt (z(-3,2), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,3), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,3), 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- call ver_dt (z(-3,3), 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- !$omp end parallel
- call ver_dt (x, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (y, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (y, 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- call ver_dt (z(-3,2), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,3), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,3), 14, T, 3, 4, F, T, 1, 1, 2, 4, T)
- !$omp parallel private (x, y, z)
- call ver_dt (x, 0, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (y, 0, T, 3, 4, F, T, 1, 1, 2, 4, T)
- deallocate (x%h, x%k)
- deallocate (y%h)
- allocate (y%k)
- call ver_dt (z(-3,2), 0, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,3), 0, T, 3, 4, F, T, 1, 1, 2, 4, T)
- deallocate (z(-3,2)%h, z(-3,2)%k)
- deallocate (z(-3,3)%h)
- allocate (z(-3,3)%k)
- !$omp end parallel
- call alloc_dt (x, 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (y, 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- call alloc_dt (z(-3,2), 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (z(-3,3), 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- !$omp parallel firstprivate (x, y, z)
- call ver_dt (x, 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (y, 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- call alloc_dt (y, 4, T, 3, 4, T, T, 1, 1, 2, 4, T)
- call ver_dt (y, 4, T, 3, 4, T, T, 1, 1, 2, 4, T)
- call ver_dt (z(-3,2), 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,3), 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- call alloc_dt (z(-3,3), 4, T, 3, 4, T, T, 1, 1, 2, 4, T)
- call ver_dt (z(-3,3), 4, T, 3, 4, T, T, 1, 1, 2, 4, T)
- !$omp end parallel
- call ver_dt (x, 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (x, 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (y, 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- call alloc_dt (y, 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,2), 5, T, 1, 2, F, T, 2, 3, -2, -2, F)
- call alloc_dt (z(-3,2), 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,3), 15, F, 0, 0, T, T, 2, 2, 2, 2, T)
- call alloc_dt (z(-3,3), 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- !$omp parallel firstprivate (x, y, z)
- call ver_dt (x, 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (x, 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (y, 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (y, 17, T, 1, 2, F, T, 2, 2, 3, 3, F)
- call ver_dt (y, 17, T, 1, 2, F, T, 2, 2, 3, 3, F)
- call ver_dt (z(-3,2), 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,2), 4, T, -3, -1, T, T, -1, -1, 2, 3, T)
- call ver_dt (z(-3,3), 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,3), 17, T, 1, 2, F, T, 2, 2, 3, 3, F)
- call ver_dt (z(-3,3), 17, T, 1, 2, F, T, 2, 2, 3, 3, F)
- !$omp end parallel
- call ver_dt (x, 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (y, 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (y, 18, T, 0, 1, T, T, 0, 1, 0, 1, T)
- call ver_dt (z(-3,2), 4, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,3), 16, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call alloc_dt (z(-3,3), 18, T, 0, 1, T, T, 0, 1, 0, 1, T)
- l = F
- !$omp parallel sections lastprivate (x, y, z) firstprivate (l)
- !$omp section
- if (l) then
- call ver_dt (x, 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (y, 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (z(-3,2), 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (z(-3,3), 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- else
- call ver_dt (x, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (y, 0, T, 0, 1, T, T, 0, 1, 0, 1, T)
- call ver_dt (z(-3,2), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,3), 0, T, 0, 1, T, T, 0, 1, 0, 1, T)
- end if
- l = T
- call alloc_dt (x, 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call ver_dt (x, 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call alloc_dt (y, 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- call ver_dt (y, 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- call alloc_dt (z(-3,2), 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call ver_dt (z(-3,2), 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call alloc_dt (z(-3,3), 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- call ver_dt (z(-3,3), 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- !$omp section
- if (l) then
- call ver_dt (x, 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call ver_dt (y, 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- call ver_dt (z(-3,2), 7, T, 1, 1, T, T, 1, 2, 3, 3, T)
- call ver_dt (z(-3,3), 20, T, 0, 0, F, T, 2, 2, 3, 4, F)
- else
- call ver_dt (x, 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (y, 0, T, 0, 1, T, T, 0, 1, 0, 1, T)
- call ver_dt (z(-3,2), 0, F, 0, 0, F, F, 0, 0, 0, 0, F)
- call ver_dt (z(-3,3), 0, T, 0, 1, T, T, 0, 1, 0, 1, T)
- end if
- l = T
- call alloc_dt (x, 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (x, 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call alloc_dt (y, 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (y, 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call alloc_dt (z(-3,2), 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (z(-3,2), 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call alloc_dt (z(-3,3), 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (z(-3,3), 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- !$omp section
- !$omp end parallel sections
- call ver_dt (x, 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (y, 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (z(-3,2), 9, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (z(-3,3), 21, F, 0, 0, T, T, 1, 2, 3, 4, T)
- !$omp parallel sections lastprivate (x, y, z) firstprivate (l)
- !$omp section
- if (l) then
- call ver_dt (x, 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (y, 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (z(-3,2), 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (z(-3,3), 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- else
- call ver_dt (x, 0, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (y, 0, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (z(-3,2), 0, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (z(-3,3), 0, F, 0, 0, T, T, 1, 2, 3, 4, T)
- end if
- l = T
- call alloc_dt (x, 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (x, 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call alloc_dt (y, 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call ver_dt (y, 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call alloc_dt (z(-3,2), 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (z(-3,2), 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call alloc_dt (z(-3,3), 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call ver_dt (z(-3,3), 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- !$omp section
- if (l) then
- call ver_dt (x, 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (y, 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call ver_dt (z(-3,2), 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (z(-3,3), 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- else
- call ver_dt (x, 0, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (y, 0, F, 0, 0, T, T, 1, 2, 3, 4, T)
- call ver_dt (z(-3,2), 0, T, 1, 1, F, F, 0, 0, 0, 0, T)
- call ver_dt (z(-3,3), 0, F, 0, 0, T, T, 1, 2, 3, 4, T)
- end if
- l = T
- call alloc_dt (x, 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (x, 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call alloc_dt (y, 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (y, 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call alloc_dt (z(-3,2), 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (z(-3,2), 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call alloc_dt (z(-3,3), 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (z(-3,3), 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- !$omp section
- !$omp end parallel sections
- call ver_dt (x, 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (y, 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (z(-3,2), 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (z(-3,3), 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- !$omp parallel private (x, y, z)
- call ver_dt (x, 0, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (y, 0, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (z(-3,2), 0, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (z(-3,3), 0, T, 0, 1, T, T, 2, 2, 2, 2, F)
- !$omp single
- call alloc_dt (x, 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call alloc_dt (y, 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call alloc_dt (z(-3,2), 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call alloc_dt (z(-3,3), 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- !$omp end single copyprivate (x, y, z)
- call ver_dt (x, 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (y, 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- call ver_dt (z(-3,2), 3, F, 0, 0, T, T, 0, 1, 0, 1, F)
- call ver_dt (z(-3,3), 22, T, 5, 5, F, T, 2, 3, 2, 2, T)
- !$omp end parallel
- call ver_dt (x, 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (y, 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- call ver_dt (z(-3,2), 5, F, 0, 0, T, T, -1, -1, -1, -1, T)
- call ver_dt (z(-3,3), 23, T, 0, 1, T, T, 2, 2, 2, 2, F)
- end subroutine foo
- end
|