|
|
@ -10,8 +10,8 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgeall(xh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zgeall(xh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -21,26 +21,26 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
|
|
|
|
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
allocate(xp)
|
|
|
|
allocate(xp)
|
|
|
|
call psb_geall(xp,descp,info)
|
|
|
|
call psb_geall(xp,descp,info)
|
|
|
|
xh%item = c_loc(xp)
|
|
|
|
xh%item = c_loc(xp)
|
|
|
|
res = min(0,info)
|
|
|
|
res = min(0,info)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function psb_c_zgeall
|
|
|
|
end function psb_c_zgeall
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgeasb(xh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zgeasb(xh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -50,27 +50,27 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
|
|
|
|
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_geasb(xp,descp,info)
|
|
|
|
call psb_geasb(xp,descp,info)
|
|
|
|
res = min(0,info)
|
|
|
|
res = min(0,info)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function psb_c_zgeasb
|
|
|
|
end function psb_c_zgeasb
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgefree(xh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zgefree(xh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -80,29 +80,29 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
|
|
|
|
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_gefree(xp,descp,info)
|
|
|
|
call psb_gefree(xp,descp,info)
|
|
|
|
res = min(0,info)
|
|
|
|
res = min(0,info)
|
|
|
|
xh%item = c_null_ptr
|
|
|
|
xh%item = c_null_ptr
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end function psb_c_zgefree
|
|
|
|
end function psb_c_zgefree
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgeins(nz,irw,val,xh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zgeins(nz,irw,val,xh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_lpk_) :: irw(*)
|
|
|
|
integer(psb_c_lpk_) :: irw(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
@ -114,19 +114,19 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: ixb, info
|
|
|
|
integer(psb_c_ipk_) :: ixb, info
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
if (ixb == 1) then
|
|
|
|
if (ixb == 1) then
|
|
|
|
call psb_geins(nz,irw(1:nz),val(1:nz),&
|
|
|
|
call psb_geins(nz,irw(1:nz),val(1:nz),&
|
|
|
|
& xp,descp,info, dupl=psb_dupl_ovwrt_)
|
|
|
|
& xp,descp,info, dupl=psb_dupl_ovwrt_)
|
|
|
|
else
|
|
|
|
else
|
|
|
@ -142,8 +142,8 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgeins_add(nz,irw,val,xh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zgeins_add(nz,irw,val,xh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_lpk_) :: irw(*)
|
|
|
|
integer(psb_c_lpk_) :: irw(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
@ -155,19 +155,19 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: ixb, info
|
|
|
|
integer(psb_c_ipk_) :: ixb, info
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
if (ixb == 1) then
|
|
|
|
if (ixb == 1) then
|
|
|
|
call psb_geins(nz,irw(1:nz),val(1:nz),&
|
|
|
|
call psb_geins(nz,irw(1:nz),val(1:nz),&
|
|
|
|
& xp,descp,info, dupl=psb_dupl_add_)
|
|
|
|
& xp,descp,info, dupl=psb_dupl_add_)
|
|
|
|
else
|
|
|
|
else
|
|
|
@ -182,8 +182,8 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zspall(mh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zspall(mh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -192,13 +192,13 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
allocate(ap)
|
|
|
|
allocate(ap)
|
|
|
|
call psb_spall(ap,descp,info)
|
|
|
|
call psb_spall(ap,descp,info)
|
|
|
@ -211,9 +211,9 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zspasb(mh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zspasb(mh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -222,15 +222,15 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_spasb(ap,descp,info)
|
|
|
|
call psb_spasb(ap,descp,info)
|
|
|
@ -240,9 +240,9 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zspfree(mh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zspfree(mh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
|
|
|
@ -251,15 +251,15 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
integer(psb_c_ipk_) :: info,n
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
call psb_spfree(ap,descp,info)
|
|
|
|
call psb_spfree(ap,descp,info)
|
|
|
@ -276,8 +276,8 @@ contains
|
|
|
|
#ifdef HAVE_LIBRSB
|
|
|
|
#ifdef HAVE_LIBRSB
|
|
|
|
use psb_z_rsb_mat_mod
|
|
|
|
use psb_z_rsb_mat_mod
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_), value :: cdh, mh,upd,dupl
|
|
|
|
integer(psb_c_ipk_), value :: cdh, mh,upd,dupl
|
|
|
|
character(c_char) :: afmt(*)
|
|
|
|
character(c_char) :: afmt(*)
|
|
|
|
integer(psb_c_ipk_) :: info,n, fdupl
|
|
|
|
integer(psb_c_ipk_) :: info,n, fdupl
|
|
|
@ -288,10 +288,10 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
call psb_check_descriptor_handle(cdh,info)
|
|
|
|
call psb_check_descriptor_handle(cdh,info)
|
|
|
|
if (info < 0) return
|
|
|
|
if (info < 0) return
|
|
|
|
call psb_check_double_spmat_handle(mh,info)
|
|
|
|
call psb_check_double_spmat_handle(mh,info)
|
|
|
|
if (info < 0) return
|
|
|
|
if (info < 0) return
|
|
|
|
|
|
|
|
|
|
|
|
call stringc2f(afmt,fafmt)
|
|
|
|
call stringc2f(afmt,fafmt)
|
|
|
|
select case(fafmt)
|
|
|
|
select case(fafmt)
|
|
|
|
#ifdef HAVE_LIBRSB
|
|
|
|
#ifdef HAVE_LIBRSB
|
|
|
@ -303,7 +303,7 @@ contains
|
|
|
|
call psb_spasb(double_spmat_pool(mh)%item,descriptor_pool(cdh)%item,info,&
|
|
|
|
call psb_spasb(double_spmat_pool(mh)%item,descriptor_pool(cdh)%item,info,&
|
|
|
|
& afmt=fafmt,upd=upd,dupl=dupl)
|
|
|
|
& afmt=fafmt,upd=upd,dupl=dupl)
|
|
|
|
end select
|
|
|
|
end select
|
|
|
|
|
|
|
|
|
|
|
|
res = min(0,info)
|
|
|
|
res = min(0,info)
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
return
|
|
|
@ -312,10 +312,10 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zspins(nz,irw,icl,val,mh,cdh) bind(c) result(res)
|
|
|
|
function psb_c_zspins(nz,irw,icl,val,mh,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_ipk_), value :: nz
|
|
|
|
integer(psb_c_lpk_) :: irw(*), icl(*)
|
|
|
|
integer(psb_c_lpk_) :: irw(*), icl(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
|
complex(c_double_complex) :: val(*)
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
@ -325,19 +325,19 @@ contains
|
|
|
|
integer(psb_c_ipk_) :: ixb,info,n
|
|
|
|
integer(psb_c_ipk_) :: ixb,info,n
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
if (ixb == 1) then
|
|
|
|
if (ixb == 1) then
|
|
|
|
call psb_spins(nz,irw(1:nz),icl(1:nz),val(1:nz),ap,descp,info)
|
|
|
|
call psb_spins(nz,irw(1:nz),icl(1:nz),val(1:nz),ap,descp,info)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
call psb_spins(nz,(irw(1:nz)+(1-ixb)),(icl(1:nz)+(1-ixb)),val(1:nz),ap,descp,info)
|
|
|
|
call psb_spins(nz,(irw(1:nz)+(1-ixb)),(icl(1:nz)+(1-ixb)),val(1:nz),ap,descp,info)
|
|
|
@ -349,8 +349,8 @@ contains
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zsprn(mh,cdh,clear) bind(c) result(res)
|
|
|
|
function psb_c_zsprn(mh,cdh,clear) bind(c) result(res)
|
|
|
|
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
implicit none
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
integer(psb_c_ipk_) :: res
|
|
|
|
logical(c_bool), value :: clear
|
|
|
|
logical(c_bool), value :: clear
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_zspmat) :: mh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
@ -358,18 +358,18 @@ contains
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
type(psb_zspmat_type), pointer :: ap
|
|
|
|
type(psb_zspmat_type), pointer :: ap
|
|
|
|
integer(psb_c_ipk_) :: info
|
|
|
|
integer(psb_c_ipk_) :: info
|
|
|
|
logical :: fclear
|
|
|
|
logical :: fclear
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
res = -1
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
if (c_associated(mh%item)) then
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
call c_f_pointer(mh%item,ap)
|
|
|
|
else
|
|
|
|
else
|
|
|
|
return
|
|
|
|
return
|
|
|
|
end if
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
fclear = clear
|
|
|
|
fclear = clear
|
|
|
@ -381,15 +381,15 @@ contains
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ function psb_c_zspprint(mh) bind(c) result(res)
|
|
|
|
!!$ function psb_c_zspprint(mh) bind(c) result(res)
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ implicit none
|
|
|
|
!!$ implicit none
|
|
|
|
!!$ integer(psb_c_ipk_) :: res
|
|
|
|
!!$ integer(psb_c_ipk_) :: res
|
|
|
|
!!$ integer(psb_c_ipk_), value :: mh
|
|
|
|
!!$ integer(psb_c_ipk_), value :: mh
|
|
|
|
!!$ integer(psb_c_ipk_) :: info
|
|
|
|
!!$ integer(psb_c_ipk_) :: info
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ res = -1
|
|
|
|
!!$ res = -1
|
|
|
|
!!$ call psb_check_double_spmat_handle(mh,info)
|
|
|
|
!!$ call psb_check_double_spmat_handle(mh,info)
|
|
|
|
!!$ if (info < 0) return
|
|
|
|
!!$ if (info < 0) return
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
|
!!$ call psb_csprt(0,double_spmat_pool(mh)%item,head='Debug mat')
|
|
|
|
!!$ call psb_csprt(0,double_spmat_pool(mh)%item,head='Debug mat')
|
|
|
|
!!$
|
|
|
|
!!$
|
|
|
@ -398,6 +398,39 @@ contains
|
|
|
|
!!$ return
|
|
|
|
!!$ return
|
|
|
|
!!$ end function psb_c_zspprint
|
|
|
|
!!$ end function psb_c_zspprint
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function psb_c_zgetelem(xh,index,cdh) bind(c) result(res)
|
|
|
|
|
|
|
|
implicit none
|
|
|
|
|
|
|
|
|
|
|
|
end module psb_z_tools_cbind_mod
|
|
|
|
type(psb_c_zvector) :: xh
|
|
|
|
|
|
|
|
integer(psb_c_lpk_), value :: index
|
|
|
|
|
|
|
|
type(psb_c_descriptor) :: cdh
|
|
|
|
|
|
|
|
complex(c_double_complex) :: res
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
type(psb_z_vect_type), pointer :: xp
|
|
|
|
|
|
|
|
type(psb_desc_type), pointer :: descp
|
|
|
|
|
|
|
|
integer(psb_c_ipk_) :: info, ixb
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
res = -1
|
|
|
|
|
|
|
|
if (c_associated(cdh%item)) then
|
|
|
|
|
|
|
|
call c_f_pointer(cdh%item,descp)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
if (c_associated(xh%item)) then
|
|
|
|
|
|
|
|
call c_f_pointer(xh%item,xp)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
ixb = psb_c_get_index_base()
|
|
|
|
|
|
|
|
if (ixb == 1) then
|
|
|
|
|
|
|
|
res = psb_getelem(xp,index,descp,info)
|
|
|
|
|
|
|
|
else
|
|
|
|
|
|
|
|
res = psb_getelem(xp,index+(1-ixb),descp,info)
|
|
|
|
|
|
|
|
end if
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end function psb_c_zgetelem
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
end module psb_z_tools_cbind_mod
|
|
|
|