X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/5a897f62cb4a09de7541022ed02344f9a8bf6e53..039807fd1fb02afb72365fe19a6ad620d1bbf4c7:/src/smpi/include/smpi_request.hpp diff --git a/src/smpi/include/smpi_request.hpp b/src/smpi/include/smpi_request.hpp index 226094de7b..5b3962c169 100644 --- a/src/smpi/include/smpi_request.hpp +++ b/src/smpi/include/smpi_request.hpp @@ -1,4 +1,4 @@ -/* Copyright (c) 2010-2021. The SimGrid Team. All rights reserved. */ +/* Copyright (c) 2010-2023. The SimGrid Team. All rights reserved. */ /* This program is free software; you can redistribute it and/or modify it * under the terms of the license (GNU LGPL) which comes with this package. */ @@ -11,8 +11,7 @@ #include -namespace simgrid{ -namespace smpi{ +namespace simgrid::smpi { struct smpi_mpi_generalized_request_funcs_t { MPI_Grequest_query_function *query_fn; @@ -30,16 +29,17 @@ class Request : public F2C { void* old_buf_; /* this is especially for derived datatypes that we need to serialize/unserialize. * It let us know how to unserialize at the end of the communication */ - MPI_Datatype old_type_; + MPI_Datatype type_; size_t size_; - int src_; - int dst_; + aid_t src_; + aid_t dst_; int tag_; // to handle cases where we have an unknown sender // We can't override src, tag, and size, because the request may be reused later - int real_src_; + aid_t real_src_; int real_tag_; bool truncated_; + bool unmatched_types_; size_t real_size_; MPI_Comm comm_; simgrid::kernel::activity::ActivityImplPtr action_; @@ -47,32 +47,36 @@ class Request : public F2C { bool detached_; MPI_Request detached_sender_; int refcount_; + std::vector message_id_; MPI_Op op_; std::unique_ptr generalized_funcs; - MPI_Request* nbc_requests_; - int nbc_requests_size_; + std::vector nbc_requests_; + s4u::Host* src_host_ = nullptr; //!< save SimGrid's source host since it can finished before the recv static bool match_common(MPI_Request req, MPI_Request sender, MPI_Request receiver); + static bool match_types(MPI_Datatype stype, MPI_Datatype rtype); public: Request() = default; - Request(const void* buf, int count, MPI_Datatype datatype, int src, int dst, int tag, MPI_Comm comm, unsigned flags, MPI_Op op = MPI_REPLACE); + Request(const void* buf, int count, MPI_Datatype datatype, aid_t src, aid_t dst, int tag, MPI_Comm comm, + unsigned flags, MPI_Op op = MPI_REPLACE); MPI_Comm comm() const { return comm_; } size_t size() const { return size_; } size_t real_size() const { return real_size_; } - int src() const { return src_; } - int dst() const { return dst_; } + aid_t src() const { return src_; } + aid_t dst() const { return dst_; } int tag() const { return tag_; } int flags() const { return flags_; } bool detached() const { return detached_; } - MPI_Datatype type() const { return old_type_; } + std::string name() const override { return "MPI_Request"; } + MPI_Datatype type() const { return type_; } void print_request(const char* message) const; void start(); void cancel(); void init_buffer(int count); void ref(); - void set_nbc_requests(MPI_Request* reqs, int size); - int get_nbc_requests_size() const; - MPI_Request* get_nbc_requests() const; + void start_nbc_requests(std::vector reqs); + static int finish_nbc_requests(MPI_Request* req, int test); + std::vector get_nbc_requests() const; static void finish_wait(MPI_Request* request, MPI_Status* status); static void unref(MPI_Request* request); static int wait(MPI_Request* req, MPI_Status* status); @@ -124,8 +128,6 @@ public: static Request* f2c(int); }; - -} -} +} // namespace simgrid::smpi #endif