X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/79affec61e2c9af35fc9d5c5f34c977dde041283..15e30191fd888064abe15d164cd4dd02229fd75d:/src/smpi/mpi/smpi_request.cpp diff --git a/src/smpi/mpi/smpi_request.cpp b/src/smpi/mpi/smpi_request.cpp index d99290b80e..6418c6585f 100644 --- a/src/smpi/mpi/smpi_request.cpp +++ b/src/smpi/mpi/smpi_request.cpp @@ -108,58 +108,49 @@ void Request::unref(MPI_Request* request) } } -int Request::match_recv(void* a, void* b, simgrid::kernel::activity::CommImpl*) +bool Request::match_common(MPI_Request req, MPI_Request sender, MPI_Request receiver) { - MPI_Request ref = static_cast(a); - MPI_Request req = static_cast(b); - XBT_DEBUG("Trying to match a recv of src %d against %d, tag %d against %d, id %d against %d",ref->src_,req->src_, ref->tag_, req->tag_,ref->comm_->id(),req->comm_->id()); - - xbt_assert(ref, "Cannot match recv against null reference"); - xbt_assert(req, "Cannot match recv against null request"); - if((ref->comm_->id()==MPI_UNDEFINED || req->comm_->id() == MPI_UNDEFINED || (ref->comm_->id()==req->comm_->id())) - && ((ref->src_ == MPI_ANY_SOURCE && (ref->comm_->group()->rank(req->src_) != MPI_UNDEFINED)) || req->src_ == ref->src_) - && ((ref->tag_ == MPI_ANY_TAG && req->tag_ >=0) || req->tag_ == ref->tag_)){ - //we match, we can transfer some values - if(ref->src_ == MPI_ANY_SOURCE) - ref->real_src_ = req->src_; - if(ref->tag_ == MPI_ANY_TAG) - ref->real_tag_ = req->tag_; - if(ref->real_size_ < req->real_size_) - ref->truncated_ = true; - if (req->detached_) - ref->detached_sender_=req; //tie the sender to the receiver, as it is detached and has to be freed in the receiver - if(req->cancelled_==0) + xbt_assert(sender, "Cannot match against null sender"); + xbt_assert(receiver, "Cannot match against null receiver"); + XBT_DEBUG("Trying to match %s of sender src %d against %d, tag %d against %d, id %d against %d", + (req == receiver ? "send" : "recv"), sender->src_, receiver->src_, sender->tag_, receiver->tag_, + sender->comm_->id(), receiver->comm_->id()); + + if ((receiver->comm_->id() == MPI_UNDEFINED || sender->comm_->id() == MPI_UNDEFINED || + receiver->comm_->id() == sender->comm_->id()) && + ((receiver->src_ == MPI_ANY_SOURCE && (receiver->comm_->group()->rank(sender->src_) != MPI_UNDEFINED)) || + receiver->src_ == sender->src_) && + ((receiver->tag_ == MPI_ANY_TAG && sender->tag_ >= 0) || receiver->tag_ == sender->tag_)) { + // we match, we can transfer some values + if (receiver->src_ == MPI_ANY_SOURCE) + receiver->real_src_ = sender->src_; + if (receiver->tag_ == MPI_ANY_TAG) + receiver->real_tag_ = sender->tag_; + if (receiver->real_size_ < sender->real_size_) + receiver->truncated_ = true; + if (sender->detached_) + receiver->detached_sender_ = sender; // tie the sender to the receiver, as it is detached and has to be freed in + // the receiver + if (req->cancelled_ == 0) req->cancelled_ = -1; // mark as uncancelable XBT_DEBUG("match succeeded"); - return 1; - }else return 0; + return true; + } + return false; } -int Request::match_send(void* a, void* b, simgrid::kernel::activity::CommImpl*) +bool Request::match_recv(void* a, void* b, simgrid::kernel::activity::CommImpl*) { MPI_Request ref = static_cast(a); MPI_Request req = static_cast(b); - XBT_DEBUG("Trying to match a send of src %d against %d, tag %d against %d, id %d against %d",ref->src_,req->src_, ref->tag_, req->tag_,ref->comm_->id(),req->comm_->id()); - xbt_assert(ref, "Cannot match send against null reference"); - xbt_assert(req, "Cannot match send against null request"); - - if((ref->comm_->id()==MPI_UNDEFINED || req->comm_->id() == MPI_UNDEFINED || (ref->comm_->id()==req->comm_->id())) - && ((req->src_ == MPI_ANY_SOURCE && (req->comm_->group()->rank(ref->src_) != MPI_UNDEFINED)) || req->src_ == ref->src_) - && ((req->tag_ == MPI_ANY_TAG && ref->tag_ >=0)|| req->tag_ == ref->tag_)){ - if(req->src_ == MPI_ANY_SOURCE) - req->real_src_ = ref->src_; - if(req->tag_ == MPI_ANY_TAG) - req->real_tag_ = ref->tag_; - if(req->real_size_ < ref->real_size_) - req->truncated_ = true; - if (ref->detached_) - req->detached_sender_=ref; //tie the sender to the receiver, as it is detached and has to be freed in the receiver - if(req->cancelled_==0) - req->cancelled_ = -1; // mark as uncancelable - XBT_DEBUG("match succeeded"); - return 1; - } else - return 0; + return match_common(req, req, ref); +} + +bool Request::match_send(void* a, void* b, simgrid::kernel::activity::CommImpl*) +{ + MPI_Request ref = static_cast(a); + MPI_Request req = static_cast(b); + return match_common(req, ref, req); } void Request::print_request(const char *message) @@ -168,11 +159,9 @@ void Request::print_request(const char *message) message, this, buf_, size_, src_, dst_, tag_, flags_); } - /* factories, to hide the internal flags from the caller */ MPI_Request Request::bsend_init(const void *buf, int count, MPI_Datatype datatype, int dst, int tag, MPI_Comm comm) { - return new Request(buf == MPI_BOTTOM ? nullptr : buf, count, datatype, simgrid::s4u::this_actor::get_pid(), comm->group()->actor(dst)->get_pid(), tag, comm, MPI_REQ_PERSISTENT | MPI_REQ_SEND | MPI_REQ_PREPARED | MPI_REQ_BSEND); @@ -180,7 +169,6 @@ MPI_Request Request::bsend_init(const void *buf, int count, MPI_Datatype datatyp MPI_Request Request::send_init(const void *buf, int count, MPI_Datatype datatype, int dst, int tag, MPI_Comm comm) { - return new Request(buf == MPI_BOTTOM ? nullptr : buf, count, datatype, simgrid::s4u::this_actor::get_pid(), comm->group()->actor(dst)->get_pid(), tag, comm, MPI_REQ_PERSISTENT | MPI_REQ_SEND | MPI_REQ_PREPARED); @@ -846,7 +834,6 @@ void Request::finish_wait(MPI_Request* request, MPI_Status * status) // FIXME Handle the case of a partial shared malloc. if (((req->flags_ & MPI_REQ_ACCUMULATE) != 0) || (datatype->flags() & DT_FLAG_DERIVED)) { // && (not smpi_is_shared(req->old_buf_))){ - if (not smpi_process()->replaying() && smpi_cfg_privatization() != SmpiPrivStrategies::NONE && static_cast(req->old_buf_) >= smpi_data_exe_start && static_cast(req->old_buf_) < smpi_data_exe_start + smpi_data_exe_size) { @@ -1108,7 +1095,8 @@ int Request::waitsome(int incount, MPI_Request requests[], int *indices, MPI_Sta return count; } -MPI_Request Request::f2c(int id) { +MPI_Request Request::f2c(int id) +{ char key[KEY_SIZE]; if(id==MPI_FORTRAN_REQUEST_NULL) return static_cast(MPI_REQUEST_NULL); @@ -1123,7 +1111,8 @@ void Request::free_f(int id) } } -int Request::get_status(MPI_Request req, int* flag, MPI_Status * status){ +int Request::get_status(MPI_Request req, int* flag, MPI_Status* status) +{ *flag=0; if(req != MPI_REQUEST_NULL && req->action_ != nullptr) { @@ -1150,8 +1139,9 @@ int Request::get_status(MPI_Request req, int* flag, MPI_Status * status){ return MPI_SUCCESS; } -int Request::grequest_start( MPI_Grequest_query_function *query_fn, MPI_Grequest_free_function *free_fn, MPI_Grequest_cancel_function *cancel_fn, void *extra_state, MPI_Request *request){ - +int Request::grequest_start(MPI_Grequest_query_function* query_fn, MPI_Grequest_free_function* free_fn, + MPI_Grequest_cancel_function* cancel_fn, void* extra_state, MPI_Request* request) +{ *request = new Request(); (*request)->flags_ |= MPI_REQ_GENERALIZED; (*request)->flags_ |= MPI_REQ_PERSISTENT; @@ -1166,7 +1156,8 @@ int Request::grequest_start( MPI_Grequest_query_function *query_fn, MPI_Grequest return MPI_SUCCESS; } -int Request::grequest_complete( MPI_Request request){ +int Request::grequest_complete(MPI_Request request) +{ if ((!(request->flags_ & MPI_REQ_GENERALIZED)) || request->generalized_funcs->mutex==NULL) return MPI_ERR_REQUEST; request->generalized_funcs->mutex->lock();