X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/12789d134b3ae0061164cf1658bfdd42abd27574..ab5892145873c4600038ad2561a9800f994e4c35:/src/s4u/s4u_Comm.cpp diff --git a/src/s4u/s4u_Comm.cpp b/src/s4u/s4u_Comm.cpp index b088052cc1..c2dc1f13e9 100644 --- a/src/s4u/s4u_Comm.cpp +++ b/src/s4u/s4u_Comm.cpp @@ -225,7 +225,8 @@ Comm* Comm::cancel() bool Comm::test() { - xbt_assert(state_ == State::INITED || state_ == State::STARTED || state_ == State::FINISHED); + xbt_assert(state_ == State::INITED || state_ == State::STARTED || state_ == State::STARTING || + state_ == State::FINISHED); if (state_ == State::FINISHED) return true; @@ -254,10 +255,27 @@ Actor* Comm::get_sender() const } // namespace s4u } // namespace simgrid /* **************************** Public C interface *************************** */ +int sg_comm_test(sg_comm_t comm) +{ + return comm->test(); +} + +void sg_comm_wait_all(sg_comm_t* comms, size_t count) +{ + std::vector s4u_comms; + for (unsigned int i = 0; i < count; i++) + s4u_comms.emplace_back(comms[i]); + + simgrid::s4u::Comm::wait_all(&s4u_comms); + for (unsigned int i = 0; i < count; i++) + s4u_comms[i]->unref(); +} + int sg_comm_wait_any(sg_comm_t* comms, size_t count) { return sg_comm_wait_any_for(comms, count, -1); } + int sg_comm_wait_any_for(sg_comm_t* comms, size_t count, double timeout) { std::vector s4u_comms;