From fd82da8d8ade3f7c62b09b0435b952cf4f72841b Mon Sep 17 00:00:00 2001 From: Salvatore Filippone Date: Wed, 4 Dec 2013 11:40:16 +0000 Subject: [PATCH] psblas3: base/serial/impl/psb_c_csr_impl.f90 base/serial/impl/psb_d_csr_impl.f90 base/serial/impl/psb_s_csr_impl.f90 base/serial/impl/psb_z_csr_impl.f90 Fix computation of output space for getrow & friends. --- base/serial/impl/psb_c_csr_impl.f90 | 8 ++++++-- base/serial/impl/psb_d_csr_impl.f90 | 8 ++++++-- base/serial/impl/psb_s_csr_impl.f90 | 8 ++++++-- base/serial/impl/psb_z_csr_impl.f90 | 8 ++++++-- 4 files changed, 24 insertions(+), 8 deletions(-) diff --git a/base/serial/impl/psb_c_csr_impl.f90 b/base/serial/impl/psb_c_csr_impl.f90 index b819b179..fcb7c779 100644 --- a/base/serial/impl/psb_c_csr_impl.f90 +++ b/base/serial/impl/psb_c_csr_impl.f90 @@ -2029,7 +2029,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd,ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl,nrd,ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='csr_getptn' @@ -2039,6 +2039,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return @@ -2209,7 +2211,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd, ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl, nrd, ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='coo_getrow' @@ -2219,6 +2221,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return diff --git a/base/serial/impl/psb_d_csr_impl.f90 b/base/serial/impl/psb_d_csr_impl.f90 index e1d7ce0e..36705709 100644 --- a/base/serial/impl/psb_d_csr_impl.f90 +++ b/base/serial/impl/psb_d_csr_impl.f90 @@ -2029,7 +2029,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd,ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl,nrd,ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='csr_getptn' @@ -2039,6 +2039,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return @@ -2209,7 +2211,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd, ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl, nrd, ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='coo_getrow' @@ -2219,6 +2221,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return diff --git a/base/serial/impl/psb_s_csr_impl.f90 b/base/serial/impl/psb_s_csr_impl.f90 index ba33131c..12a839bc 100644 --- a/base/serial/impl/psb_s_csr_impl.f90 +++ b/base/serial/impl/psb_s_csr_impl.f90 @@ -2029,7 +2029,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd,ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl,nrd,ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='csr_getptn' @@ -2039,6 +2039,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return @@ -2209,7 +2211,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd, ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl, nrd, ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='coo_getrow' @@ -2219,6 +2221,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return diff --git a/base/serial/impl/psb_z_csr_impl.f90 b/base/serial/impl/psb_z_csr_impl.f90 index f5a4de63..42aa115a 100644 --- a/base/serial/impl/psb_z_csr_impl.f90 +++ b/base/serial/impl/psb_z_csr_impl.f90 @@ -2029,7 +2029,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd,ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl,nrd,ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='csr_getptn' @@ -2039,6 +2039,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return @@ -2209,7 +2211,7 @@ contains logical, intent(in) :: append integer(psb_ipk_) :: info integer(psb_ipk_), optional :: iren(:) - integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, nrd, ncd + integer(psb_ipk_) :: nzin_, nza, idx,i,j,k, nzt, irw, lrw, icl,lcl, nrd, ncd integer(psb_ipk_) :: debug_level, debug_unit character(len=20) :: name='coo_getrow' @@ -2219,6 +2221,8 @@ contains nza = a%get_nzeros() irw = imin lrw = min(imax,a%get_nrows()) + icl = jmin + lcl = min(jmax,a%get_ncols()) if (irw<0) then info = psb_err_pivot_too_small_ return