Merge pull request #6782 from ggouaillardet/topic/neighbor_alltoallv
mpi/c: fix param checks in [I]Neighbor_alltoall{v,w}
Этот коммит содержится в:
Коммит
7005e46eed
@ -13,7 +13,7 @@
|
|||||||
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
||||||
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
||||||
* reserved.
|
* reserved.
|
||||||
* Copyright (c) 2014-2018 Research Organization for Information Science
|
* Copyright (c) 2014-2019 Research Organization for Information Science
|
||||||
* and Technology (RIST). All rights reserved.
|
* and Technology (RIST). All rights reserved.
|
||||||
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
||||||
* $COPYRIGHT$
|
* $COPYRIGHT$
|
||||||
@ -101,14 +101,15 @@ int MPI_Ineighbor_alltoallv(const void *sendbuf, const int sendcounts[], const i
|
|||||||
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
||||||
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_TOPOLOGY,
|
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_TOPOLOGY,
|
||||||
FUNC_NAME);
|
FUNC_NAME);
|
||||||
} else if ((NULL == sendcounts) || (NULL == sdispls) ||
|
|
||||||
(NULL == recvcounts) || (NULL == rdispls) ||
|
|
||||||
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
|
||||||
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
if (((0 < outdegree) && ((NULL == sendcounts) || (NULL == sdispls))) ||
|
||||||
|
((0 < indegree) && ((NULL == recvcounts) || (NULL == rdispls))) ||
|
||||||
|
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
||||||
|
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
||||||
|
}
|
||||||
for (i = 0; i < outdegree; ++i) {
|
for (i = 0; i < outdegree; ++i) {
|
||||||
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtype, sendcounts[i]);
|
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtype, sendcounts[i]);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
||||||
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
||||||
* reserved.
|
* reserved.
|
||||||
* Copyright (c) 2014-2018 Research Organization for Information Science
|
* Copyright (c) 2014-2019 Research Organization for Information Science
|
||||||
* and Technology (RIST). All rights reserved.
|
* and Technology (RIST). All rights reserved.
|
||||||
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
||||||
* $COPYRIGHT$
|
* $COPYRIGHT$
|
||||||
@ -101,14 +101,13 @@ int MPI_Ineighbor_alltoallw(const void *sendbuf, const int sendcounts[], const M
|
|||||||
FUNC_NAME);
|
FUNC_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((NULL == sendcounts) || (NULL == sdispls) || (NULL == sendtypes) ||
|
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
||||||
(NULL == recvcounts) || (NULL == rdispls) || (NULL == recvtypes) ||
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
if (((0 < outdegree) && ((NULL == sendcounts) || (NULL == sdispls) || (NULL == sendtypes))) ||
|
||||||
|
((0 < indegree) && ((NULL == recvcounts) || (NULL == rdispls) || (NULL == recvtypes))) ||
|
||||||
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
||||||
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
|
||||||
for (i = 0; i < outdegree; ++i) {
|
for (i = 0; i < outdegree; ++i) {
|
||||||
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtypes[i], sendcounts[i]);
|
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtypes[i], sendcounts[i]);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
||||||
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
||||||
* reserved.
|
* reserved.
|
||||||
* Copyright (c) 2014-2015 Research Organization for Information Science
|
* Copyright (c) 2014-2019 Research Organization for Information Science
|
||||||
* and Technology (RIST). All rights reserved.
|
* and Technology (RIST). All rights reserved.
|
||||||
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
||||||
* $COPYRIGHT$
|
* $COPYRIGHT$
|
||||||
@ -101,14 +101,15 @@ int MPI_Neighbor_alltoallv(const void *sendbuf, const int sendcounts[], const in
|
|||||||
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
||||||
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_COMM,
|
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_COMM,
|
||||||
FUNC_NAME);
|
FUNC_NAME);
|
||||||
} else if ((NULL == sendcounts) || (NULL == sdispls) ||
|
|
||||||
(NULL == recvcounts) || (NULL == rdispls) ||
|
|
||||||
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
|
||||||
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
if (((0 < outdegree) && ((NULL == sendcounts) || (NULL == sdispls))) ||
|
||||||
|
((0 < indegree) && ((NULL == recvcounts) || (NULL == rdispls))) ||
|
||||||
|
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
||||||
|
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
||||||
|
}
|
||||||
for (i = 0; i < outdegree; ++i) {
|
for (i = 0; i < outdegree; ++i) {
|
||||||
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtype, sendcounts[i]);
|
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtype, sendcounts[i]);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
||||||
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
* Copyright (c) 2012-2017 Los Alamos National Security, LLC. All rights
|
||||||
* reserved.
|
* reserved.
|
||||||
* Copyright (c) 2014-2015 Research Organization for Information Science
|
* Copyright (c) 2014-2019 Research Organization for Information Science
|
||||||
* and Technology (RIST). All rights reserved.
|
* and Technology (RIST). All rights reserved.
|
||||||
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
* Copyright (c) 2017 IBM Corporation. All rights reserved.
|
||||||
* $COPYRIGHT$
|
* $COPYRIGHT$
|
||||||
@ -97,14 +97,15 @@ int MPI_Neighbor_alltoallw(const void *sendbuf, const int sendcounts[], const MP
|
|||||||
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
} else if (! OMPI_COMM_IS_TOPO(comm)) {
|
||||||
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_TOPOLOGY,
|
return OMPI_ERRHANDLER_INVOKE(MPI_COMM_WORLD, MPI_ERR_TOPOLOGY,
|
||||||
FUNC_NAME);
|
FUNC_NAME);
|
||||||
} else if ((NULL == sendcounts) || (NULL == sdispls) || (NULL == sendtypes) ||
|
|
||||||
(NULL == recvcounts) || (NULL == rdispls) || (NULL == recvtypes) ||
|
|
||||||
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
|
||||||
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
err = mca_topo_base_neighbor_count (comm, &indegree, &outdegree);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
if (((0 < outdegree) && ((NULL == sendcounts) || (NULL == sdispls) || (NULL == sendtypes))) ||
|
||||||
|
((0 < indegree) && ((NULL == recvcounts) || (NULL == rdispls) || (NULL == recvtypes))) ||
|
||||||
|
MPI_IN_PLACE == sendbuf || MPI_IN_PLACE == recvbuf) {
|
||||||
|
return OMPI_ERRHANDLER_INVOKE(comm, MPI_ERR_ARG, FUNC_NAME);
|
||||||
|
}
|
||||||
for (i = 0; i < outdegree; ++i) {
|
for (i = 0; i < outdegree; ++i) {
|
||||||
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtypes[i], sendcounts[i]);
|
OMPI_CHECK_DATATYPE_FOR_SEND(err, sendtypes[i], sendcounts[i]);
|
||||||
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
OMPI_ERRHANDLER_CHECK(err, comm, err, FUNC_NAME);
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user