| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 
 | .. _mpi_file_iwrite_all:
MPI_File_iwrite_all
===================
.. include_body
:ref:`MPI_File_iwrite_all` |mdash| Writes a file starting at the location
specified by the individual file pointer (nonblocking, collective).
SYNTAX
------
C Syntax
^^^^^^^^
.. code-block:: c
   #include <mpi.h>
   int MPI_File_iwrite_all(MPI_File fh, const void *buf, int count,
   	MPI_Datatype datatype, MPI_Request *request)
Fortran Syntax
^^^^^^^^^^^^^^
.. code-block:: fortran
   USE MPI
   ! or the older form: INCLUDE 'mpif.h'
   MPI_FILE_IWRITE_ALL(FH, BUF, COUNT, DATATYPE, REQUEST, IERROR)
   	<type>	BUF(*)
   	INTEGER	FH, COUNT, DATATYPE, REQUEST, IERROR
Fortran 2008 Syntax
^^^^^^^^^^^^^^^^^^^
.. code-block:: fortran
   USE mpi_f08
   MPI_File_iwrite_all(fh, buf, count, datatype, request, ierror)
   	TYPE(MPI_File), INTENT(IN) :: fh
   	TYPE(*), DIMENSION(..) :: buf
   	INTEGER, INTENT(IN) :: count
   	TYPE(MPI_Datatype), INTENT(IN) :: datatype
   	TYPE(MPI_Request), INTENT(OUT) :: request
   	INTEGER, OPTIONAL, INTENT(OUT) :: ierror
INPUT/OUTPUT PARAMETER
----------------------
* ``fh``: File handle (handle).
INPUT PARAMETERS
----------------
* ``buf``: Initial address of buffer (choice).
* ``count``: Number of elements in buffer (integer).
* ``datatype``: Data type of each buffer element (handle).
OUTPUT PARAMETER
----------------
* ``request``: Request object (handle).
* ``ierror``: Fortran only: Error status (integer).
DESCRIPTION
-----------
:ref:`MPI_File_iwrite_all` is a nonblocking version of the :ref:`MPI_File_write_all`
interface. It attempts to write into the file associated with *fh* (at
the current individual file pointer position maintained by the system) a
total number of *count* data items having *datatype* type from the
user's buffer *buf.* The data is written into those parts of the file
specified by the current view. :ref:`MPI_File_iwrite_all` stores the number of
*datatype* elements actually written in *status.* All other fields of
*status* are undefined.
It is erroneous to call this function if ``MPI_MODE_SEQUENTIAL`` mode was
specified when the file was open.
ERRORS
------
.. include:: ./ERRORS.rst
 |