psblas3-cbind:
cbind/prec/Makefile cbind/prec/psb_c_dprec.h cbind/prec/psb_cprec_cbind_mod.f90 cbind/prec/psb_prec_cbind_mod.f90 cbind/prec/psb_sprec_cbind_mod.f90 cbind/prec/psb_zprec_cbind_mod.f90 Start on PREC.psblas3-mcbind
parent
39c90a8362
commit
fbc41dace7
@ -0,0 +1,118 @@
|
||||
module psb_cprec_cbind_mod
|
||||
|
||||
use iso_c_binding
|
||||
use psb_prec_mod, only : psb_cprec_type
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
|
||||
type, bind(c) :: psb_c_cprec
|
||||
type(c_ptr) :: item = c_null_ptr
|
||||
end type psb_c_cprec
|
||||
|
||||
|
||||
contains
|
||||
|
||||
|
||||
function psb_c_cprecinit(ph,ptype) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
integer(c_int) :: res
|
||||
type(psb_c_cprec) :: ph
|
||||
character(c_char) :: ptype(*)
|
||||
type(psb_cprec_type), pointer :: precp
|
||||
integer :: info
|
||||
character(len=80) :: fptype
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
return
|
||||
end if
|
||||
|
||||
allocate(precp,stat=info)
|
||||
if (info /= 0) return
|
||||
ph%item = c_loc(precp)
|
||||
|
||||
call stringc2f(ptype,fptype)
|
||||
|
||||
call psb_precinit(precp,fptype,info)
|
||||
|
||||
res = min(0,info)
|
||||
return
|
||||
end function psb_c_cprecinit
|
||||
|
||||
|
||||
|
||||
function psb_c_cprecbld(ah,cdh,ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_cspmat) :: ah
|
||||
type(psb_c_cprec) :: ph
|
||||
type(psb_c_descriptor) :: cdh
|
||||
|
||||
type(psb_desc_type), pointer :: descp
|
||||
type(psb_cspmat_type), pointer :: ap
|
||||
type(psb_cprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
!!$ write(*,*) 'Entry: ', psb_c_cd_get_local_rows(cdh)
|
||||
if (c_associated(cdh%item)) then
|
||||
call c_f_pointer(cdh%item,descp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ah%item)) then
|
||||
call c_f_pointer(ah%item,ap)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precbld(ap,descp, precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_cprecbld
|
||||
|
||||
|
||||
function psb_c_cprecfree(ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_cprec) :: ph
|
||||
|
||||
type(psb_cprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precfree(precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_cprecfree
|
||||
|
||||
|
||||
end module psb_cprec_cbind_mod
|
@ -1,3 +1,6 @@
|
||||
module psb_prec_cbind_mod
|
||||
use psb_sprec_cbind_mod
|
||||
use psb_dprec_cbind_mod
|
||||
use psb_cprec_cbind_mod
|
||||
use psb_zprec_cbind_mod
|
||||
end module psb_prec_cbind_mod
|
||||
|
@ -0,0 +1,118 @@
|
||||
module psb_sprec_cbind_mod
|
||||
|
||||
use iso_c_binding
|
||||
use psb_prec_mod, only : psb_sprec_type
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
|
||||
type, bind(c) :: psb_c_sprec
|
||||
type(c_ptr) :: item = c_null_ptr
|
||||
end type psb_c_sprec
|
||||
|
||||
|
||||
contains
|
||||
|
||||
|
||||
function psb_c_sprecinit(ph,ptype) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
integer(c_int) :: res
|
||||
type(psb_c_sprec) :: ph
|
||||
character(c_char) :: ptype(*)
|
||||
type(psb_sprec_type), pointer :: precp
|
||||
integer :: info
|
||||
character(len=80) :: fptype
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
return
|
||||
end if
|
||||
|
||||
allocate(precp,stat=info)
|
||||
if (info /= 0) return
|
||||
ph%item = c_loc(precp)
|
||||
|
||||
call stringc2f(ptype,fptype)
|
||||
|
||||
call psb_precinit(precp,fptype,info)
|
||||
|
||||
res = min(0,info)
|
||||
return
|
||||
end function psb_c_sprecinit
|
||||
|
||||
|
||||
|
||||
function psb_c_sprecbld(ah,cdh,ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_sspmat) :: ah
|
||||
type(psb_c_sprec) :: ph
|
||||
type(psb_c_descriptor) :: cdh
|
||||
|
||||
type(psb_desc_type), pointer :: descp
|
||||
type(psb_sspmat_type), pointer :: ap
|
||||
type(psb_sprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
!!$ write(*,*) 'Entry: ', psb_c_cd_get_local_rows(cdh)
|
||||
if (c_associated(cdh%item)) then
|
||||
call c_f_pointer(cdh%item,descp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ah%item)) then
|
||||
call c_f_pointer(ah%item,ap)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precbld(ap,descp, precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_sprecbld
|
||||
|
||||
|
||||
function psb_c_sprecfree(ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_sprec) :: ph
|
||||
|
||||
type(psb_sprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precfree(precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_sprecfree
|
||||
|
||||
|
||||
end module psb_sprec_cbind_mod
|
@ -0,0 +1,118 @@
|
||||
module psb_zprec_cbind_mod
|
||||
|
||||
use iso_c_binding
|
||||
use psb_prec_mod, only : psb_zprec_type
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
|
||||
type, bind(c) :: psb_c_zprec
|
||||
type(c_ptr) :: item = c_null_ptr
|
||||
end type psb_c_zprec
|
||||
|
||||
|
||||
contains
|
||||
|
||||
|
||||
function psb_c_zprecinit(ph,ptype) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
integer(c_int) :: res
|
||||
type(psb_c_zprec) :: ph
|
||||
character(c_char) :: ptype(*)
|
||||
type(psb_zprec_type), pointer :: precp
|
||||
integer :: info
|
||||
character(len=80) :: fptype
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
return
|
||||
end if
|
||||
|
||||
allocate(precp,stat=info)
|
||||
if (info /= 0) return
|
||||
ph%item = c_loc(precp)
|
||||
|
||||
call stringc2f(ptype,fptype)
|
||||
|
||||
call psb_precinit(precp,fptype,info)
|
||||
|
||||
res = min(0,info)
|
||||
return
|
||||
end function psb_c_zprecinit
|
||||
|
||||
|
||||
|
||||
function psb_c_zprecbld(ah,cdh,ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_zspmat) :: ah
|
||||
type(psb_c_zprec) :: ph
|
||||
type(psb_c_descriptor) :: cdh
|
||||
|
||||
type(psb_desc_type), pointer :: descp
|
||||
type(psb_zspmat_type), pointer :: ap
|
||||
type(psb_zprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
!!$ write(*,*) 'Entry: ', psb_c_cd_get_local_rows(cdh)
|
||||
if (c_associated(cdh%item)) then
|
||||
call c_f_pointer(cdh%item,descp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ah%item)) then
|
||||
call c_f_pointer(ah%item,ap)
|
||||
else
|
||||
return
|
||||
end if
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precbld(ap,descp, precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_zprecbld
|
||||
|
||||
|
||||
function psb_c_zprecfree(ph) bind(c) result(res)
|
||||
use psb_base_mod
|
||||
use psb_prec_mod
|
||||
use psb_objhandle_mod
|
||||
use psb_base_string_cbind_mod
|
||||
implicit none
|
||||
|
||||
integer(c_int) :: res
|
||||
type(psb_c_zprec) :: ph
|
||||
|
||||
type(psb_zprec_type), pointer :: precp
|
||||
|
||||
integer :: info
|
||||
|
||||
res = -1
|
||||
if (c_associated(ph%item)) then
|
||||
call c_f_pointer(ph%item,precp)
|
||||
else
|
||||
return
|
||||
end if
|
||||
|
||||
call psb_precfree(precp, info)
|
||||
|
||||
res = min(info,0)
|
||||
|
||||
end function psb_c_zprecfree
|
||||
|
||||
|
||||
end module psb_zprec_cbind_mod
|
Loading…
Reference in New Issue