|
|
@ -91,6 +91,7 @@ module mld_c_mumps_solver
|
|
|
|
procedure, pass(sv) :: free => c_mumps_solver_free
|
|
|
|
procedure, pass(sv) :: free => c_mumps_solver_free
|
|
|
|
procedure, pass(sv) :: descr => c_mumps_solver_descr
|
|
|
|
procedure, pass(sv) :: descr => c_mumps_solver_descr
|
|
|
|
procedure, pass(sv) :: sizeof => c_mumps_solver_sizeof
|
|
|
|
procedure, pass(sv) :: sizeof => c_mumps_solver_sizeof
|
|
|
|
|
|
|
|
procedure, pass(sv) :: csetc => c_mumps_solver_csetc
|
|
|
|
procedure, pass(sv) :: cseti => c_mumps_solver_cseti
|
|
|
|
procedure, pass(sv) :: cseti => c_mumps_solver_cseti
|
|
|
|
procedure, pass(sv) :: csetr => c_mumps_solver_csetr
|
|
|
|
procedure, pass(sv) :: csetr => c_mumps_solver_csetr
|
|
|
|
procedure, pass(sv) :: default => c_mumps_solver_default
|
|
|
|
procedure, pass(sv) :: default => c_mumps_solver_default
|
|
|
@ -107,6 +108,7 @@ module mld_c_mumps_solver
|
|
|
|
& c_mumps_solver_free, c_mumps_solver_descr, &
|
|
|
|
& c_mumps_solver_free, c_mumps_solver_descr, &
|
|
|
|
& c_mumps_solver_sizeof, c_mumps_solver_apply_vect,&
|
|
|
|
& c_mumps_solver_sizeof, c_mumps_solver_apply_vect,&
|
|
|
|
& c_mumps_solver_cseti, c_mumps_solver_csetr, &
|
|
|
|
& c_mumps_solver_cseti, c_mumps_solver_csetr, &
|
|
|
|
|
|
|
|
& c_mumps_solver_csetc, &
|
|
|
|
& c_mumps_solver_default, c_mumps_solver_get_fmt, &
|
|
|
|
& c_mumps_solver_default, c_mumps_solver_get_fmt, &
|
|
|
|
& c_mumps_solver_get_id, c_mumps_solver_is_global
|
|
|
|
& c_mumps_solver_get_id, c_mumps_solver_is_global
|
|
|
|
#if defined(HAVE_FINAL)
|
|
|
|
#if defined(HAVE_FINAL)
|
|
|
@ -277,6 +279,45 @@ contains
|
|
|
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
|
|
|
!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
subroutine c_mumps_solver_csetc(sv,what,val,info,idx)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Implicit None
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
! Arguments
|
|
|
|
|
|
|
|
class(mld_c_mumps_solver_type), intent(inout) :: sv
|
|
|
|
|
|
|
|
character(len=*), intent(in) :: what
|
|
|
|
|
|
|
|
character(len=*), intent(in) :: val
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
|
|
|
|
integer(psb_ipk_), intent(in), optional :: idx
|
|
|
|
|
|
|
|
integer(psb_ipk_) :: err_act
|
|
|
|
|
|
|
|
character(len=20) :: name='c_mumps_solver_csetc'
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
info = psb_success_
|
|
|
|
|
|
|
|
call psb_erractionsave(err_act)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
select case(psb_toupper(trim(what)))
|
|
|
|
|
|
|
|
#if defined(HAVE_MUMPS_)
|
|
|
|
|
|
|
|
case('MUMPS_LOC_GLOB')
|
|
|
|
|
|
|
|
sv%ipar(1) = sv%stringval(psb_toupper(trim(val)))
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
case default
|
|
|
|
|
|
|
|
call sv%mld_c_base_solver_type%set(what,val,info,idx=idx)
|
|
|
|
|
|
|
|
end select
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
call psb_erractionrestore(err_act)
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
9999 continue
|
|
|
|
|
|
|
|
call psb_erractionrestore(err_act)
|
|
|
|
|
|
|
|
if (err_act == psb_act_abort_) then
|
|
|
|
|
|
|
|
call psb_error()
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
end subroutine c_mumps_solver_csetc
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
subroutine c_mumps_solver_cseti(sv,what,val,info,idx)
|
|
|
|
subroutine c_mumps_solver_cseti(sv,what,val,info,idx)
|
|
|
|
|
|
|
|
|
|
|
|
Implicit None
|
|
|
|
Implicit None
|
|
|
|