This source file includes following definitions.
- request_cancel
- request_free
- request_construct
- req_completion
1
2
3
4
5
6
7
8
9
10 #include "ompi_config.h"
11
12 #include "ompi/request/request.h"
13 #include "ompi/mca/osc/osc.h"
14 #include "ompi/mca/osc/base/base.h"
15 #include "ompi/mca/osc/base/osc_base_obj_convert.h"
16
17 #include "osc_ucx.h"
18 #include "osc_ucx_request.h"
19
20 static int request_cancel(struct ompi_request_t *request, int complete)
21 {
22 return MPI_ERR_REQUEST;
23 }
24
25 static int request_free(struct ompi_request_t **ompi_req)
26 {
27 ompi_osc_ucx_request_t *request = (ompi_osc_ucx_request_t*) *ompi_req;
28
29 if (true != (bool)(request->super.req_complete)) {
30 return MPI_ERR_REQUEST;
31 }
32
33 OMPI_OSC_UCX_REQUEST_RETURN(request);
34
35 *ompi_req = MPI_REQUEST_NULL;
36
37 return OMPI_SUCCESS;
38 }
39
40 static void request_construct(ompi_osc_ucx_request_t *request)
41 {
42 request->super.req_type = OMPI_REQUEST_WIN;
43 request->super.req_status._cancelled = 0;
44 request->super.req_free = request_free;
45 request->super.req_cancel = request_cancel;
46 }
47
48 void req_completion(void *request) {
49 ompi_osc_ucx_request_t *req = (ompi_osc_ucx_request_t *)request;
50 ompi_request_complete(&(req->super), true);
51 mca_osc_ucx_component.num_incomplete_req_ops--;
52 assert(mca_osc_ucx_component.num_incomplete_req_ops >= 0);
53 }
54
55 OBJ_CLASS_INSTANCE(ompi_osc_ucx_request_t, ompi_request_t,
56 request_construct, NULL);