Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed
arrows point from an interface to procedures which implement that interface.
This could include the module procedures in a generic interface or the
implementation in a submodule of an interface in a parent module.
Where possible, edges connecting nodes are
given different colours to make them easier to distinguish in
large graphs.
Nodes of different colours represent the following:
Solid arrows point from a procedure to one which it calls. Dashed
arrows point from an interface to procedures which implement that interface.
This could include the module procedures in a generic interface or the
implementation in a submodule of an interface in a parent module.
Where possible, edges connecting nodes are
given different colours to make them easier to distinguish in
large graphs.
Variables
Type
Visibility
Attributes
Name
Initial
integer(kind=int32),
private
::
count
integer(kind=int32),
private
::
ierr
integer,
private
::
stat(MPI_STATUS_SIZE)
Source Code
subroutine comm_recv_real_sp_array(comm,data,source,tag,status)type(comm_t),intent(in)::commreal(sp),allocatable,intent(out)::data(:)integer(int32),intent(in)::sourceinteger(int32),intent(in)::tagtype(MPI_Status)::statusinteger(int32)::countinteger(int32)::ierrinteger::stat(MPI_STATUS_SIZE)! First probe to get message sizecall MPI_Probe(source,tag,comm%m_comm,stat,ierr)call MPI_Get_count(stat,MPI_REAL,count,ierr)! Allocate and receiveallocate(data(count))call MPI_Recv(data,count,MPI_REAL,source,tag,comm%m_comm,stat,ierr)! Convert statusstatus=status_array_to_type(stat)end subroutine comm_recv_real_sp_array