|
|
@ -207,7 +207,6 @@ contains
|
|
|
|
integer(psb_ipk_) :: i
|
|
|
|
integer(psb_ipk_) :: i
|
|
|
|
logical :: owned_
|
|
|
|
logical :: owned_
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
|
|
|
|
|
|
|
|
if (present(mask)) then
|
|
|
|
if (present(mask)) then
|
|
|
|
if (size(mask) < size(idx)) then
|
|
|
|
if (size(mask) < size(idx)) then
|
|
|
|
info = -1
|
|
|
|
info = -1
|
|
|
@ -249,7 +248,6 @@ contains
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
|
|
|
|
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine hash_l2gv1
|
|
|
|
end subroutine hash_l2gv1
|
|
|
|
|
|
|
|
|
|
|
|
subroutine hash_l2gv2(idxin,idxout,idxmap,info,mask,owned)
|
|
|
|
subroutine hash_l2gv2(idxin,idxout,idxmap,info,mask,owned)
|
|
|
@ -334,7 +332,6 @@ contains
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
ctxt = idxmap%get_ctxt()
|
|
|
|
ctxt = idxmap%get_ctxt()
|
|
|
|
call psb_info(ctxt,iam,np)
|
|
|
|
call psb_info(ctxt,iam,np)
|
|
|
|
|
|
|
|
|
|
|
|
if (present(mask)) then
|
|
|
|
if (present(mask)) then
|
|
|
|
if (size(mask) < size(idx)) then
|
|
|
|
if (size(mask) < size(idx)) then
|
|
|
|
info = -1
|
|
|
|
info = -1
|
|
|
@ -437,7 +434,6 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine hash_g2lv1
|
|
|
|
end subroutine hash_g2lv1
|
|
|
|
|
|
|
|
|
|
|
|
subroutine hash_g2lv2(idxin,idxout,idxmap,info,mask,owned)
|
|
|
|
subroutine hash_g2lv2(idxin,idxout,idxmap,info,mask,owned)
|
|
|
@ -460,7 +456,6 @@ contains
|
|
|
|
is = size(idxin)
|
|
|
|
is = size(idxin)
|
|
|
|
im = min(is,size(idxout))
|
|
|
|
im = min(is,size(idxout))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
ctxt = idxmap%get_ctxt()
|
|
|
|
ctxt = idxmap%get_ctxt()
|
|
|
|
call psb_info(ctxt,iam,np)
|
|
|
|
call psb_info(ctxt,iam,np)
|
|
|
@ -567,7 +562,6 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end subroutine hash_g2lv2
|
|
|
|
end subroutine hash_g2lv2
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -688,14 +682,13 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
if (use_openmp) then
|
|
|
|
if (use_openmp) then
|
|
|
|
#ifdef OPENMP
|
|
|
|
#ifdef OPENMP
|
|
|
|
call OMP_init_lock(ins_lck)
|
|
|
|
!call OMP_init_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
if (idxmap%is_bld()) then
|
|
|
|
if (idxmap%is_bld()) then
|
|
|
|
|
|
|
|
|
|
|
|
isLoopValid = .true.
|
|
|
|
isLoopValid = .true.
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
if (present(mask)) then
|
|
|
|
if (present(mask)) then
|
|
|
|
!write(0,*) 'present mask'
|
|
|
|
|
|
|
|
mask_ = mask
|
|
|
|
mask_ = mask
|
|
|
|
else
|
|
|
|
else
|
|
|
|
allocate(mask_(size(idx)))
|
|
|
|
allocate(mask_(size(idx)))
|
|
|
@ -703,13 +696,12 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
if (present(lidx)) then
|
|
|
|
if (present(lidx)) then
|
|
|
|
!write(0,*) 'present lidx'
|
|
|
|
|
|
|
|
if (present(mask)) then
|
|
|
|
if (present(mask)) then
|
|
|
|
|
|
|
|
|
|
|
|
!$OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
! $ OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
!$OMP shared(name,me,is,idx,ins_lck,mask,mglob,idxmap,ncol,nrow,laddsz,lidx) &
|
|
|
|
! $ OMP shared(name,me,is,idx,ins_lck,mask,mglob,idxmap,ncol,nrow,laddsz,lidx) &
|
|
|
|
!$OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
! $ OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
!$OMP reduction(.AND.:isLoopValid)
|
|
|
|
! $ OMP reduction(.AND.:isLoopValid)
|
|
|
|
do i = 1, is
|
|
|
|
do i = 1, is
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
if (mask(i)) then
|
|
|
|
if (mask(i)) then
|
|
|
@ -718,9 +710,9 @@ contains
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
cycle
|
|
|
|
cycle
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
@ -728,7 +720,7 @@ contains
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
if (lip < 0) then
|
|
|
|
if (lip < 0) then
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
@ -772,7 +764,7 @@ contains
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = lip
|
|
|
|
idx(i) = lip
|
|
|
@ -782,17 +774,17 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
!$OMP END PARALLEL DO
|
|
|
|
! $ OMP END PARALLEL DO
|
|
|
|
|
|
|
|
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|
|
|
|
|
|
|
|
|
!$OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
! $ OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
!$OMP shared(name,me,is,idx,ins_lck,mglob,idxmap,ncol,nrow,laddsz,lidx) &
|
|
|
|
! $ OMP shared(name,me,is,idx,ins_lck,mglob,idxmap,ncol,nrow,laddsz,lidx) &
|
|
|
|
!$OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
! $ OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
!$OMP reduction(.AND.:isLoopValid)
|
|
|
|
! $ OMP reduction(.AND.:isLoopValid)
|
|
|
|
do i = 1, is
|
|
|
|
do i = 1, is
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
ip = idx(i)
|
|
|
|
ip = idx(i)
|
|
|
@ -800,9 +792,9 @@ contains
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
cycle
|
|
|
|
cycle
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
@ -810,7 +802,7 @@ contains
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
if (lip < 0) then
|
|
|
|
if (lip < 0) then
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! is often already existing).
|
|
|
|
! is often already existing).
|
|
|
@ -851,26 +843,25 @@ contains
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = lip
|
|
|
|
idx(i) = lip
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
!$OMP END PARALLEL DO
|
|
|
|
! $ OMP END PARALLEL DO
|
|
|
|
|
|
|
|
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else if (.not.present(lidx)) then
|
|
|
|
else if (.not.present(lidx)) then
|
|
|
|
!write(0,*) 'not present lidx'
|
|
|
|
|
|
|
|
if(present(mask)) then
|
|
|
|
if(present(mask)) then
|
|
|
|
!$OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
! $ OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
!$OMP shared(name,me,is,idx,ins_lck,mask,mglob,idxmap,ncol,nrow,laddsz) &
|
|
|
|
! $ OMP shared(name,me,is,idx,ins_lck,mask,mglob,idxmap,ncol,nrow,laddsz) &
|
|
|
|
!$OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
! $ OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
!$OMP reduction(.AND.:isLoopValid)
|
|
|
|
! $ OMP reduction(.AND.:isLoopValid)
|
|
|
|
do i = 1, is
|
|
|
|
do i = 1, is
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
if (mask(i)) then
|
|
|
|
if (mask(i)) then
|
|
|
@ -879,9 +870,9 @@ contains
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
cycle
|
|
|
|
cycle
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
@ -890,7 +881,7 @@ contains
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
|
|
|
|
|
|
|
|
if (lip < 0) then
|
|
|
|
if (lip < 0) then
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! is often already existing, so this lock is relatively rare).
|
|
|
|
! is often already existing, so this lock is relatively rare).
|
|
|
@ -932,7 +923,7 @@ contains
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = lip
|
|
|
|
idx(i) = lip
|
|
|
@ -942,16 +933,16 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
!$OMP END PARALLEL DO
|
|
|
|
! $ OMP END PARALLEL DO
|
|
|
|
|
|
|
|
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|
!$OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
! $ OMP PARALLEL DO default(none) schedule(DYNAMIC) &
|
|
|
|
!$OMP shared(name,me,is,idx,ins_lck,mglob,idxmap,ncol,nrow,laddsz) &
|
|
|
|
! $ OMP shared(name,me,is,idx,ins_lck,mglob,idxmap,ncol,nrow,laddsz) &
|
|
|
|
!$OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
! $ OMP private(i,ip,lip,tlip,nxt,info) &
|
|
|
|
!$OMP reduction(.AND.:isLoopValid)
|
|
|
|
! $ OMP reduction(.AND.:isLoopValid)
|
|
|
|
do i = 1, is
|
|
|
|
do i = 1, is
|
|
|
|
info = 0
|
|
|
|
info = 0
|
|
|
|
ip = idx(i)
|
|
|
|
ip = idx(i)
|
|
|
@ -959,9 +950,9 @@ contains
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
cycle
|
|
|
|
cycle
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
ncol = idxmap%get_lc()
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! At first, we check the index presence in 'idxmap'. Usually
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
|
! the index is found. If it is not found, we repeat the checking,
|
|
|
@ -969,7 +960,7 @@ contains
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
call hash_inner_cnv(ip,lip,idxmap%hashvmask,&
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
& idxmap%hashv,idxmap%glb_lc,ncol)
|
|
|
|
if (lip < 0) then
|
|
|
|
if (lip < 0) then
|
|
|
|
call OMP_set_lock(ins_lck)
|
|
|
|
!call OMP_set_lock(ins_lck)
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! We check again if the index is already in 'idxmap', this
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! time inside a critical region (we assume that the index
|
|
|
|
! is often already existing).
|
|
|
|
! is often already existing).
|
|
|
@ -1011,7 +1002,7 @@ contains
|
|
|
|
else
|
|
|
|
else
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
call OMP_unset_lock(ins_lck)
|
|
|
|
!call OMP_unset_lock(ins_lck)
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
@ -1019,7 +1010,7 @@ contains
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
end do
|
|
|
|
end do
|
|
|
|
!$OMP END PARALLEL DO
|
|
|
|
! $ OMP END PARALLEL DO
|
|
|
|
|
|
|
|
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
if (.not. isLoopValid) then
|
|
|
|
goto 9999
|
|
|
|
goto 9999
|
|
|
@ -1032,7 +1023,7 @@ contains
|
|
|
|
idx = -1
|
|
|
|
idx = -1
|
|
|
|
info = -1
|
|
|
|
info = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
call OMP_destroy_lock(ins_lck)
|
|
|
|
!call OMP_destroy_lock(ins_lck)
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
else if (.not.use_openmp) then
|
|
|
|
else if (.not.use_openmp) then
|
|
|
@ -1182,7 +1173,6 @@ contains
|
|
|
|
idx(i) = -1
|
|
|
|
idx(i) = -1
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
|
|
|
|
|
|
|
|
else if (.not.present(mask)) then
|
|
|
|
else if (.not.present(mask)) then
|
|
|
|
|
|
|
|
|
|
|
|
do i = 1, is
|
|
|
|
do i = 1, is
|
|
|
@ -1227,7 +1217,6 @@ contains
|
|
|
|
info = psb_success_
|
|
|
|
info = psb_success_
|
|
|
|
enddo
|
|
|
|
enddo
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
else
|
|
|
|
else
|
|
|
|