150 void freeRequest(
Request& request);
151 bool testRequest(
Request& request);
155 MpiLock* mpiLock()
const {
return m_mpi_lock; }
170 int toMPISize(Int64 count);
178 void setRequestErrorAreFatal(
bool v);
179 bool isRequestErrorAreFatal()
const;
182 void setPrintRequestError(
bool v);
183 bool isPrintRequestError()
const;
187 bool isTraceMPIMessage()
const {
return m_is_trace; }
194 void setCheckRequest(
bool v);
195 bool isCheckRequest()
const;
201 IMpiProfiling* getMpiProfiling()
const;
206 ITimeMetricCollector* timeMetricCollector()
const {
return m_metric_collector; }
207 void setTimeMetricCollector(ITimeMetricCollector* v) { m_metric_collector = v; }
209 bool isAllowNullRankForAnySource()
const {
return m_is_allow_null_rank_for_any_source; }
215 IMpiProfiling* m_mpi_prof;
216 ITimeMetricCollector* m_metric_collector =
nullptr;
217 MPI_Comm m_communicator;
218 int m_comm_rank = A_PROC_NULL_RANK;
220 Int64 m_nb_all_reduce = 0;
221 Int64 m_nb_reduce = 0;
222 bool m_is_trace =
false;
223 RequestSet* m_request_set =
nullptr;
225 MPI_Request m_empty_request1;
226 MPI_Request m_empty_request2;
227 int m_recv_buffer_for_empty_request[1];
228 int m_send_buffer_for_empty_request2[1];
229 int m_recv_buffer_for_empty_request2[1];
236 bool m_is_allow_null_rank_for_any_source =
true;
240 void _trace(
const char* function);
241 void _addRequest(MPI_Request request);
242 void _removeRequest(MPI_Request request);
243 void _checkFatalInRequest();
244 MessageId _probeMessage(MessageRank source,MessageTag tag,
bool is_blocking);
245 MessageSourceInfo _legacyProbeMessage(MessageRank source,MessageTag tag,
bool is_blocking);
246 bool _handleEndRequests(ArrayView<Request> requests,ArrayView<bool> done_indexes,
247 ArrayView<MPI_Status> status);
248 void _checkHasNoRequests();
249 MessageSourceInfo _buildSourceInfoFromStatus(
const MPI_Status& status);