comm_recv_real_sp Subroutine

private subroutine comm_recv_real_sp(comm, data, source, tag, status)

Blocking receive of a single single-precision real from specified source.

Arguments

Type IntentOptional Attributes Name
type(comm_t), intent(in) :: comm
real(kind=sp), intent(out) :: data
integer(kind=int32), intent(in) :: source
integer(kind=int32), intent(in) :: tag
type(MPI_Status), intent(out), optional :: status

Calls

proc~~comm_recv_real_sp~~CallsGraph proc~comm_recv_real_sp comm_recv_real_sp mpi_recv mpi_recv proc~comm_recv_real_sp->mpi_recv

Called by

proc~~comm_recv_real_sp~~CalledByGraph proc~comm_recv_real_sp comm_recv_real_sp interface~recv recv interface~recv->proc~comm_recv_real_sp

Variables

Type Visibility Attributes Name Initial
integer(kind=int32), private :: ierr

Source Code

   subroutine comm_recv_real_sp(comm, data, source, tag, status)
      !! Blocking receive of a single single-precision real from specified source.
      type(comm_t), intent(in) :: comm
      real(sp), intent(out) :: data
      integer(int32), intent(in) :: source
      integer(int32), intent(in) :: tag
      integer(int32) :: ierr
      type(MPI_Status), intent(out), optional :: status

      if (present(status)) then
         call MPI_Recv(data, 1, MPI_REAL, source, tag, comm%m_comm, status, ierr)
      else
         call MPI_Recv(data, 1, MPI_REAL, source, tag, comm%m_comm, MPI_STATUS_IGNORE, ierr)
      end if
   end subroutine comm_recv_real_sp