Introduce submodules, adjust Makefile

oacc_loloum
sfilippone 7 months ago
parent 0707cc0a72
commit 7006665d82

@ -2,6 +2,7 @@ include ../../Make.inc
LIBDIR=../../lib LIBDIR=../../lib
INCDIR=../../include INCDIR=../../include
MODDIR=../../modules MODDIR=../../modules
UP=..
# #
# Compilers and such # Compilers and such
# #
@ -22,6 +23,17 @@ objs: $(OBJS)
lib: objs lib: objs
ar cur ../$(LIBNAME) $(OBJS) ar cur ../$(LIBNAME) $(OBJS)
psb_d_oacc_csr_vect_mv.o psb_d_oacc_csr_inner_vect_sv.o \
psb_d_oacc_csr_csmm.o psb_d_oacc_csr_csmv.o psb_d_oacc_csr_scals.o \
psb_d_oacc_csr_scal.o psb_d_oacc_csr_allocate_mnnz.o \
psb_d_oacc_csr_reallocate_nz.o psb_d_oacc_csr_cp_from_coo.o \
psb_d_oacc_csr_cp_from_fmt.o psb_d_oacc_csr_mv_from_coo.o \
psb_d_oacc_csr_mv_from_fmt.o psb_d_oacc_csr_mold.o: $(UP)/psb_d_oacc_csr_mat_mod.o
psb_d_oacc_mlt_v_2.o psb_d_oacc_mlt_v.o: $(UP)/psb_d_oacc_vect_mod.o
clean: clean:
/bin/rm -f $(OBJS) /bin/rm -f $(OBJS)

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_allocate_mnnz(m, n, a, nz) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_allocate_mnnz_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_allocate_mnnz contains
module subroutine psb_d_oacc_csr_allocate_mnnz(m, n, a, nz)
implicit none implicit none
integer(psb_ipk_), intent(in) :: m, n integer(psb_ipk_), intent(in) :: m, n
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -27,8 +28,8 @@ subroutine psb_d_oacc_csr_allocate_mnnz(m, n, a, nz)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_allocate_mnnz end subroutine psb_d_oacc_csr_allocate_mnnz
end submodule psb_d_oacc_csr_allocate_mnnz_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_cp_from_coo(a, b, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_cp_from_coo_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_cp_from_coo contains
module subroutine psb_d_oacc_csr_cp_from_coo(a, b, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -17,9 +18,9 @@ subroutine psb_d_oacc_csr_cp_from_coo(a, b, info)
return return
9999 continue 9999 continue
info = psb_err_alloc_dealloc_ info = psb_err_alloc_dealloc_
return return
end subroutine psb_d_oacc_csr_cp_from_coo end subroutine psb_d_oacc_csr_cp_from_coo
end submodule psb_d_oacc_csr_cp_from_coo_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_cp_from_fmt(a, b, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_cp_from_fmt_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_cp_from_fmt contains
module subroutine psb_d_oacc_csr_cp_from_fmt(a, b, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -19,5 +20,5 @@ subroutine psb_d_oacc_csr_cp_from_fmt(a, b, info)
!$acc update device(a%val, a%ja, a%irp) !$acc update device(a%val, a%ja, a%irp)
end select end select
end subroutine psb_d_oacc_csr_cp_from_fmt end subroutine psb_d_oacc_csr_cp_from_fmt
end submodule psb_d_oacc_csr_cp_from_fmt_impl

@ -1,8 +1,7 @@
subroutine psb_d_oacc_csr_csmm(alpha, a, x, beta, y, info, trans) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_csmm_impl
use psb_base_mod use psb_base_mod
!use elldev_mod contains
!use psb_vectordev_mod module subroutine psb_d_oacc_csr_csmm(alpha, a, x, beta, y, info, trans)
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_csmm
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
@ -79,8 +78,9 @@ subroutine psb_d_oacc_csr_csmm(alpha, a, x, beta, y, info, trans)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_csmm end subroutine psb_d_oacc_csr_csmm
end submodule psb_d_oacc_csr_csmm_impl

@ -1,8 +1,7 @@
subroutine psb_d_oacc_csr_csmv(alpha, a, x, beta, y, info, trans) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_csmv_impl
use psb_base_mod use psb_base_mod
!use elldev_mod contains
!use psb_vectordev_mod module subroutine psb_d_oacc_csr_csmv(alpha, a, x, beta, y, info, trans)
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_csmv
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
@ -74,8 +73,9 @@ subroutine psb_d_oacc_csr_csmv(alpha, a, x, beta, y, info, trans)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_csmv end subroutine psb_d_oacc_csr_csmv
end submodule psb_d_oacc_csr_csmv_impl

@ -1,9 +1,7 @@
subroutine psb_d_oacc_csr_inner_vect_sv(alpha, a, x, beta, y, info, trans) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_inner_vect_sv_impl
use psb_base_mod use psb_base_mod
! use elldev_mod contains
! use psb_vectordev_mod module subroutine psb_d_oacc_csr_inner_vect_sv(alpha, a, x, beta, y, info, trans)
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_inner_vect_sv
use psb_d_oacc_vect_mod
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
@ -78,7 +76,8 @@ subroutine psb_d_oacc_csr_inner_vect_sv(alpha, a, x, beta, y, info, trans)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_inner_vect_sv end subroutine psb_d_oacc_csr_inner_vect_sv
end submodule psb_d_oacc_csr_inner_vect_sv_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_mold(a, b, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_mold_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_mold contains
module subroutine psb_d_oacc_csr_mold(a, b, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
class(psb_d_base_sparse_mat), intent(inout), allocatable :: b class(psb_d_base_sparse_mat), intent(inout), allocatable :: b
@ -25,9 +26,10 @@ subroutine psb_d_oacc_csr_mold(a, b, info)
end if end if
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_mold end subroutine psb_d_oacc_csr_mold
end submodule psb_d_oacc_csr_mold_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_mv_from_coo(a, b, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_mv_from_coo_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_mv_from_coo contains
module subroutine psb_d_oacc_csr_mv_from_coo(a, b, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -16,9 +17,9 @@ subroutine psb_d_oacc_csr_mv_from_coo(a, b, info)
return return
9999 continue 9999 continue
info = psb_err_alloc_dealloc_ info = psb_err_alloc_dealloc_
return return
end subroutine psb_d_oacc_csr_mv_from_coo end subroutine psb_d_oacc_csr_mv_from_coo
end submodule psb_d_oacc_csr_mv_from_coo_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_mv_from_fmt(a, b, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_mv_from_fmt_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_mv_from_fmt contains
module subroutine psb_d_oacc_csr_mv_from_fmt(a, b, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -19,5 +20,5 @@ subroutine psb_d_oacc_csr_mv_from_fmt(a, b, info)
!$acc update device(a%val, a%ja, a%irp) !$acc update device(a%val, a%ja, a%irp)
end select end select
end subroutine psb_d_oacc_csr_mv_from_fmt end subroutine psb_d_oacc_csr_mv_from_fmt
end submodule psb_d_oacc_csr_mv_from_fmt_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_reallocate_nz(nz, a) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_reallocate_nz_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_reallocate_nz contains
module subroutine psb_d_oacc_csr_reallocate_nz(nz, a)
implicit none implicit none
integer(psb_ipk_), intent(in) :: nz integer(psb_ipk_), intent(in) :: nz
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
@ -20,8 +21,8 @@ subroutine psb_d_oacc_csr_reallocate_nz(nz, a)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_reallocate_nz end subroutine psb_d_oacc_csr_reallocate_nz
end submodule psb_d_oacc_csr_reallocate_nz_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_scal(d, a, info, side) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_scal_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_scal contains
module subroutine psb_d_oacc_csr_scal(d, a, info, side)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
real(psb_dpk_), intent(in) :: d(:) real(psb_dpk_), intent(in) :: d(:)
@ -45,8 +46,8 @@ subroutine psb_d_oacc_csr_scal(d, a, info, side)
call psb_erractionrestore(err_act) call psb_erractionrestore(err_act)
return return
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_scal end subroutine psb_d_oacc_csr_scal
end submodule psb_d_oacc_csr_scal_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_scals(d, a, info) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_scals_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_scals contains
module subroutine psb_d_oacc_csr_scals(d, a, info)
implicit none implicit none
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
real(psb_dpk_), intent(in) :: d real(psb_dpk_), intent(in) :: d
@ -29,4 +30,5 @@ subroutine psb_d_oacc_csr_scals(d, a, info)
9999 call psb_error_handler(err_act) 9999 call psb_error_handler(err_act)
return return
end subroutine psb_d_oacc_csr_scals end subroutine psb_d_oacc_csr_scals
end submodule psb_d_oacc_csr_scals_impl

@ -1,6 +1,7 @@
subroutine psb_d_oacc_csr_vect_mv(alpha, a, x, beta, y, info, trans) submodule (psb_d_oacc_csr_mat_mod) psb_d_oacc_csr_vect_mv_impl
use psb_base_mod use psb_base_mod
use psb_d_oacc_csr_mat_mod, psb_protect_name => psb_d_oacc_csr_vect_mv contains
module subroutine psb_d_oacc_csr_vect_mv(alpha, a, x, beta, y, info, trans)
implicit none implicit none
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
@ -28,7 +29,7 @@ subroutine psb_d_oacc_csr_vect_mv(alpha, a, x, beta, y, info, trans)
call inner_spmv(m, n, alpha, a%val, a%ja, a%irp, x%v, beta, y%v, info) call inner_spmv(m, n, alpha, a%val, a%ja, a%irp, x%v, beta, y%v, info)
call y%set_dev() call y%set_dev()
contains contains
subroutine inner_spmv(m, n, alpha, val, ja, irp, x, beta, y, info) subroutine inner_spmv(m, n, alpha, val, ja, irp, x, beta, y, info)
implicit none implicit none
@ -58,4 +59,5 @@ contains
end do end do
end subroutine inner_spmv end subroutine inner_spmv
end subroutine psb_d_oacc_csr_vect_mv end subroutine psb_d_oacc_csr_vect_mv
end submodule psb_d_oacc_csr_vect_mv_impl

@ -1,6 +1,8 @@
submodule (psb_d_oacc_vect_mod) psb_d_oacc_mlt_v_impl
use psb_string_mod
contains
subroutine d_oacc_mlt_v(x, y, info) module subroutine psb_d_oacc_mlt_v(x, y, info)
use psb_d_oacc_vect_mod, psb_protect_name => d_oacc_mlt_v
implicit none implicit none
class(psb_d_base_vect_type), intent(inout) :: x class(psb_d_base_vect_type), intent(inout) :: x
@ -28,4 +30,5 @@ subroutine d_oacc_mlt_v(x, y, info)
end do end do
call y%set_host() call y%set_host()
end select end select
end subroutine d_oacc_mlt_v end subroutine psb_d_oacc_mlt_v
end submodule psb_d_oacc_mlt_v_impl

@ -1,6 +1,7 @@
subroutine d_oacc_mlt_v_2(alpha, x, y, beta, z, info, conjgx, conjgy) submodule (psb_d_oacc_vect_mod) d_oacc_mlt_v_2_impl
use psb_d_oacc_vect_mod, psb_protect_name => d_oacc_mlt_v_2
use psb_string_mod use psb_string_mod
contains
module subroutine d_oacc_mlt_v_2(alpha, x, y, beta, z, info, conjgx, conjgy)
implicit none implicit none
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
class(psb_d_base_vect_type), intent(inout) :: x class(psb_d_base_vect_type), intent(inout) :: x
@ -49,5 +50,6 @@ subroutine d_oacc_mlt_v_2(alpha, x, y, beta, z, info, conjgx, conjgy)
end do end do
call z%set_host() call z%set_host()
end select end select
end subroutine d_oacc_mlt_v_2 end subroutine d_oacc_mlt_v_2
end submodule d_oacc_mlt_v_2_impl

@ -40,8 +40,7 @@ module psb_d_oacc_csr_mat_mod
end type psb_d_oacc_csr_sparse_mat end type psb_d_oacc_csr_sparse_mat
interface interface
subroutine psb_d_oacc_csr_mold(a,b,info) module subroutine psb_d_oacc_csr_mold(a,b,info)
import :: psb_d_oacc_csr_sparse_mat, psb_d_base_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
class(psb_d_base_sparse_mat), intent(inout), allocatable :: b class(psb_d_base_sparse_mat), intent(inout), allocatable :: b
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -49,8 +48,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_cp_from_fmt(a,b,info) module subroutine psb_d_oacc_csr_cp_from_fmt(a,b,info)
import :: psb_d_oacc_csr_sparse_mat, psb_d_base_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
class(psb_d_base_sparse_mat), intent(in) :: b class(psb_d_base_sparse_mat), intent(in) :: b
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -58,8 +56,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_mv_from_coo(a,b,info) module subroutine psb_d_oacc_csr_mv_from_coo(a,b,info)
import :: psb_d_oacc_csr_sparse_mat, psb_d_coo_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
class(psb_d_coo_sparse_mat), intent(inout) :: b class(psb_d_coo_sparse_mat), intent(inout) :: b
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -67,8 +64,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_mv_from_fmt(a,b,info) module subroutine psb_d_oacc_csr_mv_from_fmt(a,b,info)
import :: psb_d_oacc_csr_sparse_mat, psb_d_base_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
class(psb_d_base_sparse_mat), intent(inout) :: b class(psb_d_base_sparse_mat), intent(inout) :: b
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -76,8 +72,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_vect_mv(alpha, a, x, beta, y, info, trans) module subroutine psb_d_oacc_csr_vect_mv(alpha, a, x, beta, y, info, trans)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_d_base_vect_type, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
class(psb_d_base_vect_type), intent(inout) :: x, y class(psb_d_base_vect_type), intent(inout) :: x, y
@ -87,8 +82,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_inner_vect_sv(alpha, a, x, beta, y, info, trans) module subroutine psb_d_oacc_csr_inner_vect_sv(alpha, a, x, beta, y, info, trans)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_d_base_vect_type, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
class(psb_d_base_vect_type), intent(inout) :: x,y class(psb_d_base_vect_type), intent(inout) :: x,y
@ -98,8 +92,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_csmm(alpha, a, x, beta, y, info, trans) module subroutine psb_d_oacc_csr_csmm(alpha, a, x, beta, y, info, trans)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_d_base_vect_type, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta, x(:,:) real(psb_dpk_), intent(in) :: alpha, beta, x(:,:)
real(psb_dpk_), intent(inout) :: y(:,:) real(psb_dpk_), intent(inout) :: y(:,:)
@ -109,8 +102,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_csmv(alpha, a, x, beta, y, info, trans) module subroutine psb_d_oacc_csr_csmv(alpha, a, x, beta, y, info, trans)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_d_base_vect_type, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(in) :: a class(psb_d_oacc_csr_sparse_mat), intent(in) :: a
real(psb_dpk_), intent(in) :: alpha, beta, x(:) real(psb_dpk_), intent(in) :: alpha, beta, x(:)
real(psb_dpk_), intent(inout) :: y(:) real(psb_dpk_), intent(inout) :: y(:)
@ -120,8 +112,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_scals(d, a, info) module subroutine psb_d_oacc_csr_scals(d, a, info)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
real(psb_dpk_), intent(in) :: d real(psb_dpk_), intent(in) :: d
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -129,8 +120,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_scal(d,a,info,side) module subroutine psb_d_oacc_csr_scal(d,a,info,side)
import :: psb_d_oacc_csr_sparse_mat, psb_dpk_, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
real(psb_dpk_), intent(in) :: d(:) real(psb_dpk_), intent(in) :: d(:)
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
@ -139,16 +129,14 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_reallocate_nz(nz,a) module subroutine psb_d_oacc_csr_reallocate_nz(nz,a)
import :: psb_d_oacc_csr_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
integer(psb_ipk_), intent(in) :: nz integer(psb_ipk_), intent(in) :: nz
end subroutine psb_d_oacc_csr_reallocate_nz end subroutine psb_d_oacc_csr_reallocate_nz
end interface end interface
interface interface
subroutine psb_d_oacc_csr_allocate_mnnz(m,n,a,nz) module subroutine psb_d_oacc_csr_allocate_mnnz(m,n,a,nz)
import :: psb_d_oacc_csr_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
integer(psb_ipk_), intent(in) :: m,n integer(psb_ipk_), intent(in) :: m,n
integer(psb_ipk_), intent(in), optional :: nz integer(psb_ipk_), intent(in), optional :: nz
@ -156,8 +144,7 @@ module psb_d_oacc_csr_mat_mod
end interface end interface
interface interface
subroutine psb_d_oacc_csr_cp_from_coo(a,b,info) module subroutine psb_d_oacc_csr_cp_from_coo(a,b,info)
import :: psb_d_oacc_csr_sparse_mat, psb_d_coo_sparse_mat, psb_ipk_
class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a class(psb_d_oacc_csr_sparse_mat), intent(inout) :: a
class(psb_d_coo_sparse_mat), intent(in) :: b class(psb_d_coo_sparse_mat), intent(in) :: b
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info

@ -49,8 +49,8 @@ module psb_d_oacc_vect_mod
procedure, pass(z) :: abgdxyz => d_oacc_abgdxyz procedure, pass(z) :: abgdxyz => d_oacc_abgdxyz
procedure, pass(y) :: mlt_a => d_oacc_mlt_a procedure, pass(y) :: mlt_a => d_oacc_mlt_a
procedure, pass(z) :: mlt_a_2 => d_oacc_mlt_a_2 procedure, pass(z) :: mlt_a_2 => d_oacc_mlt_a_2
procedure, pass(y) :: mlt_v => d_oacc_mlt_v procedure, pass(y) :: mlt_v => psb_d_oacc_mlt_v
procedure, pass(z) :: mlt_v_2 => d_oacc_mlt_v_2 procedure, pass(z) :: mlt_v_2 => psb_d_oacc_mlt_v_2
procedure, pass(x) :: scal => d_oacc_scal procedure, pass(x) :: scal => d_oacc_scal
procedure, pass(x) :: nrm2 => d_oacc_nrm2 procedure, pass(x) :: nrm2 => d_oacc_nrm2
procedure, pass(x) :: amax => d_oacc_amax procedure, pass(x) :: amax => d_oacc_amax
@ -63,19 +63,17 @@ module psb_d_oacc_vect_mod
real(psb_dpk_), allocatable :: v1(:),v2(:),p(:) real(psb_dpk_), allocatable :: v1(:),v2(:),p(:)
interface interface
subroutine d_oacc_mlt_v(x, y, info) module subroutine psb_d_oacc_mlt_v(x, y, info)
import
implicit none implicit none
class(psb_d_base_vect_type), intent(inout) :: x class(psb_d_base_vect_type), intent(inout) :: x
class(psb_d_vect_oacc), intent(inout) :: y class(psb_d_vect_oacc), intent(inout) :: y
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
end subroutine d_oacc_mlt_v end subroutine psb_d_oacc_mlt_v
end interface end interface
interface interface
subroutine d_oacc_mlt_v_2(alpha, x, y, beta, z, info, conjgx, conjgy) module subroutine psb_d_oacc_mlt_v_2(alpha, x, y, beta, z, info, conjgx, conjgy)
import
implicit none implicit none
real(psb_dpk_), intent(in) :: alpha, beta real(psb_dpk_), intent(in) :: alpha, beta
class(psb_d_base_vect_type), intent(inout) :: x class(psb_d_base_vect_type), intent(inout) :: x
@ -83,7 +81,7 @@ module psb_d_oacc_vect_mod
class(psb_d_vect_oacc), intent(inout) :: z class(psb_d_vect_oacc), intent(inout) :: z
integer(psb_ipk_), intent(out) :: info integer(psb_ipk_), intent(out) :: info
character(len=1), intent(in), optional :: conjgx, conjgy character(len=1), intent(in), optional :: conjgx, conjgy
end subroutine d_oacc_mlt_v_2 end subroutine psb_d_oacc_mlt_v_2
end interface end interface
contains contains

Loading…
Cancel
Save