1
1

Merge pull request #2545 from kawashima-fj/pr/inactive-persistent-request

ompi/request: Fix a persistent request creation bug
Этот коммит содержится в:
KAWASHIMA Takahiro 2016-12-09 08:42:31 +09:00 коммит произвёл GitHub
родитель 1187212f5d 6510800c16
Коммит ae056d957c
3 изменённых файлов: 12 добавлений и 11 удалений

Просмотреть файл

@ -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; \