132 строки
3.9 KiB
Plaintext
132 строки
3.9 KiB
Plaintext
|
.\" -*- nroff -*-
|
||
|
.\" Copyright 2010 Cisco Systems, Inc. All rights reserved.
|
||
|
.\" Copyright 2006-2008 Sun Microsystems, Inc.
|
||
|
.\" Copyright (c) 1996 Thinking Machines Corporation
|
||
|
.\" Copyright 2015-2016 Research Organization for Information Science
|
||
|
.\" and Technology (RIST). All rights reserved.
|
||
|
.\" $COPYRIGHT$
|
||
|
.TH MPI_File_read_at 3 "#OMPI_DATE#" "#PACKAGE_VERSION#" "#PACKAGE_NAME#"
|
||
|
.SH NAME
|
||
|
\fBMPI_File_read_at\fP \- Reads a file at an explicitly specified offset (blocking, noncollective).
|
||
|
|
||
|
.SH SYNTAX
|
||
|
.ft R
|
||
|
.nf
|
||
|
.SH C Syntax
|
||
|
.nf
|
||
|
#include <mpi.h>
|
||
|
int MPI_File_read_at(MPI_File \fIfh\fP, MPI_Offset \fIoffset\fP,
|
||
|
void \fI*buf\fP, int \fIcount\fP, MPI_Datatype \fIdatatype\fP,
|
||
|
MPI_Status \fI*status\fP)
|
||
|
|
||
|
.fi
|
||
|
.SH Fortran Syntax (see FORTRAN 77 NOTES)
|
||
|
.nf
|
||
|
USE MPI
|
||
|
! or the older form: INCLUDE 'mpif.h'
|
||
|
MPI_FILE_READ_AT(\fIFH\fP, \fIOFFSET\fP, \fIBUF\fP, \fICOUNT\fP,
|
||
|
\fIDATATYPE\fP, \fISTATUS\fP, \fIIERROR\fP)
|
||
|
<type> \fIBUF\fP(*)
|
||
|
INTEGER \fIFH, COUNT, DATATYPE, STATUS(MPI_STATUS_SIZE), IERROR\fP
|
||
|
INTEGER(KIND=MPI_OFFSET_KIND) \fIOFFSET\fP
|
||
|
|
||
|
.fi
|
||
|
.SH Fortran 2008 Syntax
|
||
|
.nf
|
||
|
USE mpi_f08
|
||
|
MPI_File_read_at(\fIfh\fP, \fIoffset\fP, \fIbuf\fP, \fIcount\fP, \fIdatatype\fP, \fIstatus\fP, \fIierror\fP)
|
||
|
TYPE(MPI_File), INTENT(IN) :: \fIfh\fP
|
||
|
INTEGER(KIND=MPI_OFFSET_KIND), INTENT(IN) :: \fIoffset\fP
|
||
|
TYPE(*), DIMENSION(..) :: \fIbuf\fP
|
||
|
INTEGER, INTENT(IN) :: \fIcount\fP
|
||
|
TYPE(MPI_Datatype), INTENT(IN) :: \fIdatatype\fP
|
||
|
TYPE(MPI_Status) :: \fIstatus\fP
|
||
|
INTEGER, OPTIONAL, INTENT(OUT) :: \fIierror\fP
|
||
|
|
||
|
.fi
|
||
|
.SH C++ Syntax
|
||
|
.nf
|
||
|
#include <mpi.h>
|
||
|
void MPI::File::Read_at(MPI::Offset \fIoffset\fP, void* \fIbuf\fP,
|
||
|
int \fIcount\fP, const MPI::Datatype& \fIdatatype\fP,
|
||
|
MPI::Status& \fIstatus\fP)
|
||
|
|
||
|
void MPI::File::Read_at(MPI::Offset \fIoffset\fP, void* \fIbuf\fP,
|
||
|
int \fIcount\fP, const MPI::Datatype& \fIdatatype\fP)
|
||
|
|
||
|
.fi
|
||
|
.SH INPUT PARAMETERS
|
||
|
.ft R
|
||
|
.TP 1i
|
||
|
fh
|
||
|
File handle (handle).
|
||
|
.TP 1i
|
||
|
offset
|
||
|
File offset (integer).
|
||
|
.TP 1i
|
||
|
count
|
||
|
Number of elements in buffer (integer).
|
||
|
.TP 1i
|
||
|
datatype
|
||
|
Data type of each buffer element (handle).
|
||
|
|
||
|
.SH OUTPUT PARAMETERS
|
||
|
.ft R
|
||
|
.TP 1i
|
||
|
buf
|
||
|
Initial address of buffer (choice).
|
||
|
.TP 1i
|
||
|
status
|
||
|
Status object (status).
|
||
|
.TP 1i
|
||
|
IERROR
|
||
|
Fortran only: Error status (integer).
|
||
|
|
||
|
.SH DESCRIPTION
|
||
|
.ft R
|
||
|
|
||
|
MPI_File_read_at attempts to read from the file associated with
|
||
|
.I fh
|
||
|
(at the
|
||
|
.I offset
|
||
|
position) a total number of
|
||
|
.I count
|
||
|
data items having
|
||
|
.I datatype
|
||
|
type into the user's buffer
|
||
|
.I buf.
|
||
|
The
|
||
|
.I offset
|
||
|
is in
|
||
|
.I etype
|
||
|
units relative to the current view. That is, holes are not counted
|
||
|
when locating an offset. The data is taken out of those parts of the
|
||
|
file specified by the current view. MPI_File_read_at stores the
|
||
|
number of
|
||
|
.I datatype
|
||
|
elements actually read in
|
||
|
.I status.
|
||
|
All other fields of
|
||
|
.I status
|
||
|
are undefined. It is erroneous to call this function if MPI_MODE_SEQUENTIAL mode was specified when the file was opened.
|
||
|
|
||
|
.SH FORTRAN 77 NOTES
|
||
|
.ft R
|
||
|
The MPI standard prescribes portable Fortran syntax for
|
||
|
the \fIOFFSET\fP argument only for Fortran 90. FORTRAN 77
|
||
|
users may use the non-portable syntax
|
||
|
.sp
|
||
|
.nf
|
||
|
INTEGER*MPI_OFFSET_KIND \fIOFFSET\fP
|
||
|
.fi
|
||
|
.sp
|
||
|
where MPI_OFFSET_KIND is a constant defined in mpif.h
|
||
|
and gives the length of the declared integer in bytes.
|
||
|
|
||
|
.SH ERRORS
|
||
|
Almost all MPI routines return an error value; C routines as the value of the function and Fortran routines in the last argument. C++ functions do not return errors. If the default error handler is set to MPI::ERRORS_THROW_EXCEPTIONS, then on error the C++ exception mechanism will be used to throw an MPI::Exception object.
|
||
|
.sp
|
||
|
Before the error value is returned, the current MPI error handler is
|
||
|
called. For MPI I/O function errors, the default error handler is set to MPI_ERRORS_RETURN. The error handler may be changed with MPI_File_set_errhandler; the predefined error handler MPI_ERRORS_ARE_FATAL may be used to make I/O errors fatal. Note that MPI does not guarantee that an MPI program can continue past an error.
|
||
|
|