From d315a49a95268e35e6ce31cc86f757c5e6834580 Mon Sep 17 00:00:00 2001 From: Salvatore Filippone Date: Wed, 30 Apr 2008 08:38:42 +0000 Subject: [PATCH] psblas2-dev: base/serial/psb_dspcnv.f90 base/serial/psb_zspcnv.f90 Final fix for in-place path. --- base/serial/psb_dspcnv.f90 | 24 ++++++++++++++++-------- base/serial/psb_zspcnv.f90 | 24 ++++++++++++++++-------- 2 files changed, 32 insertions(+), 16 deletions(-) diff --git a/base/serial/psb_dspcnv.f90 b/base/serial/psb_dspcnv.f90 index f31ef0a4..82a807a6 100644 --- a/base/serial/psb_dspcnv.f90 +++ b/base/serial/psb_dspcnv.f90 @@ -408,6 +408,7 @@ subroutine psb_dspcnv1(a, info, afmt, upd, dupl) integer :: upd_, dupl_ integer :: debug_level, debug_unit character(len=20) :: name, ch_err + logical :: inplace info = 0 int_err(1)=0 @@ -456,6 +457,7 @@ subroutine psb_dspcnv1(a, info, afmt, upd, dupl) if (debug_level >= psb_debug_serial_) & & write(debug_unit,*) trim(name),& & ': Update:',upd_,psb_upd_srch_,psb_upd_perm_ + inplace = .false. if (upd_ == psb_upd_srch_) then if (present(afmt)) then select case (psb_tolower(a%fida)) @@ -463,26 +465,32 @@ subroutine psb_dspcnv1(a, info, afmt, upd, dupl) select case(psb_tolower(afmt)) case('coo') call psb_fixcoo(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. case('csr') call psb_ipcoo2csr(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. case('csc') call psb_ipcoo2csc(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. end select case('csr') select case(psb_tolower(afmt)) case('coo') call psb_ipcsr2coo(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. end select end select end if + if (inplace) then + if (info == 0) call psb_sp_trim(a,info) + if (info /= 0) then + info=4010 + ch_err='inplace cnv' + call psb_errpush(info,name,a_err=ch_err) + goto 9999 + endif + goto 9998 + end if end if call psb_sp_clone(a,atemp,info) diff --git a/base/serial/psb_zspcnv.f90 b/base/serial/psb_zspcnv.f90 index 366385b8..aa37094a 100644 --- a/base/serial/psb_zspcnv.f90 +++ b/base/serial/psb_zspcnv.f90 @@ -408,6 +408,7 @@ subroutine psb_zspcnv1(a, info, afmt, upd, dupl) integer :: upd_, dupl_ integer :: debug_level, debug_unit character(len=20) :: name, ch_err + logical :: inplace info = 0 int_err(1)=0 @@ -456,6 +457,7 @@ subroutine psb_zspcnv1(a, info, afmt, upd, dupl) if (debug_level >= psb_debug_serial_) & & write(debug_unit,*) trim(name),& & ': Update:',upd_,psb_upd_srch_,psb_upd_perm_ + inplace = .false. if (upd_ == psb_upd_srch_) then if (present(afmt)) then select case (psb_tolower(a%fida)) @@ -463,26 +465,32 @@ subroutine psb_zspcnv1(a, info, afmt, upd, dupl) select case(psb_tolower(afmt)) case('coo') call psb_fixcoo(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. case('csr') call psb_ipcoo2csr(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. case('csc') call psb_ipcoo2csc(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. end select case('csr') select case(psb_tolower(afmt)) case('coo') call psb_ipcsr2coo(a,info) - call psb_sp_trim(a,info) - goto 9998 + inplace = .true. end select end select end if + if (inplace) then + if (info == 0) call psb_sp_trim(a,info) + if (info /= 0) then + info=4010 + ch_err='inplace cnv' + call psb_errpush(info,name,a_err=ch_err) + goto 9999 + endif + goto 9998 + end if end if call psb_sp_clone(a,atemp,info)