Merge pull request #2545 from kawashima-fj/pr/inactive-persistent-request
ompi/request: Fix a persistent request creation bug
Этот коммит содержится в:
Коммит
ae056d957c
@ -35,7 +35,7 @@ int mca_pml_bfo_iprobe(int src,
|
|||||||
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
||||||
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_IPROBE;
|
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_IPROBE;
|
||||||
|
|
||||||
MCA_PML_BFO_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, true);
|
MCA_PML_BFO_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, false);
|
||||||
MCA_PML_BFO_RECV_REQUEST_START(&recvreq);
|
MCA_PML_BFO_RECV_REQUEST_START(&recvreq);
|
||||||
|
|
||||||
if( recvreq.req_recv.req_base.req_ompi.req_complete == true ) {
|
if( recvreq.req_recv.req_base.req_ompi.req_complete == true ) {
|
||||||
@ -65,7 +65,7 @@ int mca_pml_bfo_probe(int src,
|
|||||||
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
||||||
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_PROBE;
|
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_PROBE;
|
||||||
|
|
||||||
MCA_PML_BFO_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, true);
|
MCA_PML_BFO_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, false);
|
||||||
MCA_PML_BFO_RECV_REQUEST_START(&recvreq);
|
MCA_PML_BFO_RECV_REQUEST_START(&recvreq);
|
||||||
|
|
||||||
ompi_request_wait_completion(&recvreq.req_recv.req_base.req_ompi);
|
ompi_request_wait_completion(&recvreq.req_recv.req_base.req_ompi);
|
||||||
|
@ -36,7 +36,7 @@ int mca_pml_ob1_iprobe(int src,
|
|||||||
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
||||||
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_IPROBE;
|
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_IPROBE;
|
||||||
|
|
||||||
MCA_PML_OB1_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, true);
|
MCA_PML_OB1_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, false);
|
||||||
MCA_PML_OB1_RECV_REQUEST_START(&recvreq);
|
MCA_PML_OB1_RECV_REQUEST_START(&recvreq);
|
||||||
|
|
||||||
if( REQUEST_COMPLETE( &(recvreq.req_recv.req_base.req_ompi)) ) {
|
if( REQUEST_COMPLETE( &(recvreq.req_recv.req_base.req_ompi)) ) {
|
||||||
@ -66,7 +66,7 @@ int mca_pml_ob1_probe(int src,
|
|||||||
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
recvreq.req_recv.req_base.req_ompi.req_type = OMPI_REQUEST_PML;
|
||||||
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_PROBE;
|
recvreq.req_recv.req_base.req_type = MCA_PML_REQUEST_PROBE;
|
||||||
|
|
||||||
MCA_PML_OB1_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, true);
|
MCA_PML_OB1_RECV_REQUEST_INIT(&recvreq, NULL, 0, &ompi_mpi_char.dt, src, tag, comm, false);
|
||||||
MCA_PML_OB1_RECV_REQUEST_START(&recvreq);
|
MCA_PML_OB1_RECV_REQUEST_START(&recvreq);
|
||||||
|
|
||||||
ompi_request_wait_completion(&recvreq.req_recv.req_base.req_ompi);
|
ompi_request_wait_completion(&recvreq.req_recv.req_base.req_ompi);
|
||||||
|
@ -144,7 +144,8 @@ typedef struct ompi_predefined_request_t ompi_predefined_request_t;
|
|||||||
*/
|
*/
|
||||||
#define OMPI_REQUEST_INIT(request, persistent) \
|
#define OMPI_REQUEST_INIT(request, persistent) \
|
||||||
do { \
|
do { \
|
||||||
(request)->req_complete = REQUEST_PENDING; \
|
(request)->req_complete = \
|
||||||
|
(persistent) ? REQUEST_COMPLETED : REQUEST_PENDING; \
|
||||||
(request)->req_state = OMPI_REQUEST_INACTIVE; \
|
(request)->req_state = OMPI_REQUEST_INACTIVE; \
|
||||||
(request)->req_persistent = (persistent); \
|
(request)->req_persistent = (persistent); \
|
||||||
(request)->req_complete_cb = NULL; \
|
(request)->req_complete_cb = NULL; \
|
||||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user