From 06357cb166bf5eefc2a43562e735c67c777c7027 Mon Sep 17 00:00:00 2001 From: Jason Wang Date: Mon, 3 Aug 2020 13:17:33 -0400 Subject: [PATCH 1/4] added 3 64-bit MPI_Gatherv implementations --- source/adios2/helper/adiosComm.h | 20 +++ source/adios2/helper/adiosCommDummy.cpp | 64 ++++++++ source/adios2/helper/adiosCommMPI.cpp | 208 ++++++++++++++++++++++++ 3 files changed, 292 insertions(+) diff --git a/source/adios2/helper/adiosComm.h b/source/adios2/helper/adiosComm.h index 750f54dcc4..0cb8fcd967 100644 --- a/source/adios2/helper/adiosComm.h +++ b/source/adios2/helper/adiosComm.h @@ -400,6 +400,26 @@ class CommImpl Datatype recvtype, int root, const std::string &hint) const = 0; + virtual void Gatherv64(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const = 0; + + virtual void Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, Datatype recvtype, + int root, + const std::string &hint) const = 0; + + virtual void Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, Datatype recvtype, + int root, + const std::string &hint) const = 0; + virtual void Reduce(const void *sendbuf, void *recvbuf, size_t count, Datatype datatype, Comm::Op op, int root, const std::string &hint) const = 0; diff --git a/source/adios2/helper/adiosCommDummy.cpp b/source/adios2/helper/adiosCommDummy.cpp index d9c431a096..de7ba1419f 100644 --- a/source/adios2/helper/adiosCommDummy.cpp +++ b/source/adios2/helper/adiosCommDummy.cpp @@ -80,6 +80,23 @@ class CommImplDummy : public CommImpl Datatype recvtype, int root, const std::string &hint) const override; + void Gatherv64(const void *sendbuf, size_t sendcount, Datatype sendtype, + void *recvbuf, const size_t *recvcounts, + const size_t *displs, Datatype recvtype, int root, + const std::string &hint) const override; + + void Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const override; + + void Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const override; + void Reduce(const void *sendbuf, void *recvbuf, size_t count, Datatype datatype, Comm::Op op, int root, const std::string &hint) const override; @@ -211,6 +228,53 @@ void CommImplDummy::Gatherv(const void *sendbuf, size_t sendcount, recvtype, root, hint); } +void CommImplDummy::Gatherv64(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const +{ + const size_t recvcount = recvcounts[0]; + if (recvcount != sendcount) + { + return CommDummyError("send and recv counts differ"); + } + CommImplDummy::Gather(sendbuf, sendcount, sendtype, recvbuf, recvcount, + recvtype, root, hint); +} + +void CommImplDummy::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const +{ + const size_t recvcount = recvcounts[0]; + if (recvcount != sendcount) + { + return CommDummyError("send and recv counts differ"); + } + CommImplDummy::Gather(sendbuf, sendcount, sendtype, recvbuf, recvcount, + recvtype, root, hint); +} + +void CommImplDummy::Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const +{ + const size_t recvcount = recvcounts[0]; + if (recvcount != sendcount) + { + return CommDummyError("send and recv counts differ"); + } + CommImplDummy::Gather(sendbuf, sendcount, sendtype, recvbuf, recvcount, + recvtype, root, hint); +} + void CommImplDummy::Reduce(const void *sendbuf, void *recvbuf, size_t count, Datatype datatype, Comm::Op, int, const std::string &) const diff --git a/source/adios2/helper/adiosCommMPI.cpp b/source/adios2/helper/adiosCommMPI.cpp index 07f33d9abf..ed0f42a31e 100644 --- a/source/adios2/helper/adiosCommMPI.cpp +++ b/source/adios2/helper/adiosCommMPI.cpp @@ -153,6 +153,23 @@ class CommImplMPI : public CommImpl Datatype recvtype, int root, const std::string &hint) const override; + void Gatherv64(const void *sendbuf, size_t sendcount, Datatype sendtype, + void *recvbuf, const size_t *recvcounts, + const size_t *displs, Datatype recvtype, int root, + const std::string &hint) const override; + + void Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const override; + + void Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const override; + void Reduce(const void *sendbuf, void *recvbuf, size_t count, Datatype datatype, Comm::Op op, int root, const std::string &hint) const override; @@ -344,6 +361,197 @@ void CommImplMPI::Gatherv(const void *sendbuf, size_t sendcount, hint); } +void CommImplMPI::Gatherv64(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, const size_t *displs, + Datatype recvtype, int root, + const std::string &hint) const +{ + + const int chunksize = std::numeric_limits::max(); + + int mpiSize; + int mpiRank; + MPI_Comm_size(m_MPIComm, &mpiSize); + MPI_Comm_rank(m_MPIComm, &mpiRank); + + int recvTypeSize; + int sendTypeSize; + + MPI_Type_size(ToMPI(recvtype), &recvTypeSize); + MPI_Type_size(ToMPI(sendtype), &sendTypeSize); + + std::vector requests; + if (mpiRank == root) + { + for (int i = 0; i < mpiSize; ++i) + { + uint64_t recvcount = recvcounts[i]; + while (recvcount > 0) + { + requests.emplace_back(); + if (recvcount > chunksize) + { + MPI_Irecv(reinterpret_cast(recvbuf) + + (displs[i] + recvcounts[i] - recvcount) * + recvTypeSize, + chunksize, ToMPI(recvtype), i, 0, m_MPIComm, + &requests.back()); + recvcount -= chunksize; + } + else + { + MPI_Irecv(reinterpret_cast(recvbuf) + + (displs[i] + recvcounts[i] - recvcount) * + recvTypeSize, + static_cast(recvcount), ToMPI(recvtype), i, + 0, m_MPIComm, &requests.back()); + recvcount = 0; + } + } + } + } + + uint64_t sendcountvar = sendcount; + + while (sendcountvar > 0) + { + requests.emplace_back(); + if (sendcountvar > chunksize) + { + MPI_Isend(reinterpret_cast(sendbuf) + + (sendcount - sendcountvar) * sendTypeSize, + chunksize, ToMPI(sendtype), root, 0, m_MPIComm, + &requests.back()); + sendcountvar -= chunksize; + } + else + { + MPI_Isend(reinterpret_cast(sendbuf) + + (sendcount - sendcountvar) * sendTypeSize, + static_cast(sendcountvar), ToMPI(sendtype), root, 0, + m_MPIComm, &requests.back()); + sendcountvar = 0; + } + } + + MPI_Waitall(requests.size(), requests.data(), MPI_STATUSES_IGNORE); +} + +void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, Datatype recvtype, + int root, const std::string &hint) const +{ + const int chunksize = std::numeric_limits::max(); + + int mpiSize; + int mpiRank; + MPI_Comm_size(m_MPIComm, &mpiSize); + MPI_Comm_rank(m_MPIComm, &mpiRank); + + int recvTypeSize; + int sendTypeSize; + + MPI_Type_size(ToMPI(recvtype), &recvTypeSize); + MPI_Type_size(ToMPI(sendtype), &sendTypeSize); + + uint64_t recvsize = displs[mpiSize - 1] + recvcounts[mpiSize - 1]; + + MPI_Win win; + MPI_Win_create(recvbuf, recvsize * recvTypeSize, recvTypeSize, + MPI_INFO_NULL, m_MPIComm, &win); + MPI_Win_fence(0, win); + + uint64_t sendcountvar = sendcount; + + while (sendcountvar > 0) + { + if (sendcountvar > chunksize) + { + MPI_Put(reinterpret_cast(sendbuf) + + (sendcount - sendcountvar) * sendTypeSize, + chunksize, ToMPI(sendtype), root, + displs[mpiRank] + sendcount - sendcountvar, chunksize, + ToMPI(sendtype), win); + sendcountvar -= chunksize; + } + else + { + MPI_Put(reinterpret_cast(sendbuf) + + (sendcount - sendcountvar) * sendTypeSize, + sendcountvar, ToMPI(sendtype), root, + displs[mpiRank] + sendcount - sendcountvar, sendcountvar, + ToMPI(sendtype), win); + sendcountvar = 0; + } + } + + MPI_Win_fence(0, win); + MPI_Win_free(&win); +} + +void CommImplMPI::Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, + Datatype sendtype, void *recvbuf, + const size_t *recvcounts, + const size_t *displs, Datatype recvtype, + int root, const std::string &hint) const +{ + + const int chunksize = std::numeric_limits::max(); + + int mpiSize; + int mpiRank; + MPI_Comm_size(m_MPIComm, &mpiSize); + MPI_Comm_rank(m_MPIComm, &mpiRank); + + int recvTypeSize; + int sendTypeSize; + + MPI_Type_size(ToMPI(recvtype), &recvTypeSize); + MPI_Type_size(ToMPI(sendtype), &sendTypeSize); + + MPI_Win win; + MPI_Win_create(const_cast(sendbuf), sendcount * sendTypeSize, + sendTypeSize, MPI_INFO_NULL, m_MPIComm, &win); + MPI_Win_fence(0, win); + + if (mpiRank == root) + { + for (int i = 0; i < mpiSize; ++i) + { + uint64_t recvcount = recvcounts[i]; + while (recvcount > 0) + { + if (recvcount > chunksize) + { + MPI_Get(reinterpret_cast(recvbuf) + + (displs[i] + recvcounts[i] - recvcount) * + recvTypeSize, + chunksize, ToMPI(recvtype), i, + recvcounts[i] - recvcount, chunksize, + ToMPI(recvtype), win); + recvcount -= chunksize; + } + else + { + MPI_Get(reinterpret_cast(recvbuf) + + (displs[i] + recvcounts[i] - recvcount) * + recvTypeSize, + static_cast(recvcount), ToMPI(recvtype), i, + recvcounts[i] - recvcount, + static_cast(recvcount), ToMPI(recvtype), win); + recvcount = 0; + } + } + } + } + + MPI_Win_fence(0, win); + MPI_Win_free(&win); +} + void CommImplMPI::Reduce(const void *sendbuf, void *recvbuf, size_t count, Datatype datatype, Comm::Op op, int root, const std::string &hint) const From 06492a14740a257ba2c9c0c17ebee1d8ae3b18f8 Mon Sep 17 00:00:00 2001 From: Jason Wang Date: Mon, 3 Aug 2020 15:37:27 -0400 Subject: [PATCH 2/4] added missing functions --- source/adios2/helper/adiosComm.h | 17 ++++++++++++++ source/adios2/helper/adiosComm.inl | 32 +++++++++++++++++++++++++++ source/adios2/helper/adiosCommMPI.cpp | 4 ---- 3 files changed, 49 insertions(+), 4 deletions(-) diff --git a/source/adios2/helper/adiosComm.h b/source/adios2/helper/adiosComm.h index 0cb8fcd967..3ebf6878b8 100644 --- a/source/adios2/helper/adiosComm.h +++ b/source/adios2/helper/adiosComm.h @@ -218,6 +218,23 @@ class Comm const size_t *recvcounts, const size_t *displs, int root, const std::string &hint = std::string()) const; + template + void Gatherv64(const TSend *sendbuf, size_t sendcount, TRecv *recvbuf, + const size_t *recvcounts, const size_t *displs, int root, + const std::string &hint = std::string()) const; + + template + void Gatherv64OneSidedPush(const TSend *sendbuf, size_t sendcount, + TRecv *recvbuf, const size_t *recvcounts, + const size_t *displs, int root, + const std::string &hint = std::string()) const; + + template + void Gatherv64OneSidedPull(const TSend *sendbuf, size_t sendcount, + TRecv *recvbuf, const size_t *recvcounts, + const size_t *displs, int root, + const std::string &hint = std::string()) const; + template void Reduce(const T *sendbuf, T *recvbuf, size_t count, Op op, int root, const std::string &hint = std::string()) const; diff --git a/source/adios2/helper/adiosComm.inl b/source/adios2/helper/adiosComm.inl index 0ff88d892c..d57d6b6338 100644 --- a/source/adios2/helper/adiosComm.inl +++ b/source/adios2/helper/adiosComm.inl @@ -217,6 +217,38 @@ void Comm::Gatherv(const TSend *sendbuf, size_t sendcount, TRecv *recvbuf, CommImpl::GetDatatype(), root, hint); } +template +void Comm::Gatherv64(const TSend *sendbuf, size_t sendcount, TRecv *recvbuf, + const size_t *recvcounts, const size_t *displs, int root, + const std::string &hint) const +{ + return m_Impl->Gatherv64(sendbuf, sendcount, CommImpl::GetDatatype(), + recvbuf, recvcounts, displs, + CommImpl::GetDatatype(), root, hint); +} + +template +void Comm::Gatherv64OneSidedPush(const TSend *sendbuf, size_t sendcount, + TRecv *recvbuf, const size_t *recvcounts, + const size_t *displs, int root, + const std::string &hint) const +{ + return m_Impl->Gatherv64OneSidedPush( + sendbuf, sendcount, CommImpl::GetDatatype(), recvbuf, recvcounts, + displs, CommImpl::GetDatatype(), root, hint); +} + +template +void Comm::Gatherv64OneSidedPull(const TSend *sendbuf, size_t sendcount, + TRecv *recvbuf, const size_t *recvcounts, + const size_t *displs, int root, + const std::string &hint) const +{ + return m_Impl->Gatherv64OneSidedPush( + sendbuf, sendcount, CommImpl::GetDatatype(), recvbuf, recvcounts, + displs, CommImpl::GetDatatype(), root, hint); +} + template void Comm::Reduce(const T *sendbuf, T *recvbuf, size_t count, Op op, int root, const std::string &hint) const diff --git a/source/adios2/helper/adiosCommMPI.cpp b/source/adios2/helper/adiosCommMPI.cpp index ed0f42a31e..9979546878 100644 --- a/source/adios2/helper/adiosCommMPI.cpp +++ b/source/adios2/helper/adiosCommMPI.cpp @@ -462,7 +462,6 @@ void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, MPI_Win win; MPI_Win_create(recvbuf, recvsize * recvTypeSize, recvTypeSize, MPI_INFO_NULL, m_MPIComm, &win); - MPI_Win_fence(0, win); uint64_t sendcountvar = sendcount; @@ -488,7 +487,6 @@ void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, } } - MPI_Win_fence(0, win); MPI_Win_free(&win); } @@ -515,7 +513,6 @@ void CommImplMPI::Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, MPI_Win win; MPI_Win_create(const_cast(sendbuf), sendcount * sendTypeSize, sendTypeSize, MPI_INFO_NULL, m_MPIComm, &win); - MPI_Win_fence(0, win); if (mpiRank == root) { @@ -548,7 +545,6 @@ void CommImplMPI::Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, } } - MPI_Win_fence(0, win); MPI_Win_free(&win); } From 315e6d1c9b81cc1bf01bd5e1b78989e110e76696 Mon Sep 17 00:00:00 2001 From: Jason Wang Date: Mon, 3 Aug 2020 16:03:08 -0400 Subject: [PATCH 3/4] fixing warnings for windows build --- source/adios2/helper/adiosCommMPI.cpp | 20 +++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/source/adios2/helper/adiosCommMPI.cpp b/source/adios2/helper/adiosCommMPI.cpp index 9979546878..5bb51f6a45 100644 --- a/source/adios2/helper/adiosCommMPI.cpp +++ b/source/adios2/helper/adiosCommMPI.cpp @@ -386,7 +386,7 @@ void CommImplMPI::Gatherv64(const void *sendbuf, size_t sendcount, { for (int i = 0; i < mpiSize; ++i) { - uint64_t recvcount = recvcounts[i]; + size_t recvcount = recvcounts[i]; while (recvcount > 0) { requests.emplace_back(); @@ -412,7 +412,7 @@ void CommImplMPI::Gatherv64(const void *sendbuf, size_t sendcount, } } - uint64_t sendcountvar = sendcount; + size_t sendcountvar = sendcount; while (sendcountvar > 0) { @@ -435,7 +435,8 @@ void CommImplMPI::Gatherv64(const void *sendbuf, size_t sendcount, } } - MPI_Waitall(requests.size(), requests.data(), MPI_STATUSES_IGNORE); + MPI_Waitall(static_cast(requests.size()), requests.data(), + MPI_STATUSES_IGNORE); } void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, @@ -457,13 +458,13 @@ void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, MPI_Type_size(ToMPI(recvtype), &recvTypeSize); MPI_Type_size(ToMPI(sendtype), &sendTypeSize); - uint64_t recvsize = displs[mpiSize - 1] + recvcounts[mpiSize - 1]; + size_t recvsize = displs[mpiSize - 1] + recvcounts[mpiSize - 1]; MPI_Win win; MPI_Win_create(recvbuf, recvsize * recvTypeSize, recvTypeSize, MPI_INFO_NULL, m_MPIComm, &win); - uint64_t sendcountvar = sendcount; + size_t sendcountvar = sendcount; while (sendcountvar > 0) { @@ -480,9 +481,10 @@ void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, { MPI_Put(reinterpret_cast(sendbuf) + (sendcount - sendcountvar) * sendTypeSize, - sendcountvar, ToMPI(sendtype), root, - displs[mpiRank] + sendcount - sendcountvar, sendcountvar, - ToMPI(sendtype), win); + static_cast(sendcountvar), ToMPI(sendtype), root, + static_cast(displs[mpiRank]) + sendcount - + sendcountvar, + sendcountvar, ToMPI(sendtype), win); sendcountvar = 0; } } @@ -518,7 +520,7 @@ void CommImplMPI::Gatherv64OneSidedPull(const void *sendbuf, size_t sendcount, { for (int i = 0; i < mpiSize; ++i) { - uint64_t recvcount = recvcounts[i]; + size_t recvcount = recvcounts[i]; while (recvcount > 0) { if (recvcount > chunksize) From 0bff1ee1896aa9e870f7d044bd8b28dd2dfe766e Mon Sep 17 00:00:00 2001 From: Jason Wang Date: Mon, 3 Aug 2020 16:23:09 -0400 Subject: [PATCH 4/4] fixing more windows warnings --- source/adios2/helper/adiosCommMPI.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/source/adios2/helper/adiosCommMPI.cpp b/source/adios2/helper/adiosCommMPI.cpp index 5bb51f6a45..6eee7e268a 100644 --- a/source/adios2/helper/adiosCommMPI.cpp +++ b/source/adios2/helper/adiosCommMPI.cpp @@ -484,7 +484,7 @@ void CommImplMPI::Gatherv64OneSidedPush(const void *sendbuf, size_t sendcount, static_cast(sendcountvar), ToMPI(sendtype), root, static_cast(displs[mpiRank]) + sendcount - sendcountvar, - sendcountvar, ToMPI(sendtype), win); + static_cast(sendcountvar), ToMPI(sendtype), win); sendcountvar = 0; } }