Loading [MathJax]/extensions/tex2jax.js
Neko 0.9.99
A portable framework for high-order spectral element flow simulations
All Classes Namespaces Files Functions Variables Typedefs Enumerator Macros Pages
gs_device_shmem Module Reference

Defines GPU aware MPI gather-scatter communication.

Data Types

type  gs_device_shmem_buf_t
 Buffers for non-blocking communication and packing/unpacking. More...
 
type  gs_device_shmem_t
 Gather-scatter communication using device SHMEM. The arrays are indexed per PE like send_pe and @ recv_pe. More...
 

Functions/Subroutines

subroutine gs_device_shmem_buf_init (this, pe_order, dof_stack, mark_dupes)
 
subroutine gs_device_shmem_buf_free (this)
 
subroutine gs_device_shmem_init (this, send_pe, recv_pe)
 Initialise MPI based communication method.
 
subroutine gs_device_shmem_free (this)
 Deallocate MPI based communication method.
 
subroutine gs_device_shmem_nbsend (this, u, n, deps, strm)
 Post non-blocking send operations.
 
subroutine gs_device_shmem_nbrecv (this)
 Post non-blocking receive operations.
 
subroutine gs_device_shmem_nbwait (this, u, n, op, strm)
 Wait for non-blocking operations.
 

Function/Subroutine Documentation

◆ gs_device_shmem_buf_free()

subroutine gs_device_shmem::gs_device_shmem_buf_free ( class(gs_device_shmem_buf_t), intent(inout this)
private

Definition at line 216 of file gs_device_shmem.F90.

Here is the call graph for this function:

◆ gs_device_shmem_buf_init()

subroutine gs_device_shmem::gs_device_shmem_buf_init ( class(gs_device_shmem_buf_t), intent(inout this,
integer, dimension(:), intent(inout), allocatable  pe_order,
type(stack_i4_t), dimension(:), intent(inout), allocatable  dof_stack,
logical, intent(in mark_dupes 
)

Definition at line 139 of file gs_device_shmem.F90.

Here is the call graph for this function:

◆ gs_device_shmem_free()

subroutine gs_device_shmem::gs_device_shmem_free ( class(gs_device_shmem_t), intent(inout this)
private

Definition at line 267 of file gs_device_shmem.F90.

Here is the call graph for this function:

◆ gs_device_shmem_init()

subroutine gs_device_shmem::gs_device_shmem_init ( class(gs_device_shmem_t), intent(inout this,
type(stack_i4_t), intent(inout send_pe,
type(stack_i4_t), intent(inout recv_pe 
)
private

Definition at line 231 of file gs_device_shmem.F90.

Here is the call graph for this function:

◆ gs_device_shmem_nbrecv()

subroutine gs_device_shmem::gs_device_shmem_nbrecv ( class(gs_device_shmem_t), intent(inout this)
private

Definition at line 312 of file gs_device_shmem.F90.

◆ gs_device_shmem_nbsend()

subroutine gs_device_shmem::gs_device_shmem_nbsend ( class(gs_device_shmem_t), intent(inout this,
real(kind=rp), dimension(n), intent(inout u,
integer, intent(in n,
type(c_ptr), intent(inout deps,
type(c_ptr), intent(inout strm 
)
private

Definition at line 289 of file gs_device_shmem.F90.

Here is the call graph for this function:

◆ gs_device_shmem_nbwait()

subroutine gs_device_shmem::gs_device_shmem_nbwait ( class(gs_device_shmem_t), intent(inout this,
real(kind=rp), dimension(n), intent(inout u,
integer, intent(in n,
integer  op,
type(c_ptr), intent(inout strm 
)
private

Definition at line 321 of file gs_device_shmem.F90.

Here is the call graph for this function: