11 #include <unordered_map>
14 #include <ucp/api/ucp.h>
16 #include <ucxx/typedefs.h>
21 class InflightRequests;
39 ucp_ep_h
_ep{
nullptr};
65 std::shared_ptr<RequestAm> request,
66 std::shared_ptr<Buffer> buffer,
68 std::vector<std::byte> userHeader = {});
89 void callback(
void* request, ucs_status_t status);
92 typedef std::unordered_map<ucp_ep_h, std::queue<std::shared_ptr<RequestAm>>> AmPoolType;
93 typedef std::map<std::shared_ptr<RequestAm>,
94 std::shared_ptr<RecvAmMessage>,
95 std::owner_less<std::shared_ptr<RequestAm>>>
98 typedef std::unordered_map<AmReceiverCallbackIdType, AmReceiverCallbackType>
99 AmReceiverCallbackMapType;
100 typedef std::unordered_map<AmReceiverCallbackOwnerType, AmReceiverCallbackMapType>
101 AmReceiverCallbackOwnerMapType;
118 AmReceiverCallbackOwnerMapType
122 std::function<void(std::shared_ptr<Request>)>
124 std::unordered_map<ucs_memory_type_t, AmAllocatorType>
Active Message data owned by a ucxx::Worker.
Definition: request_am.h:110
RecvAmMessageMapType _recvAmMessageMap
The active messages waiting to be handled by callback.
Definition: request_am.h:117
AmReceiverCallbackOwnerMapType _receiverCallbacks
Definition: request_am.h:119
AmPoolType _recvPool
The pool of completed receive requests (waiting for user request)
Definition: request_am.h:114
std::unordered_map< ucs_memory_type_t, AmAllocatorType > _allocators
Default and user-defined active message allocators.
Definition: request_am.h:125
std::string _ownerString
The owner string used for logging.
Definition: request_am.h:113
std::weak_ptr< Worker > _worker
The worker to which the Active Message callback belongs.
Definition: request_am.h:112
std::mutex _mutex
Mutex to provide access to pools/maps.
Definition: request_am.h:121
AmPoolType _recvWait
The pool of user receive requests (waiting for message arrival)
Definition: request_am.h:115
std::function< void(std::shared_ptr< Request >)> _registerInflightRequest
Worker function to register inflight requests with.
Definition: request_am.h:123
Handle receiving of a ucxx::RequestAm.
Definition: request_am.h:36
ucp_ep_h _ep
Handle containing address of the reply endpoint.
Definition: request_am.h:39
void callback(void *request, ucs_status_t status)
Execute the ucxx::Request::callback().
std::shared_ptr< Buffer > _buffer
Buffer containing the received data.
Definition: request_am.h:42
RecvAmMessage(internal::AmData *amData, ucp_ep_h ep, std::shared_ptr< RequestAm > request, std::shared_ptr< Buffer > buffer, AmReceiverCallbackType receiverCallback=AmReceiverCallbackType(), std::vector< std::byte > userHeader={})
Constructor of ucxx::RecvAmMessage.
void setUcpRequest(void *request)
Set the UCP request.
internal::AmData * _amData
Active messages data.
Definition: request_am.h:38
std::shared_ptr< RequestAm > _request
Request which will later be notified/delivered to user.
Definition: request_am.h:40
std::function< void(std::shared_ptr< Request >, ucp_ep_h)> AmReceiverCallbackType
Active Message receiver callback.
Definition: typedefs.h:137