You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
47 lines
1.2 KiB
Fortran
47 lines
1.2 KiB
Fortran
|
|
subroutine psb_d_oacc_mlt_v(x, y, info)
|
|
use psb_d_oacc_vect_mod, psb_protect_name => psb_d_oacc_mlt_v
|
|
|
|
implicit none
|
|
class(psb_d_base_vect_type), intent(inout) :: x
|
|
class(psb_d_vect_oacc), intent(inout) :: y
|
|
integer(psb_ipk_), intent(out) :: info
|
|
|
|
integer(psb_ipk_) :: i, n
|
|
|
|
info = 0
|
|
n = min(x%get_nrows(), y%get_nrows())
|
|
info = 0
|
|
n = min(x%get_nrows(), y%get_nrows())
|
|
select type(xx => x)
|
|
class is (psb_d_vect_oacc)
|
|
if (y%is_host()) call y%sync()
|
|
if (xx%is_host()) call xx%sync()
|
|
call d_inner_oacc_mlt_v(n,xx%v, y%v)
|
|
!!$ !$acc parallel loop
|
|
!!$ do i = 1, n
|
|
!!$ y%v(i) = y%v(i) * xx%v(i)
|
|
!!$ end do
|
|
call y%set_dev()
|
|
class default
|
|
if (xx%is_dev()) call xx%sync()
|
|
if (y%is_dev()) call y%sync()
|
|
do i = 1, n
|
|
y%v(i) = y%v(i) * xx%v(i)
|
|
end do
|
|
call y%set_host()
|
|
end select
|
|
contains
|
|
subroutine d_inner_oacc_mlt_v(n,x, y)
|
|
implicit none
|
|
integer(psb_ipk_), intent(in) :: n
|
|
real(psb_dpk_), intent(inout) :: x(:), y(:)
|
|
|
|
integer(psb_ipk_) :: i
|
|
!$acc parallel loop present(x,y)
|
|
do i = 1, n
|
|
y(i) = (x(i)) * (y(i))
|
|
end do
|
|
end subroutine d_inner_oacc_mlt_v
|
|
end subroutine psb_d_oacc_mlt_v
|