2005-06-30 05:50:55 +00:00
|
|
|
#ifndef MCA_BTL_SM_FIFO_H
|
|
|
|
#define MCA_BTL_SM_FIFO_H
|
2005-05-23 22:06:50 +00:00
|
|
|
|
2005-06-30 05:50:55 +00:00
|
|
|
#include "btl_sm.h"
|
2005-09-11 20:55:22 +00:00
|
|
|
#include "btl_sm_endpoint.h"
|
2005-05-23 22:06:50 +00:00
|
|
|
|
2007-10-22 12:07:22 +00:00
|
|
|
#define MCA_BTL_SM_FIFO_WRITE(endpoint_peer, my_smp_rank, \
|
|
|
|
peer_smp_rank, hdr, resend, rc) \
|
2007-08-30 13:21:52 +00:00
|
|
|
do { \
|
|
|
|
ompi_fifo_t* fifo; \
|
|
|
|
fifo=&(mca_btl_sm_component.fifo[peer_smp_rank][my_smp_rank]); \
|
|
|
|
\
|
|
|
|
/* thread lock */ \
|
2007-08-31 12:34:48 +00:00
|
|
|
if(opal_using_threads()) \
|
|
|
|
opal_atomic_lock(fifo->head_lock); \
|
2007-08-30 13:21:52 +00:00
|
|
|
/* post fragment */ \
|
2007-10-22 12:07:22 +00:00
|
|
|
if(ompi_fifo_write_to_head(hdr, fifo, mca_btl_sm_component.sm_mpool) \
|
|
|
|
!= OMPI_SUCCESS) { \
|
|
|
|
btl_sm_add_pending(endpoint_peer, hdr, resend); \
|
2008-05-12 07:15:29 +00:00
|
|
|
rc = OMPI_ERR_RESOURCE_BUSY; \
|
2007-10-22 12:07:22 +00:00
|
|
|
} else { \
|
|
|
|
MCA_BTL_SM_SIGNAL_PEER(endpoint_peer); \
|
|
|
|
rc = OMPI_SUCCESS; \
|
|
|
|
} \
|
2007-08-31 12:34:48 +00:00
|
|
|
if(opal_using_threads()) \
|
|
|
|
opal_atomic_unlock(fifo->head_lock); \
|
2008-03-09 13:17:13 +00:00
|
|
|
} while(0)
|
2005-05-23 22:06:50 +00:00
|
|
|
|
|
|
|
#endif
|