int mca_pml_ob1_isend(void *buf, size_t count, ompi_datatype_t * datatype, int dst, int tag, mca_pml_base_send_mode_t sendmode, ompi_communicator_t * comm, ompi_request_t ** request) { int rc; mca_pml_ob1_send_request_t *sendreq = NULL; MCA_PML_OB1_SEND_REQUEST_ALLOC(comm, dst, sendreq); if (NULL == sendreq) return OMPI_ERR_OUT_OF_RESOURCE; MCA_PML_OB1_SEND_REQUEST_INIT(sendreq, buf, count, datatype, dst, tag, comm, sendmode, false); PERUSE_TRACE_COMM_EVENT (PERUSE_COMM_REQ_ACTIVATE, &(sendreq)->req_send.req_base, PERUSE_SEND); MCA_PML_OB1_SEND_REQUEST_START(sendreq, rc); *request = (ompi_request_t *) sendreq; return rc; }
int mca_pml_ob1_start(size_t count, ompi_request_t** requests) { int rc; for (size_t i = 0 ; i < count ; ++i) { mca_pml_base_request_t *pml_request = (mca_pml_base_request_t*)requests[i]; if (NULL == pml_request || OMPI_REQUEST_PML != requests[i]->req_type) { continue; } /* If the persistent request is currently active - verify the status * is incomplete. if the pml layer has not completed the request - mark * the request as free called - so that it will be freed when the request * completes - and create a new request. */ #if OPAL_ENABLE_MULTI_THREADS opal_atomic_rmb(); #endif /* start the request */ switch(pml_request->req_type) { case MCA_PML_REQUEST_SEND: { mca_pml_ob1_send_request_t* sendreq = (mca_pml_ob1_send_request_t*)pml_request; MEMCHECKER( memchecker_call(&opal_memchecker_base_isdefined, pml_request->req_addr, pml_request->req_count, pml_request->req_datatype); ); if (!pml_request->req_pml_complete) { ompi_request_t *request; /* buffered sends can be mpi complete and pml incomplete. to support this * case we need to allocate a new request. */ rc = mca_pml_ob1_isend_init (pml_request->req_addr, pml_request->req_count, pml_request->req_datatype, pml_request->req_peer, pml_request->req_tag, sendreq->req_send.req_send_mode, pml_request->req_comm, &request); if (OPAL_UNLIKELY(OMPI_SUCCESS != rc)) { return rc; } /* copy the callback and callback data to the new requests */ request->req_complete_cb = pml_request->req_ompi.req_complete_cb; request->req_complete_cb_data = pml_request->req_ompi.req_complete_cb_data; /* ensure the old request gets released */ pml_request->req_free_called = true; sendreq = (mca_pml_ob1_send_request_t *) request; requests[i] = request; } else if (sendreq->req_send.req_bytes_packed != 0) { size_t offset = 0; /** * Reset the convertor in case we're dealing with the original * request, which when completed do not reset the convertor. */ opal_convertor_set_position (&sendreq->req_send.req_base.req_convertor, &offset); } /* reset the completion flag */ pml_request->req_pml_complete = false; MCA_PML_OB1_SEND_REQUEST_START(sendreq, rc); if(rc != OMPI_SUCCESS) return rc; break; } case MCA_PML_REQUEST_RECV: { mca_pml_ob1_recv_request_t* recvreq = (mca_pml_ob1_recv_request_t*)pml_request; MCA_PML_OB1_RECV_REQUEST_START(recvreq); break; } default: return OMPI_ERR_REQUEST; } }