All Classes Namespaces Functions Variables Typedefs Enumerations Friends
Public Member Functions | Static Public Member Functions | Friends | List of all members
ucxx::RequestEndpointClose Class Reference

Send or receive a message with the UCX Tag API. More...

#include <request_endpoint_close.h>

Inheritance diagram for ucxx::RequestEndpointClose:
ucxx::Request ucxx::Component

Public Member Functions

virtual void populateDelayedSubmission ()
 Populate the internal submission dispatcher. More...
 
void request ()
 Create and submit an endpoint close request. More...
 
- Public Member Functions inherited from ucxx::Request
 Request (const Request &)=delete
 
Requestoperator= (Request const &)=delete
 
 Request (Request &&o)=delete
 
Requestoperator= (Request &&o)=delete
 
virtual ~Request ()
 ucxx::Request destructor. More...
 
virtual void cancel ()
 Cancel the request. More...
 
ucs_status_t getStatus ()
 Return the status of the request. More...
 
void * getFuture ()
 Return the future used to check on state. More...
 
void checkError ()
 Check whether the request completed with an error. More...
 
bool isCompleted ()
 Check whether the request has already completed. More...
 
void callback (void *request, ucs_status_t status)
 Callback executed by UCX when request is completed. More...
 
const std::string & getOwnerString () const
 Get formatted string with owner type and handle address. More...
 
virtual std::shared_ptr< BuffergetRecvBuffer ()
 Get the received buffer. More...
 
- Public Member Functions inherited from ucxx::Component
void setParent (std::shared_ptr< Component > parent)
 Set the internal parent reference. More...
 
std::shared_ptr< ComponentgetParent () const
 Get the internal parent reference. More...
 

Static Public Member Functions

static void endpointCloseCallback (void *request, ucs_status_t status, void *arg)
 Callback executed by UCX when an endpoint close request is completed. More...
 

Friends

std::shared_ptr< RequestEndpointClosecreateRequestEndpointClose (std::shared_ptr< Endpoint > endpoint, const data::EndpointClose requestData, const bool enablePythonFuture, RequestCallbackUserFunction callbackFunction, RequestCallbackUserData callbackData)
 Constructor for std::shared_ptr<ucxx::RequestEndpointClose>. More...
 

Additional Inherited Members

- Protected Member Functions inherited from ucxx::Request
 Request (std::shared_ptr< Component > endpointOrWorker, const data::RequestData requestData, const std::string operationName, const bool enablePythonFuture=false, RequestCallbackUserFunction callbackFunction=nullptr, RequestCallbackUserData callbackData=nullptr)
 Protected constructor of an abstract ucxx::Request. More...
 
void process ()
 Perform initial processing of the request to determine if immediate completion. More...
 
void setStatus (ucs_status_t status)
 Set the request status and notify Python future. More...
 
- Protected Attributes inherited from ucxx::Request
ucs_status_t _status {UCS_INPROGRESS}
 Requests status.
 
std::string _status_msg {}
 Human-readable status message.
 
void * _request {nullptr}
 Pointer to UCP request.
 
std::shared_ptr< Future_future {nullptr}
 Future to notify upon completion.
 
RequestCallbackUserFunction _callback {nullptr}
 Completion callback.
 
RequestCallbackUserData _callbackData {nullptr}
 Completion callback data.
 
std::shared_ptr< Worker_worker
 Worker that generated request (if not from endpoint) More...
 
std::shared_ptr< Endpoint_endpoint
 Endpoint that generated request (if not from worker) More...
 
std::string _ownerString
 String to print owner (endpoint or worker) when logging. More...
 
data::RequestData _requestData {}
 The operation-specific data to be used in the request.
 
std::string _operationName
 Human-readable operation name, mostly used for log messages. More...
 
std::recursive_mutex _mutex {}
 Mutex to prevent checking status while it's being set.
 
bool _enablePythonFuture {true}
 Whether Python future is enabled for this request.
 
- Protected Attributes inherited from ucxx::Component
std::shared_ptr< Component_parent {nullptr}
 A reference-counted pointer to the parent.
 

Detailed Description

Send or receive a message with the UCX Tag API.

Close a UCP endpoint, using non-blocking UCP call ucp_ep_close_nbx.

Member Function Documentation

◆ endpointCloseCallback()

static void ucxx::RequestEndpointClose::endpointCloseCallback ( void *  request,
ucs_status_t  status,
void *  arg 
)
static

Callback executed by UCX when an endpoint close request is completed.

Callback executed by UCX when an endpoint close request is completed, that will dispatch ucxx::Request::callback().

WARNING: This is not intended to be called by the user, but it currently needs to be a public method so that UCX may access it. In future changes this will be moved to an internal object and remove this method from the public API.

Parameters
[in]requestthe UCX request pointer.
[in]statusthe completion status of the request.
[in]argthe pointer to the ucxx::Request object that created the transfer, effectively this pointer as seen by request().

◆ populateDelayedSubmission()

virtual void ucxx::RequestEndpointClose::populateDelayedSubmission ( )
virtual

Populate the internal submission dispatcher.

The ucxx::Request utilizes ucxx::DelayedSubmission to manage when the request will be dispatched. This method is registered as a callback in the worker, that may choose to either execute (submit) it immediately or delay for the next iteration of its progress loop, depending on the progress mode in use by the worker.

See ucxx::DelayedSubmission::DelayedSubmission() for more details.

Implements ucxx::Request.

◆ request()

void ucxx::RequestEndpointClose::request ( )

Create and submit an endpoint close request.

This is the method that should be called to actually submit an endpoint close request. It is meant to be called from populateDelayedSubmission(), which is decided at the discretion of std::shared_ptr<ucxx::Worker>. See populateDelayedSubmission() for more details.

Friends And Related Function Documentation

◆ createRequestEndpointClose

std::shared_ptr<RequestEndpointClose> createRequestEndpointClose ( std::shared_ptr< Endpoint endpoint,
const data::EndpointClose  requestData,
const bool  enablePythonFuture,
RequestCallbackUserFunction  callbackFunction,
RequestCallbackUserData  callbackData 
)
friend

Constructor for std::shared_ptr<ucxx::RequestEndpointClose>.

The constructor for a std::shared_ptr<ucxx::RequestEndpointClose> object, creating a request to close a UCP endpoint, returning a pointer to the request object that can be later awaited and checked for errors. This is a non-blocking operation, and its status must be verified from the resulting request object to confirm the close operation has completed successfully.

Exceptions
ucxx::Errorendpoint is not a valid std::shared_ptr<ucxx::Endpoint>.
Parameters
[in]endpointthe std::shared_ptr<Endpoint> parent component.
[in]requestDatacontainer of the specified message type, including all type-specific data.
[in]enablePythonFuturewhether a python future should be created and subsequently notified.
[in]callbackFunctionuser-defined callback function to call upon completion.
[in]callbackDatauser-defined data to pass to the callbackFunction.
Returns
The shared_ptr<ucxx::RequestEndpointClose> object.

The documentation for this class was generated from the following file: