base/modules/psb_const_mod.F90
 base/modules/psb_error_mod.F90
 base/tools/psb_cdins.f90
 base/tools/psb_icdasb.F90

1. New error code to be called from cdasb (if we get there).
2. Fix proper error signal into cdins.
psblas3-type-indexed
Salvatore Filippone 15 years ago
parent 3fc1495f39
commit 1c6b259541

@ -141,6 +141,7 @@ module psb_const_mod
integer, parameter, public :: psb_err_iarray_outside_process_=150 integer, parameter, public :: psb_err_iarray_outside_process_=150
integer, parameter, public :: psb_err_forgot_geall_=290 integer, parameter, public :: psb_err_forgot_geall_=290
integer, parameter, public :: psb_err_forgot_spall_=295 integer, parameter, public :: psb_err_forgot_spall_=295
integer, parameter, public :: psb_err_wrong_ins_=298
integer, parameter, public :: psb_err_iarg_mbeeiarra_i_=300 integer, parameter, public :: psb_err_iarg_mbeeiarra_i_=300
integer, parameter, public :: psb_err_mpi_error_=400 integer, parameter, public :: psb_err_mpi_error_=400
integer, parameter, public :: psb_err_parm_differs_among_procs_=550 integer, parameter, public :: psb_err_parm_differs_among_procs_=550

@ -360,6 +360,8 @@ contains
write (error_unit,'("To call this routine you must first call psb_geall on the same matrix")') write (error_unit,'("To call this routine you must first call psb_geall on the same matrix")')
case(psb_err_forgot_spall_) case(psb_err_forgot_spall_)
write (error_unit,'("To call this routine you must first call psb_spall on the same matrix")') write (error_unit,'("To call this routine you must first call psb_spall on the same matrix")')
case(psb_err_wrong_ins_)
write (0,'("Something went wrong before this call to ",a,", probably in cdins/spins")')r_name
case(psb_err_iarg_mbeeiarra_i_) case(psb_err_iarg_mbeeiarra_i_)
write (error_unit,'("Input argument n. ",i0," must be equal to entry n. ",i0," in array input argument n.",i0)') & write (error_unit,'("Input argument n. ",i0," must be equal to entry n. ",i0," in array input argument n.",i0)') &
& i_e_d(1),i_e_d(4),i_e_d(3) & i_e_d(1),i_e_d(4),i_e_d(3)

@ -120,7 +120,8 @@ subroutine psb_cdinsrc(nz,ia,ja,desc_a,info,ila,jla)
if (present(ila).and.present(jla)) then if (present(ila).and.present(jla)) then
call psi_idx_cnv(nz,ia,ila,desc_a,info,owned=.true.) call psi_idx_cnv(nz,ia,ila,desc_a,info,owned=.true.)
call psb_cdins(nz,ja,desc_a,info,jla=jla,mask=(ila(1:nz)>0)) if (info == psb_success_) &
& call psb_cdins(nz,ja,desc_a,info,jla=jla,mask=(ila(1:nz)>0))
else else
if (present(ila).or.present(jla)) then if (present(ila).or.present(jla)) then
write(0,*) 'Inconsistent call : ',present(ila),present(jla) write(0,*) 'Inconsistent call : ',present(ila),present(jla)
@ -132,7 +133,8 @@ subroutine psb_cdinsrc(nz,ia,ja,desc_a,info,ila,jla)
goto 9999 goto 9999
end if end if
call psi_idx_cnv(nz,ia,ila_,desc_a,info,owned=.true.) call psi_idx_cnv(nz,ia,ila_,desc_a,info,owned=.true.)
call psb_cdins(nz,ja,desc_a,info,mask=(ila_(1:nz)>0)) if (info == psb_success_) &
& call psb_cdins(nz,ja,desc_a,info,mask=(ila_(1:nz)>0))
deallocate(ila_) deallocate(ila_)
end if end if

@ -96,6 +96,15 @@ subroutine psb_icdasb(desc_a,info,ext_hv)
goto 9999 goto 9999
endif endif
info = psb_get_errstatus()
if (info /= psb_success_) then
! Something went wrong in cdins/spins
! signal and exit
info = psb_err_wrong_ins_
call psb_errpush(info,name)
goto 9999
end if
if (present(ext_hv)) then if (present(ext_hv)) then
ext_hv_ = ext_hv ext_hv_ = ext_hv
else else

Loading…
Cancel
Save