Blame src/mpi/coll/ineighbor_alltoallw/ineighbor_alltoallw_allcomm_linear.c

Packit Service c5cf8c
/* -*- Mode: C; c-basic-offset:4 ; indent-tabs-mode:nil ; -*- */
Packit Service c5cf8c
/*
Packit Service c5cf8c
 *  (C) 2017 by Argonne National Laboratory.
Packit Service c5cf8c
 *      See COPYRIGHT in top-level directory.
Packit Service c5cf8c
 */
Packit Service c5cf8c
Packit Service c5cf8c
#include "mpiimpl.h"
Packit Service c5cf8c
Packit Service c5cf8c
/*
Packit Service c5cf8c
 * Linear
Packit Service c5cf8c
 *
Packit Service c5cf8c
 * Simple send to each outgoing neighbor and recv from each incoming
Packit Service c5cf8c
 * neighbor.
Packit Service c5cf8c
 */
Packit Service c5cf8c
Packit Service c5cf8c
#undef FUNCNAME
Packit Service c5cf8c
#define FUNCNAME MPIR_Ineighbor_alltoallw_sched_allcomm_linear
Packit Service c5cf8c
#undef FCNAME
Packit Service c5cf8c
#define FCNAME MPL_QUOTE(FUNCNAME)
Packit Service c5cf8c
int MPIR_Ineighbor_alltoallw_sched_allcomm_linear(const void *sendbuf, const int sendcounts[],
Packit Service c5cf8c
                                                  const MPI_Aint sdispls[],
Packit Service c5cf8c
                                                  const MPI_Datatype sendtypes[], void *recvbuf,
Packit Service c5cf8c
                                                  const int recvcounts[], const MPI_Aint rdispls[],
Packit Service c5cf8c
                                                  const MPI_Datatype recvtypes[],
Packit Service c5cf8c
                                                  MPIR_Comm * comm_ptr, MPIR_Sched_t s)
Packit Service c5cf8c
{
Packit Service c5cf8c
    int mpi_errno = MPI_SUCCESS;
Packit Service c5cf8c
    int indegree, outdegree, weighted;
Packit Service c5cf8c
    int k, l;
Packit Service c5cf8c
    int *srcs, *dsts;
Packit Service c5cf8c
    MPIR_CHKLMEM_DECL(2);
Packit Service c5cf8c
Packit Service c5cf8c
    mpi_errno = MPIR_Topo_canon_nhb_count(comm_ptr, &indegree, &outdegree, &weighted);
Packit Service c5cf8c
    if (mpi_errno)
Packit Service c5cf8c
        MPIR_ERR_POP(mpi_errno);
Packit Service c5cf8c
    MPIR_CHKLMEM_MALLOC(srcs, int *, indegree * sizeof(int), mpi_errno, "srcs", MPL_MEM_COMM);
Packit Service c5cf8c
    MPIR_CHKLMEM_MALLOC(dsts, int *, outdegree * sizeof(int), mpi_errno, "dsts", MPL_MEM_COMM);
Packit Service c5cf8c
    mpi_errno = MPIR_Topo_canon_nhb(comm_ptr,
Packit Service c5cf8c
                                    indegree, srcs, MPI_UNWEIGHTED,
Packit Service c5cf8c
                                    outdegree, dsts, MPI_UNWEIGHTED);
Packit Service c5cf8c
    if (mpi_errno)
Packit Service c5cf8c
        MPIR_ERR_POP(mpi_errno);
Packit Service c5cf8c
Packit Service c5cf8c
    for (k = 0; k < outdegree; ++k) {
Packit Service c5cf8c
        char *sb;
Packit Service c5cf8c
        MPIR_Ensure_Aint_fits_in_pointer(MPIR_VOID_PTR_CAST_TO_MPI_AINT sendbuf + sdispls[k]);
Packit Service c5cf8c
Packit Service c5cf8c
        sb = ((char *) sendbuf) + sdispls[k];
Packit Service c5cf8c
        mpi_errno = MPIR_Sched_send(sb, sendcounts[k], sendtypes[k], dsts[k], comm_ptr, s);
Packit Service c5cf8c
        if (mpi_errno)
Packit Service c5cf8c
            MPIR_ERR_POP(mpi_errno);
Packit Service c5cf8c
    }
Packit Service c5cf8c
Packit Service c5cf8c
    for (l = 0; l < indegree; ++l) {
Packit Service c5cf8c
        char *rb;
Packit Service c5cf8c
        MPIR_Ensure_Aint_fits_in_pointer(MPIR_VOID_PTR_CAST_TO_MPI_AINT recvbuf + rdispls[l]);
Packit Service c5cf8c
Packit Service c5cf8c
        rb = ((char *) recvbuf) + rdispls[l];
Packit Service c5cf8c
        mpi_errno = MPIR_Sched_recv(rb, recvcounts[l], recvtypes[l], srcs[l], comm_ptr, s);
Packit Service c5cf8c
        if (mpi_errno)
Packit Service c5cf8c
            MPIR_ERR_POP(mpi_errno);
Packit Service c5cf8c
    }
Packit Service c5cf8c
Packit Service c5cf8c
    MPIR_SCHED_BARRIER(s);
Packit Service c5cf8c
Packit Service c5cf8c
  fn_exit:
Packit Service c5cf8c
    MPIR_CHKLMEM_FREEALL();
Packit Service c5cf8c
    return mpi_errno;
Packit Service c5cf8c
  fn_fail:
Packit Service c5cf8c
    goto fn_exit;
Packit Service c5cf8c
}