|
Packit Service |
c5cf8c |
.TH MPI_Waitsome 3 "11/12/2019" " " "MPI"
|
|
Packit Service |
c5cf8c |
.SH NAME
|
|
Packit Service |
c5cf8c |
MPI_Waitsome \- Waits for some given MPI Requests to complete
|
|
Packit Service |
c5cf8c |
.SH SYNOPSIS
|
|
Packit Service |
c5cf8c |
.nf
|
|
Packit Service |
c5cf8c |
int MPI_Waitsome(int incount, MPI_Request array_of_requests[],
|
|
Packit Service |
c5cf8c |
int *outcount, int array_of_indices[], MPI_Status array_of_statuses[])
|
|
Packit Service |
c5cf8c |
.fi
|
|
Packit Service |
c5cf8c |
.SH INPUT PARAMETERS
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B incount
|
|
Packit Service |
c5cf8c |
- length of array_of_requests (integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_requests
|
|
Packit Service |
c5cf8c |
- array of requests (array of handles)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH OUTPUT PARAMETERS
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B outcount
|
|
Packit Service |
c5cf8c |
- number of completed requests (integer)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_indices
|
|
Packit Service |
c5cf8c |
- array of indices of operations that
|
|
Packit Service |
c5cf8c |
completed (array of integers)
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B array_of_statuses
|
|
Packit Service |
c5cf8c |
- array of status objects for
|
|
Packit Service |
c5cf8c |
operations that completed (array of Status). May be
|
|
Packit Service |
c5cf8c |
.I MPI_STATUSES_IGNORE
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES
|
|
Packit Service |
c5cf8c |
The array of indicies are in the range
|
|
Packit Service |
c5cf8c |
.I 0
|
|
Packit Service |
c5cf8c |
to
|
|
Packit Service |
c5cf8c |
.I incount - 1
|
|
Packit Service |
c5cf8c |
for C and
|
|
Packit Service |
c5cf8c |
in the range
|
|
Packit Service |
c5cf8c |
.I 1
|
|
Packit Service |
c5cf8c |
to
|
|
Packit Service |
c5cf8c |
.I incount
|
|
Packit Service |
c5cf8c |
for Fortran.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
Null requests are ignored; if all requests are null, then the routine
|
|
Packit Service |
c5cf8c |
returns with
|
|
Packit Service |
c5cf8c |
.I outcount
|
|
Packit Service |
c5cf8c |
set to
|
|
Packit Service |
c5cf8c |
.I MPI_UNDEFINED
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
While it is possible to list a request handle more than once in the
|
|
Packit Service |
c5cf8c |
array_of_requests, such an action is considered erroneous and may cause the
|
|
Packit Service |
c5cf8c |
program to unexecpectedly terminate or produce incorrect results.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
provides an interface much like the Unix
|
|
Packit Service |
c5cf8c |
.I select
|
|
Packit Service |
c5cf8c |
or
|
|
Packit Service |
c5cf8c |
.I poll
|
|
Packit Service |
c5cf8c |
calls and, in a high qualilty implementation, indicates all of the requests
|
|
Packit Service |
c5cf8c |
that have completed when
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
is called.
|
|
Packit Service |
c5cf8c |
However,
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
only guarantees that at least one
|
|
Packit Service |
c5cf8c |
request has completed; there is no guarantee that
|
|
Packit Service |
c5cf8c |
.B all
|
|
Packit Service |
c5cf8c |
completed requests
|
|
Packit Service |
c5cf8c |
will be returned, or that the entries in
|
|
Packit Service |
c5cf8c |
.I array_of_indices
|
|
Packit Service |
c5cf8c |
will be in
|
|
Packit Service |
c5cf8c |
increasing order. Also, requests that are completed while
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
is
|
|
Packit Service |
c5cf8c |
executing may or may not be returned, depending on the timing of the
|
|
Packit Service |
c5cf8c |
completion of the message.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES ON THE MPI_STATUS ARGUMENT
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
The
|
|
Packit Service |
c5cf8c |
.I MPI_ERROR
|
|
Packit Service |
c5cf8c |
field of the status return is only set if
|
|
Packit Service |
c5cf8c |
the return from the MPI routine is
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_IN_STATUS
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
That error class
|
|
Packit Service |
c5cf8c |
is only returned by the routines that take an array of status arguments
|
|
Packit Service |
c5cf8c |
(
|
|
Packit Service |
c5cf8c |
.I MPI_Testall
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Testsome
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Waitall
|
|
Packit Service |
c5cf8c |
, and
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
). In
|
|
Packit Service |
c5cf8c |
all other cases, the value of the
|
|
Packit Service |
c5cf8c |
.I MPI_ERROR
|
|
Packit Service |
c5cf8c |
field in the status is
|
|
Packit Service |
c5cf8c |
unchanged. See section 3.2.5 in the MPI-1.1 specification for the
|
|
Packit Service |
c5cf8c |
exact text.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
For send operations, the only use of status is for
|
|
Packit Service |
c5cf8c |
.I MPI_Test_cancelled
|
|
Packit Service |
c5cf8c |
or
|
|
Packit Service |
c5cf8c |
in the case that there is an error in one of the four routines that
|
|
Packit Service |
c5cf8c |
may return the error class
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_IN_STATUS
|
|
Packit Service |
c5cf8c |
, in which case the
|
|
Packit Service |
c5cf8c |
.I MPI_ERROR
|
|
Packit Service |
c5cf8c |
field of status will be set. In that case, the value
|
|
Packit Service |
c5cf8c |
will be set to
|
|
Packit Service |
c5cf8c |
.I MPI_SUCCESS
|
|
Packit Service |
c5cf8c |
for any send or receive operation that completed
|
|
Packit Service |
c5cf8c |
successfully, or
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_PENDING
|
|
Packit Service |
c5cf8c |
for any operation which has neither
|
|
Packit Service |
c5cf8c |
failed nor completed.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH THREAD AND INTERRUPT SAFETY
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
This routine is thread-safe. This means that this routine may be
|
|
Packit Service |
c5cf8c |
safely used by multiple threads without the need for any user-provided
|
|
Packit Service |
c5cf8c |
thread locks. However, the routine is not interrupt safe. Typically,
|
|
Packit Service |
c5cf8c |
this is due to the use of memory allocation routines such as
|
|
Packit Service |
c5cf8c |
.I malloc
|
|
Packit Service |
c5cf8c |
or other non-MPICH runtime routines that are themselves not interrupt-safe.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH NOTES FOR FORTRAN
|
|
Packit Service |
c5cf8c |
All MPI routines in Fortran (except for
|
|
Packit Service |
c5cf8c |
.I MPI_WTIME
|
|
Packit Service |
c5cf8c |
and
|
|
Packit Service |
c5cf8c |
.I MPI_WTICK
|
|
Packit Service |
c5cf8c |
) have
|
|
Packit Service |
c5cf8c |
an additional argument
|
|
Packit Service |
c5cf8c |
.I ierr
|
|
Packit Service |
c5cf8c |
at the end of the argument list.
|
|
Packit Service |
c5cf8c |
.I ierr
|
|
Packit Service |
c5cf8c |
is an integer and has the same meaning as the return value of the routine
|
|
Packit Service |
c5cf8c |
in C. In Fortran, MPI routines are subroutines, and are invoked with the
|
|
Packit Service |
c5cf8c |
.I call
|
|
Packit Service |
c5cf8c |
statement.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
All MPI objects (e.g.,
|
|
Packit Service |
c5cf8c |
.I MPI_Datatype
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Comm
|
|
Packit Service |
c5cf8c |
) are of type
|
|
Packit Service |
c5cf8c |
.I INTEGER
|
|
Packit Service |
c5cf8c |
in Fortran.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.SH ERRORS
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
All MPI routines (except
|
|
Packit Service |
c5cf8c |
.I MPI_Wtime
|
|
Packit Service |
c5cf8c |
and
|
|
Packit Service |
c5cf8c |
.I MPI_Wtick
|
|
Packit Service |
c5cf8c |
) return an error value;
|
|
Packit Service |
c5cf8c |
C routines as the value of the function and Fortran routines in the last
|
|
Packit Service |
c5cf8c |
argument. Before the value is returned, the current MPI error handler is
|
|
Packit Service |
c5cf8c |
called. By default, this error handler aborts the MPI job. The error handler
|
|
Packit Service |
c5cf8c |
may be changed with
|
|
Packit Service |
c5cf8c |
.I MPI_Comm_set_errhandler
|
|
Packit Service |
c5cf8c |
(for communicators),
|
|
Packit Service |
c5cf8c |
.I MPI_File_set_errhandler
|
|
Packit Service |
c5cf8c |
(for files), and
|
|
Packit Service |
c5cf8c |
.I MPI_Win_set_errhandler
|
|
Packit Service |
c5cf8c |
(for
|
|
Packit Service |
c5cf8c |
RMA windows). The MPI-1 routine
|
|
Packit Service |
c5cf8c |
.I MPI_Errhandler_set
|
|
Packit Service |
c5cf8c |
may be used but
|
|
Packit Service |
c5cf8c |
its use is deprecated. The predefined error handler
|
|
Packit Service |
c5cf8c |
.I MPI_ERRORS_RETURN
|
|
Packit Service |
c5cf8c |
may be used to cause error values to be returned.
|
|
Packit Service |
c5cf8c |
Note that MPI does
|
|
Packit Service |
c5cf8c |
.B not
|
|
Packit Service |
c5cf8c |
guarentee that an MPI program can continue past
|
|
Packit Service |
c5cf8c |
an error; however, MPI implementations will attempt to continue whenever
|
|
Packit Service |
c5cf8c |
possible.
|
|
Packit Service |
c5cf8c |
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_SUCCESS
|
|
Packit Service |
c5cf8c |
- No error; MPI routine completed successfully.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_REQUEST
|
|
Packit Service |
c5cf8c |
- Invalid
|
|
Packit Service |
c5cf8c |
.I MPI_Request
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
Either null or, in the case of a
|
|
Packit Service |
c5cf8c |
.I MPI_Start
|
|
Packit Service |
c5cf8c |
or
|
|
Packit Service |
c5cf8c |
.I MPI_Startall
|
|
Packit Service |
c5cf8c |
, not a persistent request.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_ARG
|
|
Packit Service |
c5cf8c |
- Invalid argument. Some argument is invalid and is not
|
|
Packit Service |
c5cf8c |
identified by a specific error class (e.g.,
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_RANK
|
|
Packit Service |
c5cf8c |
).
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
.PD 0
|
|
Packit Service |
c5cf8c |
.TP
|
|
Packit Service |
c5cf8c |
.B MPI_ERR_IN_STATUS
|
|
Packit Service |
c5cf8c |
- The actual error value is in the
|
|
Packit Service |
c5cf8c |
.I MPI_Status
|
|
Packit Service |
c5cf8c |
argument.
|
|
Packit Service |
c5cf8c |
This error class is returned only from the multiple-completion routines
|
|
Packit Service |
c5cf8c |
(
|
|
Packit Service |
c5cf8c |
.I MPI_Testall
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Testany
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Testsome
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Waitall
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
.I MPI_Waitany
|
|
Packit Service |
c5cf8c |
,
|
|
Packit Service |
c5cf8c |
and
|
|
Packit Service |
c5cf8c |
.I MPI_Waitsome
|
|
Packit Service |
c5cf8c |
). The field
|
|
Packit Service |
c5cf8c |
.I MPI_ERROR
|
|
Packit Service |
c5cf8c |
in the status argument
|
|
Packit Service |
c5cf8c |
contains the error value or
|
|
Packit Service |
c5cf8c |
.I MPI_SUCCESS
|
|
Packit Service |
c5cf8c |
(no error and complete) or
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_PENDING
|
|
Packit Service |
c5cf8c |
to indicate that the request has not completed.
|
|
Packit Service |
c5cf8c |
.PD 1
|
|
Packit Service |
c5cf8c |
The MPI Standard does not specify what the result of the multiple
|
|
Packit Service |
c5cf8c |
completion routines is when an error occurs. For example, in an
|
|
Packit Service |
c5cf8c |
.I MPI_WAITALL
|
|
Packit Service |
c5cf8c |
, does the routine wait for all requests to either fail or
|
|
Packit Service |
c5cf8c |
complete, or does it return immediately (with the MPI definition of
|
|
Packit Service |
c5cf8c |
immediately, which means independent of actions of other MPI processes)?
|
|
Packit Service |
c5cf8c |
MPICH has chosen to make the return immediate (alternately, local in MPI
|
|
Packit Service |
c5cf8c |
terms), and to use the error class
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_PENDING
|
|
Packit Service |
c5cf8c |
(introduced in MPI 1.1)
|
|
Packit Service |
c5cf8c |
to indicate which requests have not completed. In most cases, only
|
|
Packit Service |
c5cf8c |
one request with an error will be detected in each call to an MPI routine
|
|
Packit Service |
c5cf8c |
that tests multiple requests. The requests that have not been processed
|
|
Packit Service |
c5cf8c |
(because an error occured in one of the requests) will have their
|
|
Packit Service |
c5cf8c |
.I MPI_ERROR
|
|
Packit Service |
c5cf8c |
field marked with
|
|
Packit Service |
c5cf8c |
.I MPI_ERR_PENDING
|
|
Packit Service |
c5cf8c |
\&.
|
|
Packit Service |
c5cf8c |
|