Fix CRITICAL in LIST%G2L_INS

omp-threadsafe
sfilippone 2 years ago
parent 5a5712b4f0
commit 6ba7d93159

@ -500,20 +500,38 @@ contains
if (present(lidx)) then if (present(lidx)) then
if (present(mask)) then if (present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if (mask(i)) then if (mask(i)) then
if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idx(i)) ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then if (ix < 0) then
#if defined(OPENMP)
!$OMP CRITICAL(LISTINS)
ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4 info = -4
return else
idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix
end if end if
end if
!$OMP END CRITICAL(LISTINS)
#else
ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4
else
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idx(i) idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix idxmap%glob_to_loc(idx(i)) = ix
end if end if
#endif
end if
idx(i) = ix idx(i) = ix
else else
idx(i) = -1 idx(i) = -1
@ -524,19 +542,38 @@ contains
else if (.not.present(mask)) then else if (.not.present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idx(i)) ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then if (ix < 0) then
#if defined(OPENMP)
!$OMP CRITICAL(LISTINS)
ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4 info = -4
return else
idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix
end if
end if end if
!$OMP END CRITICAL(LISTINS)
#else
ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4
else
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idx(i) idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix idxmap%glob_to_loc(idx(i)) = ix
end if end if
#endif
end if
idx(i) = ix idx(i) = ix
else else
idx(i) = -1 idx(i) = -1
@ -548,20 +585,38 @@ contains
if (present(mask)) then if (present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if (mask(i)) then if (mask(i)) then
if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idx(i)) ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then if (ix < 0) then
#if defined(OPENMP)
!$OMP CRITICAL(LISTINS)
ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then if (info /= 0) then
info = -4 info = -4
return else
idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix
end if
end if end if
!$OMP END CRITICAL(LISTINS)
#else
ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then
info = -4
else
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idx(i) idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix idxmap%glob_to_loc(idx(i)) = ix
end if end if
#endif
end if
idx(i) = ix idx(i) = ix
else else
idx(i) = -1 idx(i) = -1
@ -572,19 +627,37 @@ contains
else if (.not.present(mask)) then else if (.not.present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then if ((1<= idx(i)).and.(idx(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idx(i)) ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then if (ix < 0) then
#if defined(OPENMP)
!$OMP CRITICAL(LISTINS)
ix = idxmap%glob_to_loc(idx(i))
if (ix < 0) then
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then if (info /= 0) then
info = -4 info = -4
return else
idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix
end if
end if end if
!$OMP END CRITICAL(LISTINS)
#else
ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then
info = -4
else
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idx(i) idxmap%loc_to_glob(ix) = idx(i)
idxmap%glob_to_loc(idx(i)) = ix idxmap%glob_to_loc(idx(i)) = ix
end if end if
#endif
end if
idx(i) = ix idx(i) = ix
else else
idx(i) = -1 idx(i) = -1
@ -640,6 +713,7 @@ contains
if (present(lidx)) then if (present(lidx)) then
if (present(mask)) then if (present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if (mask(i)) then if (mask(i)) then
if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idxin(i)) ix = idxmap%glob_to_loc(idxin(i))
@ -650,22 +724,25 @@ contains
if (ix < 0) then if (ix < 0) then
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) info = -4 if (info /= 0) then
info = -4
else
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if end if
end if
!$OMP END CRITICAL(LISTINS) !$OMP END CRITICAL(LISTINS)
#else #else
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4 info = -4
return else
end if
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if
#endif #endif
end if end if
idxout(i) = ix idxout(i) = ix
@ -678,6 +755,7 @@ contains
else if (.not.present(mask)) then else if (.not.present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idxin(i)) ix = idxmap%glob_to_loc(idxin(i))
if (ix < 0) then if (ix < 0) then
@ -687,22 +765,25 @@ contains
if (ix < 0) then if (ix < 0) then
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) info = -4 if (info /= 0) then
info = -4
else
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if end if
end if
!$OMP END CRITICAL(LISTINS) !$OMP END CRITICAL(LISTINS)
#else #else
ix = lidx(i) ix = lidx(i)
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if ((ix <= idxmap%local_rows).or.(info /= 0)) then if ((ix <= idxmap%local_rows).or.(info /= 0)) then
info = -4 info = -4
return else
end if
idxmap%local_cols = max(ix,idxmap%local_cols) idxmap%local_cols = max(ix,idxmap%local_cols)
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if
#endif #endif
end if end if
idxout(i) = ix idxout(i) = ix
@ -716,6 +797,7 @@ contains
if (present(mask)) then if (present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if (mask(i)) then if (mask(i)) then
if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idxin(i)) ix = idxmap%glob_to_loc(idxin(i))
@ -726,22 +808,25 @@ contains
if (ix < 0) then if (ix < 0) then
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) info = -4 if (info /= 0) then
info = -4
else
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if end if
end if
!$OMP END CRITICAL(LISTINS) !$OMP END CRITICAL(LISTINS)
#else #else
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then if (info /= 0) then
info = -4 info = -4
return else
end if
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if
#endif #endif
end if end if
idxout(i) = ix idxout(i) = ix
@ -754,6 +839,7 @@ contains
else if (.not.present(mask)) then else if (.not.present(mask)) then
do i=1, is do i=1, is
if (info /= 0) cycle
if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then if ((1<= idxin(i)).and.(idxin(i) <= idxmap%global_rows)) then
ix = idxmap%glob_to_loc(idxin(i)) ix = idxmap%glob_to_loc(idxin(i))
if (ix < 0) then if (ix < 0) then
@ -763,22 +849,25 @@ contains
if (ix < 0) then if (ix < 0) then
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) info = -4 if (info /= 0) then
info = -4
else
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if end if
end if
!$OMP END CRITICAL(LISTINS) !$OMP END CRITICAL(LISTINS)
#else #else
ix = idxmap%local_cols + 1 ix = idxmap%local_cols + 1
call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz) call psb_ensure_size(ix,idxmap%loc_to_glob,info,addsz=laddsz)
if (info /= 0) then if (info /= 0) then
info = -4 info = -4
return else
end if
idxmap%local_cols = ix idxmap%local_cols = ix
idxmap%loc_to_glob(ix) = idxin(i) idxmap%loc_to_glob(ix) = idxin(i)
idxmap%glob_to_loc(idxin(i)) = ix idxmap%glob_to_loc(idxin(i)) = ix
end if
#endif #endif
end if end if
idxout(i) = ix idxout(i) = ix

Loading…
Cancel
Save