- •Contents
- •List of Figures
- •List of Tables
- •Acknowledgments
- •Introduction to MPI
- •Overview and Goals
- •Background of MPI-1.0
- •Background of MPI-1.1, MPI-1.2, and MPI-2.0
- •Background of MPI-1.3 and MPI-2.1
- •Background of MPI-2.2
- •Who Should Use This Standard?
- •What Platforms Are Targets For Implementation?
- •What Is Included In The Standard?
- •What Is Not Included In The Standard?
- •Organization of this Document
- •MPI Terms and Conventions
- •Document Notation
- •Naming Conventions
- •Semantic Terms
- •Data Types
- •Opaque Objects
- •Array Arguments
- •State
- •Named Constants
- •Choice
- •Addresses
- •Language Binding
- •Deprecated Names and Functions
- •Fortran Binding Issues
- •C Binding Issues
- •C++ Binding Issues
- •Functions and Macros
- •Processes
- •Error Handling
- •Implementation Issues
- •Independence of Basic Runtime Routines
- •Interaction with Signals
- •Examples
- •Point-to-Point Communication
- •Introduction
- •Blocking Send and Receive Operations
- •Blocking Send
- •Message Data
- •Message Envelope
- •Blocking Receive
- •Return Status
- •Passing MPI_STATUS_IGNORE for Status
- •Data Type Matching and Data Conversion
- •Type Matching Rules
- •Type MPI_CHARACTER
- •Data Conversion
- •Communication Modes
- •Semantics of Point-to-Point Communication
- •Buffer Allocation and Usage
- •Nonblocking Communication
- •Communication Request Objects
- •Communication Initiation
- •Communication Completion
- •Semantics of Nonblocking Communications
- •Multiple Completions
- •Non-destructive Test of status
- •Probe and Cancel
- •Persistent Communication Requests
- •Send-Receive
- •Null Processes
- •Datatypes
- •Derived Datatypes
- •Type Constructors with Explicit Addresses
- •Datatype Constructors
- •Subarray Datatype Constructor
- •Distributed Array Datatype Constructor
- •Address and Size Functions
- •Lower-Bound and Upper-Bound Markers
- •Extent and Bounds of Datatypes
- •True Extent of Datatypes
- •Commit and Free
- •Duplicating a Datatype
- •Use of General Datatypes in Communication
- •Correct Use of Addresses
- •Decoding a Datatype
- •Examples
- •Pack and Unpack
- •Canonical MPI_PACK and MPI_UNPACK
- •Collective Communication
- •Introduction and Overview
- •Communicator Argument
- •Applying Collective Operations to Intercommunicators
- •Barrier Synchronization
- •Broadcast
- •Example using MPI_BCAST
- •Gather
- •Examples using MPI_GATHER, MPI_GATHERV
- •Scatter
- •Examples using MPI_SCATTER, MPI_SCATTERV
- •Example using MPI_ALLGATHER
- •All-to-All Scatter/Gather
- •Global Reduction Operations
- •Reduce
- •Signed Characters and Reductions
- •MINLOC and MAXLOC
- •All-Reduce
- •Process-local reduction
- •Reduce-Scatter
- •MPI_REDUCE_SCATTER_BLOCK
- •MPI_REDUCE_SCATTER
- •Scan
- •Inclusive Scan
- •Exclusive Scan
- •Example using MPI_SCAN
- •Correctness
- •Introduction
- •Features Needed to Support Libraries
- •MPI's Support for Libraries
- •Basic Concepts
- •Groups
- •Contexts
- •Intra-Communicators
- •Group Management
- •Group Accessors
- •Group Constructors
- •Group Destructors
- •Communicator Management
- •Communicator Accessors
- •Communicator Constructors
- •Communicator Destructors
- •Motivating Examples
- •Current Practice #1
- •Current Practice #2
- •(Approximate) Current Practice #3
- •Example #4
- •Library Example #1
- •Library Example #2
- •Inter-Communication
- •Inter-communicator Accessors
- •Inter-communicator Operations
- •Inter-Communication Examples
- •Caching
- •Functionality
- •Communicators
- •Windows
- •Datatypes
- •Error Class for Invalid Keyval
- •Attributes Example
- •Naming Objects
- •Formalizing the Loosely Synchronous Model
- •Basic Statements
- •Models of Execution
- •Static communicator allocation
- •Dynamic communicator allocation
- •The General case
- •Process Topologies
- •Introduction
- •Virtual Topologies
- •Embedding in MPI
- •Overview of the Functions
- •Topology Constructors
- •Cartesian Constructor
- •Cartesian Convenience Function: MPI_DIMS_CREATE
- •General (Graph) Constructor
- •Distributed (Graph) Constructor
- •Topology Inquiry Functions
- •Cartesian Shift Coordinates
- •Partitioning of Cartesian structures
- •Low-Level Topology Functions
- •An Application Example
- •MPI Environmental Management
- •Implementation Information
- •Version Inquiries
- •Environmental Inquiries
- •Tag Values
- •Host Rank
- •IO Rank
- •Clock Synchronization
- •Memory Allocation
- •Error Handling
- •Error Handlers for Communicators
- •Error Handlers for Windows
- •Error Handlers for Files
- •Freeing Errorhandlers and Retrieving Error Strings
- •Error Codes and Classes
- •Error Classes, Error Codes, and Error Handlers
- •Timers and Synchronization
- •Startup
- •Allowing User Functions at Process Termination
- •Determining Whether MPI Has Finished
- •Portable MPI Process Startup
- •The Info Object
- •Process Creation and Management
- •Introduction
- •The Dynamic Process Model
- •Starting Processes
- •The Runtime Environment
- •Process Manager Interface
- •Processes in MPI
- •Starting Processes and Establishing Communication
- •Reserved Keys
- •Spawn Example
- •Manager-worker Example, Using MPI_COMM_SPAWN.
- •Establishing Communication
- •Names, Addresses, Ports, and All That
- •Server Routines
- •Client Routines
- •Name Publishing
- •Reserved Key Values
- •Client/Server Examples
- •Ocean/Atmosphere - Relies on Name Publishing
- •Simple Client-Server Example.
- •Other Functionality
- •Universe Size
- •Singleton MPI_INIT
- •MPI_APPNUM
- •Releasing Connections
- •Another Way to Establish MPI Communication
- •One-Sided Communications
- •Introduction
- •Initialization
- •Window Creation
- •Window Attributes
- •Communication Calls
- •Examples
- •Accumulate Functions
- •Synchronization Calls
- •Fence
- •General Active Target Synchronization
- •Lock
- •Assertions
- •Examples
- •Error Handling
- •Error Handlers
- •Error Classes
- •Semantics and Correctness
- •Atomicity
- •Progress
- •Registers and Compiler Optimizations
- •External Interfaces
- •Introduction
- •Generalized Requests
- •Examples
- •Associating Information with Status
- •MPI and Threads
- •General
- •Initialization
- •Introduction
- •File Manipulation
- •Opening a File
- •Closing a File
- •Deleting a File
- •Resizing a File
- •Preallocating Space for a File
- •Querying the Size of a File
- •Querying File Parameters
- •File Info
- •Reserved File Hints
- •File Views
- •Data Access
- •Data Access Routines
- •Positioning
- •Synchronism
- •Coordination
- •Data Access Conventions
- •Data Access with Individual File Pointers
- •Data Access with Shared File Pointers
- •Noncollective Operations
- •Collective Operations
- •Seek
- •Split Collective Data Access Routines
- •File Interoperability
- •Datatypes for File Interoperability
- •Extent Callback
- •Datarep Conversion Functions
- •Matching Data Representations
- •Consistency and Semantics
- •File Consistency
- •Random Access vs. Sequential Files
- •Progress
- •Collective File Operations
- •Type Matching
- •Logical vs. Physical File Layout
- •File Size
- •Examples
- •Asynchronous I/O
- •I/O Error Handling
- •I/O Error Classes
- •Examples
- •Subarray Filetype Constructor
- •Requirements
- •Discussion
- •Logic of the Design
- •Examples
- •MPI Library Implementation
- •Systems with Weak Symbols
- •Systems Without Weak Symbols
- •Complications
- •Multiple Counting
- •Linker Oddities
- •Multiple Levels of Interception
- •Deprecated Functions
- •Deprecated since MPI-2.0
- •Deprecated since MPI-2.2
- •Language Bindings
- •Overview
- •Design
- •C++ Classes for MPI
- •Class Member Functions for MPI
- •Semantics
- •C++ Datatypes
- •Communicators
- •Exceptions
- •Mixed-Language Operability
- •Problems With Fortran Bindings for MPI
- •Problems Due to Strong Typing
- •Problems Due to Data Copying and Sequence Association
- •Special Constants
- •Fortran 90 Derived Types
- •A Problem with Register Optimization
- •Basic Fortran Support
- •Extended Fortran Support
- •The mpi Module
- •No Type Mismatch Problems for Subroutines with Choice Arguments
- •Additional Support for Fortran Numeric Intrinsic Types
- •Language Interoperability
- •Introduction
- •Assumptions
- •Initialization
- •Transfer of Handles
- •Status
- •MPI Opaque Objects
- •Datatypes
- •Callback Functions
- •Error Handlers
- •Reduce Operations
- •Addresses
- •Attributes
- •Extra State
- •Constants
- •Interlanguage Communication
- •Language Bindings Summary
- •Groups, Contexts, Communicators, and Caching Fortran Bindings
- •External Interfaces C++ Bindings
- •Change-Log
- •Bibliography
- •Examples Index
- •MPI Declarations Index
- •MPI Function Index
Annex A
Language Bindings Summary
In this section we summarize the speci c bindings for C, Fortran, and C++. First we present the constants, type de nitions, info values and keys. Then we present the routine prototypes separately for each binding. Listings are alphabetical within chapter.
A.1 De ned Values and Handles
A.1.1 De ned Constants
The C and Fortran name is listed in the left column and the C++ name is listed in the middle or right column. Constants with the type const int may also be implemented as literal integer constants substituted by the preprocessor.
Return Codes
C type: const int (or unnamed enum) |
C++ type: const int |
Fortran type: INTEGER |
(or unnamed enum) |
|
|
MPI_SUCCESS |
MPI::SUCCESS |
MPI_ERR_BUFFER |
MPI::ERR_BUFFER |
MPI_ERR_COUNT |
MPI::ERR_COUNT |
MPI_ERR_TYPE |
MPI::ERR_TYPE |
MPI_ERR_TAG |
MPI::ERR_TAG |
MPI_ERR_COMM |
MPI::ERR_COMM |
MPI_ERR_RANK |
MPI::ERR_RANK |
MPI_ERR_REQUEST |
MPI::ERR_REQUEST |
MPI_ERR_ROOT |
MPI::ERR_ROOT |
MPI_ERR_GROUP |
MPI::ERR_GROUP |
MPI_ERR_OP |
MPI::ERR_OP |
MPI_ERR_TOPOLOGY |
MPI::ERR_TOPOLOGY |
MPI_ERR_DIMS |
MPI::ERR_DIMS |
MPI_ERR_ARG |
MPI::ERR_ARG |
MPI_ERR_UNKNOWN |
MPI::ERR_UNKNOWN |
MPI_ERR_TRUNCATE |
MPI::ERR_TRUNCATE |
MPI_ERR_OTHER |
MPI::ERR_OTHER |
MPI_ERR_INTERN |
MPI::ERR_INTERN |
MPI_ERR_PENDING |
MPI::ERR_PENDING |
(Continued on next page)
1
2
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
513
1
2
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
514 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
Return Codes (continued)
MPI_ERR_IN_STATUS MPI_ERR_ACCESS MPI_ERR_AMODE MPI_ERR_ASSERT MPI_ERR_BAD_FILE MPI_ERR_BASE MPI_ERR_CONVERSION MPI_ERR_DISP MPI_ERR_DUP_DATAREP MPI_ERR_FILE_EXISTS MPI_ERR_FILE_IN_USE MPI_ERR_FILE MPI_ERR_INFO_KEY MPI_ERR_INFO_NOKEY MPI_ERR_INFO_VALUE MPI_ERR_INFO MPI_ERR_IO MPI_ERR_KEYVAL MPI_ERR_LOCKTYPE MPI_ERR_NAME MPI_ERR_NO_MEM MPI_ERR_NOT_SAME MPI_ERR_NO_SPACE MPI_ERR_NO_SUCH_FILE MPI_ERR_PORT MPI_ERR_QUOTA MPI_ERR_READ_ONLY MPI_ERR_RMA_CONFLICT MPI_ERR_RMA_SYNC MPI_ERR_SERVICE MPI_ERR_SIZE MPI_ERR_SPAWN
MPI_ERR_UNSUPPORTED_DATAREP MPI_ERR_UNSUPPORTED_OPERATION MPI_ERR_WIN
MPI_ERR_LASTCODE
MPI::ERR_IN_STATUS MPI::ERR_ACCESS MPI::ERR_AMODE MPI::ERR_ASSERT MPI::ERR_BAD_FILE MPI::ERR_BASE MPI::ERR_CONVERSION MPI::ERR_DISP MPI::ERR_DUP_DATAREP MPI::ERR_FILE_EXISTS MPI::ERR_FILE_IN_USE MPI::ERR_FILE MPI::ERR_INFO_VALUE MPI::ERR_INFO_NOKEY MPI::ERR_INFO_KEY MPI::ERR_INFO MPI::ERR_IO MPI::ERR_KEYVAL MPI::ERR_LOCKTYPE MPI::ERR_NAME MPI::ERR_NO_MEM MPI::ERR_NOT_SAME MPI::ERR_NO_SPACE MPI::ERR_NO_SUCH_FILE MPI::ERR_PORT MPI::ERR_QUOTA MPI::ERR_READ_ONLY MPI::ERR_RMA_CONFLICT MPI::ERR_RMA_SYNC MPI::ERR_SERVICE MPI::ERR_SIZE MPI::ERR_SPAWN
MPI::ERR_UNSUPPORTED_DATAREP MPI::ERR_UNSUPPORTED_OPERATION MPI::ERR_WIN
MPI::ERR_LASTCODE
Bu er Address Constants
C type: void * const |
C++ type: |
Fortran type: (prede ned memory location) |
void * const |
|
|
MPI_BOTTOM |
MPI::BOTTOM |
MPI_IN_PLACE |
MPI::IN_PLACE |
|
|
A.1. DEFINED VALUES AND HANDLES |
515 |
||
|
Assorted Constants |
||
|
C type: const int (or unnamed enum) |
C++ type: |
|
|
Fortran type: INTEGER |
const int (or unnamed enum) |
|
|
|
|
|
|
MPI_PROC_NULL |
MPI::PROC_NULL |
|
|
MPI_ANY_SOURCE |
MPI::ANY_SOURCE |
|
|
MPI_ANY_TAG |
MPI::ANY_TAG |
|
|
MPI_UNDEFINED |
MPI::UNDEFINED |
|
|
MPI_BSEND_OVERHEAD |
MPI::BSEND_OVERHEAD |
|
|
MPI_KEYVAL_INVALID |
MPI::KEYVAL_INVALID |
|
|
MPI_LOCK_EXCLUSIVE |
MPI::LOCK_EXCLUSIVE |
|
|
MPI_LOCK_SHARED |
MPI::LOCK_SHARED |
|
|
MPI_ROOT |
MPI::ROOT |
|
|
|
|
|
Status size and reserved index values (Fortran only)
Fortran type: INTEGER
MPI_STATUS_SIZE |
Not de ned for C++ |
MPI_SOURCE |
Not de ned for C++ |
MPI_TAG |
Not de ned for C++ |
MPI_ERROR |
Not de ned for C++ |
|
|
Variable Address Size (Fortran only)
Fortran type: INTEGER
MPI_ADDRESS_KIND |
Not de ned for C++ |
MPI_INTEGER_KIND |
Not de ned for C++ |
MPI_OFFSET_KIND |
Not de ned for C++ |
|
|
Error-handling speci ers
C type: MPI_Errhandler |
C++ type: MPI::Errhandler |
Fortran type: INTEGER |
|
|
|
MPI_ERRORS_ARE_FATAL |
MPI::ERRORS_ARE_FATAL |
MPI_ERRORS_RETURN |
MPI::ERRORS_RETURN |
|
MPI::ERRORS_THROW_EXCEPTIONS |
|
|
Maximum Sizes for Strings
C type: const int (or unnamed enum) |
C++ type: |
Fortran type: INTEGER |
const int (or unnamed enum) |
MPI_MAX_PROCESSOR_NAME MPI_MAX_ERROR_STRING MPI_MAX_DATAREP_STRING MPI_MAX_INFO_KEY MPI_MAX_INFO_VAL MPI_MAX_OBJECT_NAME MPI_MAX_PORT_NAME
MPI::MAX_PROCESSOR_NAME MPI::MAX_ERROR_STRING MPI::MAX_DATAREP_STRING MPI::MAX_INFO_KEY MPI::MAX_INFO_VAL MPI::MAX_OBJECT_NAME MPI::MAX_PORT_NAME
1
2
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
1
2
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
516 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
||
Named Prede ned Datatypes |
|
C/C++ types |
|
|
|||
C type: MPI_Datatype |
C++ type: MPI::Datatype |
|
|
Fortran type: INTEGER |
|
|
|
|
|
|
|
MPI_CHAR |
MPI::CHAR |
|
char |
|
|
|
(treated as printable |
|
|
|
character) |
MPI_SHORT |
MPI::SHORT |
|
signed short int |
MPI_INT |
MPI::INT |
|
signed int |
MPI_LONG |
MPI::LONG |
|
signed long |
MPI_LONG_LONG_INT |
MPI::LONG_LONG_INT |
|
signed long long |
MPI_LONG_LONG |
MPI::LONG_LONG |
|
long long (synonym) |
MPI_SIGNED_CHAR |
MPI::SIGNED_CHAR |
|
signed char |
|
|
|
(treated as integral value) |
MPI_UNSIGNED_CHAR |
MPI::UNSIGNED_CHAR |
|
unsigned char |
|
|
|
(treated as integral value) |
MPI_UNSIGNED_SHORT |
MPI::UNSIGNED_SHORT |
|
unsigned short |
MPI_UNSIGNED |
MPI::UNSIGNED |
|
unsigned int |
MPI_UNSIGNED_LONG |
MPI::UNSIGNED_LONG |
|
unsigned long |
MPI_UNSIGNED_LONG_LONG |
MPI::UNSIGNED_LONG_LONG |
|
unsigned long long |
MPI_FLOAT |
MPI::FLOAT |
|
float |
MPI_DOUBLE |
MPI::DOUBLE |
|
double |
MPI_LONG_DOUBLE |
MPI::LONG_DOUBLE |
|
long double |
MPI_WCHAR |
MPI::WCHAR |
|
wchar_t |
|
|
|
(de ned in <stddef.h>) |
|
|
|
(treated as printable |
|
|
|
character) |
MPI_C_BOOL |
(use C datatype handle) |
|
_Bool |
MPI_INT8_T |
(use C datatype handle) |
|
int8_t |
MPI_INT16_T |
(use C datatype handle) |
|
int16_t |
MPI_INT32_T |
(use C datatype handle) |
|
int32_t |
MPI_INT64_T |
(use C datatype handle) |
|
int64_t |
MPI_UINT8_T |
(use C datatype handle) |
|
uint8_t |
MPI_UINT16_T |
(use C datatype handle) |
|
uint16_t |
MPI_UINT32_T |
(use C datatype handle) |
|
uint32_t |
MPI_UINT64_T |
(use C datatype handle) |
|
uint64_t |
MPI_AINT |
(use C datatype handle) |
|
MPI_Aint |
MPI_OFFSET |
(use C datatype handle) |
|
MPI_Offset |
MPI_C_COMPLEX |
(use C datatype handle) |
|
float _Complex |
MPI_C_FLOAT_COMPLEX |
(use C datatype handle) |
|
float _Complex |
MPI_C_DOUBLE_COMPLEX |
(use C datatype handle) |
|
double _Complex |
MPI_C_LONG_DOUBLE_COMPLEX |
(use C datatype handle) |
|
long double _Complex |
MPI_BYTE |
MPI::BYTE |
|
(any C/C++ type) |
MPI_PACKED |
MPI::PACKED |
|
(any C/C++ type) |
|
|
|
|
A.1. DEFINED VALUES AND HANDLES |
517 |
|
Named Prede ned Datatypes |
|
Fortran types |
|||
C type: MPI_Datatype |
C++ type: MPI::Datatype |
|
|
|
|
|
Fortran type: INTEGER |
|
|
|
|
|
|
|
|
|
|
|
|
|
MPI_INTEGER |
MPI::INTEGER |
|
INTEGER |
|||
MPI_REAL |
MPI::REAL |
|
REAL |
|||
MPI_DOUBLE_PRECISION |
MPI::DOUBLE_PRECISION |
|
DOUBLE PRECISION |
|||
MPI_COMPLEX |
MPI::F_COMPLEX |
|
COMPLEX |
|||
MPI_LOGICAL |
MPI::LOGICAL |
|
LOGICAL |
|||
MPI_CHARACTER |
MPI::CHARACTER |
|
CHARACTER(1) |
|||
MPI_AINT |
(use C datatype handle) |
|
INTEGER (KIND=MPI_ADDRESS_KIND) |
|||
MPI_OFFSET |
(use C datatype handle) |
|
INTEGER (KIND=MPI_OFFSET_KIND) |
|||
MPI_BYTE |
MPI::BYTE |
|
(any Fortran type) |
|||
MPI_PACKED |
MPI::PACKED |
|
(any Fortran type) |
|||
|
|
|
|
|
|
|
|
C++-Only Named Prede ned Datatypes |
|
C++ types |
|||
|
||||||
|
|
|
|
|
||
|
C++ type: MPI::Datatype |
|
|
|
||
|
|
|
|
|
|
|
|
MPI::BOOL |
|
|
|
bool |
|
|
MPI::COMPLEX |
|
|
|
Complex<float> |
|
|
MPI::DOUBLE_COMPLEX |
|
Complex<double> |
|||
|
MPI::LONG_DOUBLE_COMPLEX |
|
Complex<long double> |
|||
|
|
|
|
|
|
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
Optional datatypes (Fortran) |
Fortran types |
|
C type: MPI_Datatype |
C++ type: MPI::Datatype |
|
Fortran type: INTEGER |
|
|
|
|
|
MPI_DOUBLE_COMPLEX |
MPI::F_DOUBLE_COMPLEX |
DOUBLE COMPLEX |
MPI_INTEGER1 |
MPI::INTEGER1 |
INTEGER*1 |
MPI_INTEGER2 |
MPI::INTEGER2 |
INTEGER*8 |
MPI_INTEGER4 |
MPI::INTEGER4 |
INTEGER*4 |
MPI_INTEGER8 |
MPI::INTEGER8 |
INTEGER*8 |
MPI_INTEGER16 |
|
INTEGER*16 |
MPI_REAL2 |
MPI::REAL2 |
REAL*2 |
MPI_REAL4 |
MPI::REAL4 |
REAL*4 |
MPI_REAL8 |
MPI::REAL8 |
REAL*8 |
MPI_REAL16 |
|
REAL*16 |
MPI_COMPLEX4 |
|
COMPLEX*4 |
MPI_COMPLEX8 |
|
COMPLEX*8 |
MPI_COMPLEX16 |
|
COMPLEX*16 |
MPI_COMPLEX32 |
|
COMPLEX*32 |
|
|
|
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
1
2
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
518 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
Datatypes for reduction functions (C and C++)
C type: MPI_Datatype |
C++ type: MPI::Datatype |
Fortran type: INTEGER |
|
|
|
MPI_FLOAT_INT |
MPI::FLOAT_INT |
MPI_DOUBLE_INT |
MPI::DOUBLE_INT |
MPI_LONG_INT |
MPI::LONG_INT |
MPI_2INT |
MPI::TWOINT |
MPI_SHORT_INT |
MPI::SHORT_INT |
MPI_LONG_DOUBLE_INT |
MPI::LONG_DOUBLE_INT |
|
|
Datatypes for reduction functions (Fortran)
C type: MPI_Datatype |
C++ type: MPI::Datatype |
Fortran type: INTEGER |
|
|
|
MPI_2REAL |
MPI::TWOREAL |
MPI_2DOUBLE_PRECISION |
MPI::TWODOUBLE_PRECISION |
MPI_2INTEGER |
MPI::TWOINTEGER |
|
|
Special datatypes for constructing derived datatypes
C type: MPI_Datatype |
C++ type: MPI::Datatype |
Fortran type: INTEGER |
|
|
|
MPI_UB |
MPI::UB |
MPI_LB |
MPI::LB |
|
|
Reserved communicators
C type: MPI_Comm C++ type: MPI::Intracomm
Fortran type: INTEGER
MPI_COMM_WORLD MPI::COMM_WORLD
MPI_COMM_SELF MPI::COMM_SELF
Results of communicator and group comparisons
C type: const int (or unnamed enum) |
C++ type: const int |
Fortran type: INTEGER |
(or unnamed enum) |
|
|
MPI_IDENT |
MPI::IDENT |
MPI_CONGRUENT |
MPI::CONGRUENT |
MPI_SIMILAR |
MPI::SIMILAR |
MPI_UNEQUAL |
MPI::UNEQUAL |
|
|
Environmental inquiry keys
C type: const int (or unnamed enum) |
C++ type: const int |
Fortran type: INTEGER |
(or unnamed enum) |
|
|
MPI_TAG_UB |
MPI::TAG_UB |
MPI_IO |
MPI::IO |
MPI_HOST |
MPI::HOST |
MPI_WTIME_IS_GLOBAL |
MPI::WTIME_IS_GLOBAL |
|
|
A.1. DEFINED VALUES AND HANDLES |
519 |
Collective Operations
C type: MPI_Op |
C++ type: const MPI::Op |
Fortran type: INTEGER |
|
|
|
MPI_MAX |
MPI::MAX |
MPI_MIN |
MPI::MIN |
MPI_SUM |
MPI::SUM |
MPI_PROD |
MPI::PROD |
MPI_MAXLOC |
MPI::MAXLOC |
MPI_MINLOC |
MPI::MINLOC |
MPI_BAND |
MPI::BAND |
MPI_BOR |
MPI::BOR |
MPI_BXOR |
MPI::BXOR |
MPI_LAND |
MPI::LAND |
MPI_LOR |
MPI::LOR |
MPI_LXOR |
MPI::LXOR |
MPI_REPLACE |
MPI::REPLACE |
|
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
Null Handles |
19 |
||
|
|
|
|
|
|
|
|
C/Fortran name |
C++ name |
20 |
|
C type / Fortran type |
C++ type |
21 |
|
|
|
|
|
|
|
|
|
MPI_GROUP_NULL |
MPI::GROUP_NULL |
22 |
|
|
|
|
|
MPI_Group / INTEGER |
const MPI::Group |
23 |
|
|
|||
MPI_COMM_NULL |
MPI::COMM_NULL |
24 |
|
|
|
|
|
MPI_Comm / INTEGER |
1 |
) |
25 |
|
|
||
MPI_DATATYPE_NULL |
MPI::DATATYPE_NULL |
26 |
|
|
|
|
|
MPI_Datatype / INTEGER |
const MPI::Datatype |
27 |
|
|
|||
MPI_REQUEST_NULL |
MPI::REQUEST_NULL |
28 |
|
|
|
|
|
MPI_Request / INTEGER |
const MPI::Request |
29 |
|
|
|||
MPI_OP_NULL |
MPI::OP_NULL |
30 |
|
|
|
|
|
MPI_Op / INTEGER |
const MPI::Op |
31 |
|
|
|||
MPI_ERRHANDLER_NULL |
MPI::ERRHANDLER_NULL |
32 |
|
MPI_Errhandler / INTEGER |
const MPI::Errhandler |
33 |
|
|
|
|
|
MPI_FILE_NULL |
MPI::FILE_NULL |
34 |
|
|
|
|
|
MPI_File / INTEGER |
|
|
35 |
MPI::INFO_NULL |
|
||
MPI_INFO_NULL |
36 |
||
|
|
|
|
MPI_Info / INTEGER |
const MPI::Info |
37 |
|
|
|||
MPI_WIN_NULL |
MPI::WIN_NULL |
38 |
|
|
|
|
|
MPI_Win / INTEGER |
|
|
39 |
|
|
|
|
|
|
||
1) C++ type: See Section 16.1.7 on page 474 regarding |
40 |
||
class hierarchy and the speci c type of MPI::COMM_NULL |
41 |
||
|
|
|
42
43
Empty group
C type: MPI_Group C++ type: const MPI::Group
Fortran type: INTEGER
MPI_GROUP_EMPTY MPI::GROUP_EMPTY
44
45
46
47
48
1
2
3
4
5
6
7
8
520 ANNEX A. LANGUAGE BINDINGS SUMMARY
Topologies
C type: const int (or unnamed enum) |
C++ type: const int |
Fortran type: INTEGER |
(or unnamed enum) |
|
|
MPI_GRAPH |
MPI::GRAPH |
MPI_CART |
MPI::CART |
MPI_DIST_GRAPH |
MPI::DIST_GRAPH |
|
|
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
Prede ned functions
C/Fortran name |
C++ name |
C type / Fortran type |
C++ type |
|
|
MPI_COMM_NULL_COPY_FN |
MPI_COMM_NULL_COPY_FN |
MPI_Comm_copy_attr_function |
same as in C 1) |
/ COMM_COPY_ATTR_FN |
|
MPI_COMM_DUP_FN |
MPI_COMM_DUP_FN |
MPI_Comm_copy_attr_function |
same as in C 1) |
/ COMM_COPY_ATTR_FN |
|
MPI_COMM_NULL_DELETE_FN |
MPI_COMM_NULL_DELETE_FN |
MPI_Comm_delete_attr_function |
same as in C 1) |
/ COMM_DELETE_ATTR_FN |
|
|
|
MPI_WIN_NULL_COPY_FN |
MPI_WIN_NULL_COPY_FN |
MPI_Win_copy_attr_function |
same as in C 1) |
/ WIN_COPY_ATTR_FN |
|
MPI_WIN_DUP_FN |
MPI_WIN_DUP_FN |
MPI_Win_copy_attr_function |
same as in C 1) |
/ WIN_COPY_ATTR_FN |
|
MPI_WIN_NULL_DELETE_FN |
MPI_WIN_NULL_DELETE_FN |
MPI_Win_delete_attr_function |
same as in C 1) |
/ WIN_DELETE_ATTR_FN |
|
|
|
MPI_TYPE_NULL_COPY_FN |
MPI_TYPE_NULL_COPY_FN |
MPI_Type_copy_attr_function |
same as in C 1) |
/ TYPE_COPY_ATTR_FN |
|
33
34
35
MPI_TYPE_DUP_FN |
MPI_TYPE_DUP_FN |
MPI_Type_copy_attr_function |
same as in C 1) |
/ TYPE_COPY_ATTR_FN |
|
36 |
MPI_TYPE_NULL_DELETE_FN |
MPI_TYPE_NULL_DELETE_FN |
|
||
37 |
MPI_Type_delete_attr_function |
same as in C 1) |
|
||
38 |
/ TYPE_DELETE_ATTR_FN |
|
|
|
391 See the advice to implementors on MPI_COMM_NULL_COPY_FN, ... in
40Section 6.7.2 on page 226
41
42
43
44
45
46
47
48
A.1. DEFINED VALUES AND HANDLES |
|
521 |
|||||
|
|
Deprecated prede ned functions |
|||||
|
C/Fortran name |
|
C++ name |
|
|||
|
|
C type / Fortran type |
|
C++ type |
|||
|
|
|
|
|
|
|
|
|
MPI_NULL_COPY_FN |
|
MPI::NULL_COPY_FN |
||||
|
|
MPI_Copy_function / COPY_FUNCTION |
|
MPI::Copy_function |
|||
|
MPI_DUP_FN |
|
MPI::DUP_FN |
||||
|
|
MPI_Copy_function / COPY_FUNCTION |
|
MPI::Copy_function |
|||
|
MPI_NULL_DELETE_FN |
|
MPI::NULL_DELETE_FN |
||||
|
|
MPI_Delete_function / DELETE_FUNCTION |
MPI::Delete_function |
||||
|
|
|
|
|
|
||
|
|
Prede ned Attribute Keys |
|||||
|
|
|
|
|
|||
|
|
C type: const int (or unnamed enum) |
C++ type: |
|
|
||
|
|
Fortran type: INTEGER |
const int (or unnamed enum) |
||||
|
|
|
|
|
|
||
|
|
MPI_APPNUM |
MPI::APPNUM |
||||
|
|
MPI_LASTUSEDCODE |
MPI::LASTUSEDCODE |
||||
|
|
MPI_UNIVERSE_SIZE |
MPI::UNIVERSE_SIZE |
||||
|
|
MPI_WIN_BASE |
MPI::WIN_BASE |
||||
|
|
MPI_WIN_DISP_UNIT |
MPI::WIN_DISP_UNIT |
||||
|
|
MPI_WIN_SIZE |
MPI::WIN_SIZE |
||||
|
|
|
|
|
|
|
|
|
|
Mode Constants |
|
|
|
|
|
|
|
|
|||||
|
C type: const int (or unnamed enum) |
C++ type: |
|
||||
|
Fortran type: INTEGER |
const int (or unnamed enum) |
MPI_MODE_APPEND
MPI_MODE_CREATE MPI_MODE_DELETE_ON_CLOSE MPI_MODE_EXCL MPI_MODE_NOCHECK MPI_MODE_NOPRECEDE MPI_MODE_NOPUT MPI_MODE_NOSTORE MPI_MODE_NOSUCCEED MPI_MODE_RDONLY MPI_MODE_RDWR MPI_MODE_SEQUENTIAL MPI_MODE_UNIQUE_OPEN MPI_MODE_WRONLY
MPI::MODE_APPEND
MPI::MODE_CREATE MPI::MODE_DELETE_ON_CLOSE MPI::MODE_EXCL MPI::MODE_NOCHECK MPI::MODE_NOPRECEDE MPI::MODE_NOPUT MPI::MODE_NOSTORE MPI::MODE_NOSUCCEED MPI::MODE_RDONLY MPI::MODE_RDWR MPI::MODE_SEQUENTIAL MPI::MODE_UNIQUE_OPEN MPI::MODE_WRONLY
1
2
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
1
2
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
522 ANNEX A. LANGUAGE BINDINGS SUMMARY
Datatype Decoding Constants
C type: const int (or unnamed enum) |
C++ type: |
Fortran type: INTEGER |
const int (or unnamed enum) |
MPI_COMBINER_CONTIGUOUS MPI_COMBINER_DARRAY MPI_COMBINER_DUP MPI_COMBINER_F90_COMPLEX MPI_COMBINER_F90_INTEGER MPI_COMBINER_F90_REAL MPI_COMBINER_HINDEXED_INTEGER MPI_COMBINER_HINDEXED MPI_COMBINER_HVECTOR_INTEGER MPI_COMBINER_HVECTOR MPI_COMBINER_INDEXED_BLOCK MPI_COMBINER_INDEXED MPI_COMBINER_NAMED MPI_COMBINER_RESIZED MPI_COMBINER_STRUCT_INTEGER MPI_COMBINER_STRUCT MPI_COMBINER_SUBARRAY MPI_COMBINER_VECTOR
MPI::COMBINER_CONTIGUOUS MPI::COMBINER_DARRAY MPI::COMBINER_DUP MPI::COMBINER_F90_COMPLEX MPI::COMBINER_F90_INTEGER MPI::COMBINER_F90_REAL MPI::COMBINER_HINDEXED_INTEGER MPI::COMBINER_HINDEXED MPI::COMBINER_HVECTOR_INTEGER MPI::COMBINER_HVECTOR MPI::COMBINER_INDEXED_BLOCK MPI::COMBINER_INDEXED MPI::COMBINER_NAMED MPI::COMBINER_RESIZED MPI::COMBINER_STRUCT_INTEGER MPI::COMBINER_STRUCT MPI::COMBINER_SUBARRAY MPI::COMBINER_VECTOR
Threads Constants
C type: const int (or unnamed enum) |
C++ type: |
Fortran type: INTEGER |
const int (or unnamed enum) |
|
|
MPI_THREAD_FUNNELED |
MPI::THREAD_FUNNELED |
MPI_THREAD_MULTIPLE |
MPI::THREAD_MULTIPLE |
MPI_THREAD_SERIALIZED |
MPI::THREAD_SERIALIZED |
MPI_THREAD_SINGLE |
MPI::THREAD_SINGLE |
|
|
File Operation Constants, Part 1
C type: const MPI_Offset (or unnamed enum) |
C++ type: |
Fortran type: INTEGER (KIND=MPI_OFFSET_KIND) |
const MPI::Offset (or unnamed enum) |
|
|
MPI_DISPLACEMENT_CURRENT |
MPI::DISPLACEMENT_CURRENT |
|
|
A.1. DEFINED VALUES AND HANDLES |
523 |
||
|
File Operation Constants, Part 2 |
||
|
C type: const int (or unnamed enum) |
C++ type: |
|
|
Fortran type: INTEGER |
const int (or unnamed enum) |
MPI_DISTRIBUTE_BLOCK MPI_DISTRIBUTE_CYCLIC MPI_DISTRIBUTE_DFLT_DARG MPI_DISTRIBUTE_NONE MPI_ORDER_C MPI_ORDER_FORTRAN MPI_SEEK_CUR MPI_SEEK_END MPI_SEEK_SET
MPI::DISTRIBUTE_BLOCK MPI::DISTRIBUTE_CYCLIC MPI::DISTRIBUTE_DFLT_DARG MPI::DISTRIBUTE_NONE MPI::ORDER_C MPI::ORDER_FORTRAN MPI::SEEK_CUR MPI::SEEK_END MPI::SEEK_SET
F90 Datatype Matching Constants
C type: const int (or unnamed enum) |
C++ type: |
Fortran type: INTEGER |
const int (or unnamed enum) |
|
|
MPI_TYPECLASS_COMPLEX |
MPI::TYPECLASS_COMPLEX |
MPI_TYPECLASS_INTEGER |
MPI::TYPECLASS_INTEGER |
MPI_TYPECLASS_REAL |
MPI::TYPECLASS_REAL |
|
|
Constants Specifying Empty or Ignored Input
C/Fortran name |
C++ name |
C type / Fortran type |
C++ type |
|
|
MPI_ARGVS_NULL |
MPI::ARGVS_NULL |
char*** / 2-dim. array of CHARACTER*(*) |
const char *** |
MPI_ARGV_NULL |
MPI::ARGV_NULL |
char** / array of CHARACTER*(*) |
const char ** |
|
|
MPI_ERRCODES_IGNORE |
Not de ned for C++ |
int* / INTEGER array |
|
MPI_STATUSES_IGNORE |
Not de ned for C++ |
MPI_Status* / INTEGER, DIMENSION(MPI_STATUS_SIZE,*) |
|
MPI_STATUS_IGNORE |
Not de ned for C++ |
MPI_Status* / INTEGER, DIMENSION(MPI_STATUS_SIZE) |
|
MPI_UNWEIGHTED |
Not de ned for C++ |
|
|
C Constants Specifying Ignored Input (no C++ or Fortran)
C type: MPI_Fint*
MPI_F_STATUSES_IGNORE
MPI_F_STATUS_IGNORE
C and C++ preprocessor Constants and Fortran Parameters
C/C++ type: const int (or unnamed enum)
Fortran type: INTEGER
MPI_SUBVERSION
1
2
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
MPI_VERSION |
48 |
1
2
524 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
A.1.2 Types
The following are de ned C type de nitions, included in the le mpi.h.
3
4/* C opaque types */
5MPI_Aint
6MPI_Fint
7MPI_O set
8MPI_Status
9
10/* C handles to assorted structures */
11MPI_Comm
12MPI_Datatype
13MPI_Errhandler
14MPI_File
15MPI_Group
16MPI_Info
17MPI_Op
18MPI_Request
19MPI_Win
20
21// C++ opaque types (all within the MPI namespace)
22MPI::Aint
23MPI::O set
24MPI::Status
25
26// C++ handles to assorted structures (classes,
27// all within the MPI namespace)
28MPI::Comm
29MPI::Intracomm
30MPI::Graphcomm
31MPI::Distgraphcomm
32MPI::Cartcomm
33MPI::Intercomm
34MPI::Datatype
35MPI::Errhandler
36MPI::Exception
37MPI::File
38MPI::Group
39MPI::Info
40MPI::Op
41MPI::Request
42MPI::Prequest
43MPI::Grequest
44MPI::Win
45
46
47
48
A.1. DEFINED VALUES AND HANDLES |
525 |
A.1.3 Prototype de nitions
The following are de ned C typedefs for user-de ned functions, also included in the le mpi.h.
/* prototypes for user-defined functions */
typedef void MPI_User_function(void *invec, void *inoutvec, int *len, MPI_Datatype *datatype);
typedef int MPI_Comm_copy_attr_function(MPI_Comm oldcomm,
int comm_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int*flag);
typedef int MPI_Comm_delete_attr_function(MPI_Comm comm,
int comm_keyval, void *attribute_val, void *extra_state);
typedef int MPI_Win_copy_attr_function(MPI_Win oldwin, int win_keyval, void *extra_state, void *attribute_val_in,
void *attribute_val_out, int *flag);
typedef int MPI_Win_delete_attr_function(MPI_Win win, int win_keyval, void *attribute_val, void *extra_state);
typedef int MPI_Type_copy_attr_function(MPI_Datatype oldtype, int type_keyval, void *extra_state,
void *attribute_val_in, void *attribute_val_out, int *flag); typedef int MPI_Type_delete_attr_function(MPI_Datatype type,
int type_keyval, void *attribute_val, void *extra_state);
typedef void MPI_Comm_errhandler_function(MPI_Comm *, int *, ...); typedef void MPI_Win_errhandler_function(MPI_Win *, int *, ...); typedef void MPI_File_errhandler_function(MPI_File *, int *, ...);
typedef int MPI_Grequest_query_function(void *extra_state, MPI_Status *status);
typedef int MPI_Grequest_free_function(void *extra_state);
typedef int MPI_Grequest_cancel_function(void *extra_state, int complete);
typedef int MPI_Datarep_extent_function(MPI_Datatype datatype, MPI_Aint *file_extent, void *extra_state);
typedef int MPI_Datarep_conversion_function(void *userbuf, MPI_Datatype datatype, int count, void *filebuf, MPI_Offset position, void *extra_state);
For Fortran, here are examples of how each of the user-de ned subroutines should be declared.
The user-function argument to MPI_OP_CREATE should be declared like this:
SUBROUTINE USER_FUNCTION(INVEC, INOUTVEC, LEN, TYPE) <type> INVEC(LEN), INOUTVEC(LEN)
INTEGER LEN, TYPE
1
2
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
526 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1The copy and delete function arguments to MPI_COMM_CREATE_KEYVAL should be
2
3
declared like these:
4SUBROUTINE COMM_COPY_ATTR_FN(OLDCOMM, COMM_KEYVAL, EXTRA_STATE,
5
6
ATTRIBUTE_VAL_IN, ATTRIBUTE_VAL_OUT, FLAG, IERROR)
INTEGER OLDCOMM, COMM_KEYVAL, IERROR
7INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE, ATTRIBUTE_VAL_IN,
8
9
ATTRIBUTE_VAL_OUT LOGICAL FLAG
10 |
|
11 |
SUBROUTINE COMM_DELETE_ATTR_FN(COMM, COMM_KEYVAL, ATTRIBUTE_VAL, |
12 |
EXTRA_STATE, IERROR) |
13INTEGER COMM, COMM_KEYVAL, IERROR
14INTEGER(KIND=MPI_ADDRESS_KIND) ATTRIBUTE_VAL, EXTRA_STATE
15
The copy and delete function arguments to MPI_WIN_CREATE_KEYVAL should be
16
declared like these:
17
18
SUBROUTINE WIN_COPY_ATTR_FN(OLDWIN, WIN_KEYVAL, EXTRA_STATE,
19
ATTRIBUTE_VAL_IN, ATTRIBUTE_VAL_OUT, FLAG, IERROR)
20
INTEGER OLDWIN, WIN_KEYVAL, IERROR
21
INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE, ATTRIBUTE_VAL_IN,
22
ATTRIBUTE_VAL_OUT
23
LOGICAL FLAG
24
25
SUBROUTINE WIN_DELETE_ATTR_FN(WIN, WIN_KEYVAL, ATTRIBUTE_VAL,
26
EXTRA_STATE, IERROR)
27
INTEGER WIN, WIN_KEYVAL, IERROR
28
INTEGER(KIND=MPI_ADDRESS_KIND) ATTRIBUTE_VAL, EXTRA_STATE
29
30The copy and delete function arguments to MPI_TYPE_CREATE_KEYVAL should be
31declared like these:
32 |
|
|
33 |
SUBROUTINE TYPE_COPY_ATTR_FN(OLDTYPE, TYPE_KEYVAL, |
EXTRA_STATE, |
34 |
ATTRIBUTE_VAL_IN, ATTRIBUTE_VAL_OUT, |
FLAG, IERROR) |
35INTEGER OLDTYPE, TYPE_KEYVAL, IERROR
36INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE,
37 |
|
ATTRIBUTE_VAL_IN, ATTRIBUTE_VAL_OUT |
38 |
LOGICAL |
FLAG |
39 |
|
|
40 |
SUBROUTINE |
TYPE_DELETE_ATTR_FN(TYPE, TYPE_KEYVAL, ATTRIBUTE_VAL, |
41 |
|
EXTRA_STATE, IERROR) |
42INTEGER TYPE, TYPE_KEYVAL, IERROR
43INTEGER(KIND=MPI_ADDRESS_KIND) ATTRIBUTE_VAL, EXTRA_STATE
44
The handler-function argument to MPI_COMM_CREATE_ERRHANDLER should be de-
45
clared like this:
46
47SUBROUTINE COMM_ERRHANDLER_FUNCTION(COMM, ERROR_CODE)
48INTEGER COMM, ERROR_CODE
A.1. DEFINED VALUES AND HANDLES |
527 |
The handler-function argument to MPI_WIN_CREATE_ERRHANDLER should be declared like this:
SUBROUTINE WIN_ERRHANDLER_FUNCTION(WIN, ERROR_CODE)
INTEGER WIN, ERROR_CODE
The handler-function argument to MPI_FILE_CREATE_ERRHANDLER should be declared like this:
SUBROUTINE FILE_ERRHANDLER_FUNCTION(FILE, ERROR_CODE)
INTEGER FILE, ERROR_CODE
The query, free, and cancel function arguments to MPI_GREQUEST_START should be declared like these:
SUBROUTINE GREQUEST_QUERY_FUNCTION(EXTRA_STATE, STATUS, IERROR) INTEGER STATUS(MPI_STATUS_SIZE), IERROR INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE
SUBROUTINE GREQUEST_FREE_FUNCTION(EXTRA_STATE, IERROR)
INTEGER IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE
SUBROUTINE GREQUEST_CANCEL_FUNCTION(EXTRA_STATE, COMPLETE, IERROR) INTEGER IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE
LOGICAL COMPLETE
The extend and conversion function arguments to MPI_REGISTER_DATAREP should be declared like these:
SUBROUTINE DATAREP_EXTENT_FUNCTION(DATATYPE, EXTENT, EXTRA_STATE, IERROR) INTEGER DATATYPE, IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) EXTENT, EXTRA_STATE
SUBROUTINE DATAREP_CONVERSION_FUNCTION(USERBUF, DATATYPE, COUNT, FILEBUF, POSITION, EXTRA_STATE, IERROR)
<TYPE> USERBUF(*), FILEBUF(*)
INTEGER COUNT, DATATYPE, IERROR
INTEGER(KIND=MPI_OFFSET_KIND) POSITION
INTEGER(KIND=MPI_ADDRESS_KIND) EXTRA_STATE
The following are de ned C++ typedefs, also included in the le mpi.h.
namespace MPI {
typedef void User_function(const void* invec, void *inoutvec, int len, const Datatype& datatype);
1
2
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
typedef int Comm::Copy_attr_function(const Comm& oldcomm, |
48 |
|
1
2
528 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
int comm_keyval, void* extra_state, void* attribute_val_in, void* attribute_val_out, bool& flag);
3typedef int Comm::Delete_attr_function(Comm& comm, int
4
5
comm_keyval, void* attribute_val, void* extra_state);
6typedef int Win::Copy_attr_function(const Win& oldwin,
7
8
9
10
11
12
13
14
15
16
17
18
int win_keyval, void* extra_state, void* attribute_val_in, void* attribute_val_out, bool& flag);
typedef int Win::Delete_attr_function(Win& win, int
win_keyval, void* attribute_val, void* extra_state);
typedef int Datatype::Copy_attr_function(const Datatype& oldtype, int type_keyval, void* extra_state,
const void* attribute_val_in, void* attribute_val_out, bool& flag);
typedef int Datatype::Delete_attr_function(Datatype& type,
int type_keyval, void* attribute_val, void* extra_state);
19typedef void Comm::Errhandler_function(Comm &, int *, ...);
20typedef void Win::Errhandler_function(Win &, int *, ...);
21typedef void File::Errhandler_function(File &, int *, ...);
22
23typedef int Grequest::Query_function(void* extra_state, Status& status);
24typedef int Grequest::Free_function(void* extra_state);
25typedef int Grequest::Cancel_function(void* extra_state, bool complete);
26
27
28
29
30
31
32 }
33
typedef void Datarep_extent_function(const Datatype& datatype, Aint& file_extent, void* extra_state);
typedef void Datarep_conversion_function(void* userbuf, Datatype& datatype, int count, void* filebuf, Offset position, void* extra_state);
34 |
A.1.4 Deprecated prototype de nitions |
|
|
35 |
|
36The following are de ned C typedefs for deprecated user-de ned functions, also included in
37the le mpi.h.
38
/* prototypes for user-defined functions */
39
typedef int MPI_Copy_function(MPI_Comm oldcomm, int keyval,
40
void *extra_state, void *attribute_val_in,
41
void *attribute_val_out, int *flag);
42
typedef int MPI_Delete_function(MPI_Comm comm, int keyval,
43
void *attribute_val, void *extra_state);
44
typedef void MPI_Handler_function(MPI_Comm *, int *, ...);
45
46The following are deprecated Fortran user-de ned callback subroutine prototypes. The
47deprecated copy and delete function arguments to MPI_KEYVAL_CREATE should be de-
48clared like these:
A.1. DEFINED VALUES AND HANDLES |
529 |
SUBROUTINE COPY_FUNCTION(OLDCOMM, KEYVAL, EXTRA_STATE, ATTRIBUTE_VAL_IN, ATTRIBUTE_VAL_OUT, FLAG, IERR)
INTEGER OLDCOMM, KEYVAL, EXTRA_STATE, ATTRIBUTE_VAL_IN,
ATTRIBUTE_VAL_OUT, IERR
LOGICAL FLAG
SUBROUTINE DELETE_FUNCTION(COMM, KEYVAL, ATTRIBUTE_VAL, EXTRA_STATE, IERR) INTEGER COMM, KEYVAL, ATTRIBUTE_VAL, EXTRA_STATE, IERR
The deprecated handler-function for error handlers should be declared like this:
SUBROUTINE HANDLER_FUNCTION(COMM, ERROR_CODE)
INTEGER COMM, ERROR_CODE
A.1.5 Info Keys
access_style appnum arch
cb_block_size cb_bu er_size cb_nodes chunked_item chunked_size chunked collective_bu eringle_perm
lenamele host
io_node_list ip_address ip_port nb_proc no_locks num_io_nodes path
soft striping_factor striping_unit wdir
A.1.6 Info Values
false random read_mostly read_once
1
2
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
1
2
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
530 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
reverse_sequential sequential
true write_mostly write_once
A.2. C BINDINGS |
531 |
A.2 C Bindings
A.2.1 Point-to-Point Communication C Bindings
int MPI_Bsend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm)
int MPI_Bsend_init(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Buffer_attach(void* buffer, int size)
int MPI_Buffer_detach(void* buffer_addr, int* size) int MPI_Cancel(MPI_Request *request)
int MPI_Get_count(MPI_Status *status, MPI_Datatype datatype, int *count)
int MPI_Ibsend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Iprobe(int source, int tag, MPI_Comm comm, int *flag, MPI_Status *status)
int MPI_Irecv(void* buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Irsend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Isend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Issend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Probe(int source, int tag, MPI_Comm comm, MPI_Status *status)
int MPI_Recv(void* buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Status *status)
int MPI_Recv_init(void* buf, int count, MPI_Datatype datatype, int source, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Request_free(MPI_Request *request)
int MPI_Request_get_status(MPI_Request request, int *flag, MPI_Status *status)
int MPI_Rsend(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm)
int MPI_Rsend_init(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm, MPI_Request *request)
int MPI_Send(void* buf, int count, MPI_Datatype datatype, int dest, int tag, MPI_Comm comm)
1
2
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
532 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1int MPI_Send_init(void* buf, int count, MPI_Datatype datatype, int dest,
2
3
int tag, MPI_Comm comm, MPI_Request *request)
4int MPI_Sendrecv(void *sendbuf, int sendcount, MPI_Datatype sendtype,
5
6
7
int dest, int sendtag, void *recvbuf, int recvcount,
MPI_Datatype recvtype, int source, int recvtag, MPI_Comm comm,
MPI_Status *status)
8int MPI_Sendrecv_replace(void* buf, int count, MPI_Datatype datatype,
9 |
int dest, int sendtag, int source, int recvtag, MPI_Comm comm, |
|
|
||
10 |
MPI_Status *status) |
|
|
||
11 |
|
|
12 |
int MPI_Ssend(void* buf, int count, MPI_Datatype datatype, int dest, |
|
13 |
int tag, MPI_Comm comm) |
|
14 |
int MPI_Ssend_init(void* buf, int count, MPI_Datatype datatype, int dest, |
|
|
||
15 |
int tag, MPI_Comm comm, MPI_Request *request) |
|
|
||
16 |
|
|
17 |
int MPI_Start(MPI_Request *request) |
|
18 |
int MPI_Startall(int count, MPI_Request *array_of_requests) |
|
|
||
19 |
|
|
20 |
int MPI_Test(MPI_Request *request, int *flag, MPI_Status *status) |
|
21 |
int MPI_Test_cancelled(MPI_Status *status, int *flag) |
|
22 |
||
|
||
23 |
int MPI_Testall(int count, MPI_Request *array_of_requests, int *flag, |
|
24 |
MPI_Status *array_of_statuses) |
|
25 |
int MPI_Testany(int count, MPI_Request *array_of_requests, int *index, |
|
26 |
||
int *flag, MPI_Status *status) |
||
27 |
||
|
||
28 |
int MPI_Testsome(int incount, MPI_Request *array_of_requests, |
|
29 |
int *outcount, int *array_of_indices, |
|
30 |
MPI_Status *array_of_statuses) |
|
31 |
|
int MPI_Wait(MPI_Request *request, MPI_Status *status)
32
33 |
int MPI_Waitall(int count, MPI_Request *array_of_requests, |
|
|
||
34 |
MPI_Status *array_of_statuses) |
|
|
||
35 |
int MPI_Waitany(int count, MPI_Request *array_of_requests, int *index, |
|
36 |
||
MPI_Status *status) |
||
37 |
||
|
||
38 |
int MPI_Waitsome(int incount, MPI_Request *array_of_requests, |
|
|
||
39 |
int *outcount, int *array_of_indices, |
|
|
||
40 |
MPI_Status *array_of_statuses) |
|
|
41
42
43
44
45
46
47
48
A.2.2 Datatypes C Bindings
int MPI_Get_address(void *location, MPI_Aint *address)
int MPI_Get_elements(MPI_Status *status, MPI_Datatype datatype, int *count)
A.2. C BINDINGS |
533 |
int MPI_Pack(void* inbuf, int incount, MPI_Datatype datatype, void *outbuf, int outsize, int *position, MPI_Comm comm)
int MPI_Pack_external(char *datarep, void *inbuf, int incount, MPI_Datatype datatype, void *outbuf, MPI_Aint outsize, MPI_Aint *position)
int MPI_Pack_external_size(char *datarep, int incount, MPI_Datatype datatype, MPI_Aint *size)
int MPI_Pack_size(int incount, MPI_Datatype datatype, MPI_Comm comm, int *size)
int MPI_Type_commit(MPI_Datatype *datatype)
int MPI_Type_contiguous(int count, MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_create_darray(int size, int rank, int ndims,
int array_of_gsizes[], int array_of_distribs[], int array_of_dargs[], int array_of_psizes[], int order, MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_create_hindexed(int count, int array_of_blocklengths[], MPI_Aint array_of_displacements[], MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_create_hvector(int count, int blocklength, MPI_Aint stride, MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_create_indexed_block(int count, int blocklength, int array_of_displacements[], MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_create_resized(MPI_Datatype oldtype, MPI_Aint lb, MPI_Aint extent, MPI_Datatype *newtype)
int MPI_Type_create_struct(int count, int array_of_blocklengths[], MPI_Aint array_of_displacements[],
MPI_Datatype array_of_types[], MPI_Datatype *newtype)
int MPI_Type_create_subarray(int ndims, int array_of_sizes[],
int array_of_subsizes[], int array_of_starts[], int order, MPI_Datatype oldtype, MPI_Datatype *newtype)
int MPI_Type_dup(MPI_Datatype type, MPI_Datatype *newtype) int MPI_Type_free(MPI_Datatype *datatype)
int MPI_Type_get_contents(MPI_Datatype datatype, int max_integers,
int max_addresses, int max_datatypes, int array_of_integers[], MPI_Aint array_of_addresses[],
MPI_Datatype array_of_datatypes[])
1
2
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
int MPI_Type_get_envelope(MPI_Datatype datatype, int *num_integers,
48
1
2
534 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
int *num_addresses, int *num_datatypes, int *combiner)
3int MPI_Type_get_extent(MPI_Datatype datatype, MPI_Aint *lb,
4 |
MPI_Aint *extent) |
|
5int MPI_Type_get_true_extent(MPI_Datatype datatype, MPI_Aint *true_lb,
6
7
MPI_Aint *true_extent)
8int MPI_Type_indexed(int count, int *array_of_blocklengths,
9 |
int *array_of_displacements, MPI_Datatype oldtype, |
10 |
MPI_Datatype *newtype) |
11 |
int MPI_Type_size(MPI_Datatype datatype, int *size) |
|
|
12 |
|
13 |
int MPI_Type_vector(int count, int blocklength, int stride, |
14 |
MPI_Datatype oldtype, MPI_Datatype *newtype) |
15 |
int MPI_Unpack(void* inbuf, int insize, int *position, void *outbuf, |
|
|
16 |
int outcount, MPI_Datatype datatype, MPI_Comm comm) |
|
|
17 |
|
18 |
int MPI_Unpack_external(char *datarep, void *inbuf, MPI_Aint insize, |
19 |
MPI_Aint *position, void *outbuf, int outcount, |
|
MPI_Datatype datatype) |
|
int |
MPI_Barrier(MPI_Comm comm) |
45 |
|
|
46 |
int |
MPI_Bcast(void* buffer, int count, MPI_Datatype datatype, int root, |
47 |
|
MPI_Comm comm ) |
48 |
|
|
A.2. C BINDINGS |
535 |
int MPI_Exscan(void *sendbuf, void *recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm)
int MPI_Gather(void* sendbuf, int sendcount, MPI_Datatype sendtype,
void* recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm)
int MPI_Gatherv(void* sendbuf, int sendcount, MPI_Datatype sendtype, void* recvbuf, int *recvcounts, int *displs, MPI_Datatype recvtype, int root, MPI_Comm comm)
int MPI_Op_commutative(MPI_Op op, int *commute)
int MPI_Op_create(MPI_User_function *function, int commute, MPI_Op *op)
int MPI_Reduce(void* sendbuf, void* recvbuf, int count,
MPI_Datatype datatype, MPI_Op op, int root, MPI_Comm comm)
int MPI_Reduce_local(void* inbuf, void* inoutbuf, int count, MPI_Datatype datatype, MPI_Op op)
int MPI_Reduce_scatter(void* sendbuf, void* recvbuf, int *recvcounts, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm)
int MPI_Reduce_scatter_block(void* sendbuf, void* recvbuf, int recvcount, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm)
int MPI_Scan(void* sendbuf, void* recvbuf, int count, MPI_Datatype datatype, MPI_Op op, MPI_Comm comm )
int MPI_Scatter(void* sendbuf, int sendcount, MPI_Datatype sendtype,
void* recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm)
int MPI_Scatterv(void* sendbuf, int *sendcounts, int *displs, MPI_Datatype sendtype, void* recvbuf, int recvcount, MPI_Datatype recvtype, int root, MPI_Comm comm)
int MPI_op_free( MPI_Op *op)
A.2.4 Groups, Contexts, Communicators, and Caching C Bindings
int MPI_COMM_DUP_FN(MPI_Comm oldcomm, int comm_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_COMM_NULL_COPY_FN(MPI_Comm oldcomm, int comm_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_COMM_NULL_DELETE_FN(MPI_Comm comm, int comm_keyval, void *attribute_val, void *extra_state)
int MPI_Comm_compare(MPI_Comm comm1,MPI_Comm comm2, int *result)
int MPI_Comm_create(MPI_Comm comm, MPI_Group group, MPI_Comm *newcomm)
1
2
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
536 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1int MPI_Comm_create_keyval(MPI_Comm_copy_attr_function *comm_copy_attr_fn,
2
3
4
MPI_Comm_delete_attr_function *comm_delete_attr_fn,
int *comm_keyval, void *extra_state)
5int MPI_Comm_delete_attr(MPI_Comm comm, int comm_keyval)
6 |
int MPI_Comm_dup(MPI_Comm comm, MPI_Comm *newcomm) |
|
|
||
7 |
|
|
8 |
int MPI_Comm_free(MPI_Comm *comm) |
|
9 |
int MPI_Comm_free_keyval(int *comm_keyval) |
|
|
||
10 |
|
|
11 |
int MPI_Comm_get_attr(MPI_Comm comm, int comm_keyval, void *attribute_val, |
|
12 |
int *flag) |
|
13 |
int MPI_Comm_get_name(MPI_Comm comm, char *comm_name, int *resultlen) |
|
|
||
14 |
|
|
15 |
int MPI_Comm_group(MPI_Comm comm, MPI_Group *group) |
|
16 |
int MPI_Comm_rank(MPI_Comm comm, int *rank) |
|
17 |
||
|
||
18 |
int MPI_Comm_remote_group(MPI_Comm comm, MPI_Group *group) |
|
19 |
int MPI_Comm_remote_size(MPI_Comm comm, int *size) |
|
20 |
||
|
||
21 |
int MPI_Comm_set_attr(MPI_Comm comm, int comm_keyval, void *attribute_val) |
|
22 |
|
int MPI_Comm_set_name(MPI_Comm comm, char *comm_name)
23 |
|
|
24 |
int MPI_Comm_size(MPI_Comm comm, int *size) |
|
|
||
25 |
int MPI_Comm_split(MPI_Comm comm, int color, int key, MPI_Comm *newcomm) |
|
26 |
||
|
||
27 |
int MPI_Comm_test_inter(MPI_Comm comm, int *flag) |
|
|
||
28 |
|
|
29 |
int MPI_Group_compare(MPI_Group group1,MPI_Group group2, int *result) |
|
|
||
30 |
int MPI_Group_difference(MPI_Group group1, MPI_Group group2, |
|
|
||
31 |
MPI_Group *newgroup) |
|
|
||
32 |
|
33int MPI_Group_excl(MPI_Group group, int n, int *ranks, MPI_Group *newgroup)
34int MPI_Group_free(MPI_Group *group)
A.2. C BINDINGS |
537 |
int MPI_Group_translate_ranks (MPI_Group group1, int n, int *ranks1, MPI_Group group2, int *ranks2)
int MPI_Group_union(MPI_Group group1, MPI_Group group2, MPI_Group *newgroup)
int MPI_Intercomm_create(MPI_Comm local_comm, int local_leader, MPI_Comm peer_comm, int remote_leader, int tag, MPI_Comm *newintercomm)
int MPI_Intercomm_merge(MPI_Comm intercomm, int high, MPI_Comm *newintracomm)
int MPI_TYPE_DUP_FN(MPI_Datatype oldtype, int type_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_TYPE_NULL_COPY_FN(MPI_Datatype oldtype, int type_keyval, void *extra_state, void *attribute_val_in,
void *attribute_val_out, int *flag)
int MPI_TYPE_NULL_DELETE_FN(MPI_Datatype type, int type_keyval, void *attribute_val, void *extra_state)
int MPI_Type_create_keyval(MPI_Type_copy_attr_function *type_copy_attr_fn, MPI_Type_delete_attr_function *type_delete_attr_fn,
int *type_keyval, void *extra_state)
int MPI_Type_delete_attr(MPI_Datatype type, int type_keyval) int MPI_Type_free_keyval(int *type_keyval)
int MPI_Type_get_attr(MPI_Datatype type, int type_keyval, void *attribute_val, int *flag)
int MPI_Type_get_name(MPI_Datatype type, char *type_name, int *resultlen)
int MPI_Type_set_attr(MPI_Datatype type, int type_keyval, void *attribute_val)
int MPI_Type_set_name(MPI_Datatype type, char *type_name)
int MPI_WIN_DUP_FN(MPI_Win oldwin, int win_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_WIN_NULL_COPY_FN(MPI_Win oldwin, int win_keyval, void *extra_state, void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_WIN_NULL_DELETE_FN(MPI_Win win, int win_keyval, void *attribute_val, void *extra_state)
int MPI_Win_create_keyval(MPI_Win_copy_attr_function *win_copy_attr_fn, MPI_Win_delete_attr_function *win_delete_attr_fn,
int *win_keyval, void *extra_state)
1
2
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
int MPI_Win_delete_attr(MPI_Win win, int win_keyval) |
48 |
|
538 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1
2
int MPI_Win_free_keyval(int *win_keyval)
3int MPI_Win_get_attr(MPI_Win win, int win_keyval, void *attribute_val,
4 |
int *flag) |
|
5int MPI_Win_get_name(MPI_Win win, char *win_name, int *resultlen)
6
7int MPI_Win_set_attr(MPI_Win win, int win_keyval, void *attribute_val)
8int MPI_Win_set_name(MPI_Win win, char *win_name)
9
10
11 |
A.2.5 Process Topologies C Bindings |
|
12 |
int MPI_Cart_coords(MPI_Comm comm, int rank, int maxdims, int *coords) |
|
13 |
||
|
||
14 |
int MPI_Cart_create(MPI_Comm comm_old, int ndims, int *dims, int *periods, |
|
15 |
int reorder, MPI_Comm *comm_cart) |
16
int MPI_Cart_get(MPI_Comm comm, int maxdims, int *dims, int *periods,
17
int *coords)
18
19 |
int MPI_Cart_map(MPI_Comm comm, int ndims, int *dims, int *periods, |
|
|
||
20 |
int *newrank) |
|
|
||
21 |
int MPI_Cart_rank(MPI_Comm comm, int *coords, int *rank) |
|
22 |
||
|
||
23 |
int MPI_Cart_shift(MPI_Comm comm, int direction, int disp, |
|
|
||
24 |
int *rank_source, int *rank_dest) |
|
|
||
25 |
|
|
26 |
int MPI_Cart_sub(MPI_Comm comm, int *remain_dims, MPI_Comm *newcomm) |
|
|
||
27 |
int MPI_Cartdim_get(MPI_Comm comm, int *ndims) |
|
|
||
28 |
|
29int MPI_Dims_create(int nnodes, int ndims, int *dims)
30int MPI_Dist_graph_create(MPI_Comm comm_old, int n, int sources[],
31
32
33
int degrees[], int destinations[], int weights[], MPI_Info info, int reorder, MPI_Comm *comm_dist_graph)
34 |
int MPI_Dist_graph_create_adjacent(MPI_Comm comm_old, int indegree, |
35 |
int sources[], int sourceweights[], int outdegree, |
36 |
int destinations[], int destweights[], MPI_Info info, |
37 |
int reorder, MPI_Comm *comm_dist_graph) |
38 |
int MPI_Dist_graph_neighbors(MPI_Comm comm, int maxindegree, int sources[], |
|
|
39 |
int sourceweights[], int maxoutdegree, int destinations[], |
|
|
40 |
int destweights[]) |
|
|
41 |
|
42 |
int MPI_Dist_graph_neighbors_count(MPI_Comm comm, int *indegree, |
43 |
int *outdegree, int *weighted) |
44 |
int MPI_Graph_create(MPI_Comm comm_old, int nnodes, int *index, int *edges, |
|
|
45 |
int reorder, MPI_Comm *comm_graph) |
|
|
46 |
|
47 |
int MPI_Graph_get(MPI_Comm comm, int maxindex, int maxedges, int *index, |
48 |
int *edges) |
A.2. C BINDINGS |
539 |
int MPI_Graph_map(MPI_Comm comm, int nnodes, int *index, int *edges, int *newrank)
int MPI_Graph_neighbors(MPI_Comm comm, int rank, int maxneighbors, int *neighbors)
int MPI_Graph_neighbors_count(MPI_Comm comm, int rank, int *nneighbors) int MPI_Graphdims_get(MPI_Comm comm, int *nnodes, int *nedges)
int MPI_Topo_test(MPI_Comm comm, int *status)
A.2.6 MPI Environmenta Management C Bindings double MPI_Wtick(void)
double MPI_Wtime(void)
int MPI_Abort(MPI_Comm comm, int errorcode) int MPI_Add_error_class(int *errorclass)
int MPI_Add_error_code(int errorclass, int *errorcode) int MPI_Add_error_string(int errorcode, char *string)
int MPI_Alloc_mem(MPI_Aint size, MPI_Info info, void *baseptr) int MPI_Comm_call_errhandler(MPI_Comm comm, int errorcode)
int MPI_Comm_create_errhandler(MPI_Comm_errhandler_function *function, MPI_Errhandler *errhandler)
int MPI_Comm_get_errhandler(MPI_Comm comm, MPI_Errhandler *errhandler) int MPI_Comm_set_errhandler(MPI_Comm comm, MPI_Errhandler errhandler) int MPI_Errhandler_free(MPI_Errhandler *errhandler)
int MPI_Error_class(int errorcode, int *errorclass)
int MPI_Error_string(int errorcode, char *string, int *resultlen) int MPI_File_call_errhandler(MPI_File fh, int errorcode)
int MPI_File_create_errhandler(MPI_File_errhandler_function *function, MPI_Errhandler *errhandler)
int MPI_File_get_errhandler(MPI_File file, MPI_Errhandler *errhandler) int MPI_File_set_errhandler(MPI_File file, MPI_Errhandler errhandler) int MPI_Finalize(void)
int MPI_Finalized(int *flag) int MPI_Free_mem(void *base)
int MPI_Get_processor_name(char *name, int *resultlen)
1
2
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
1
2
3
4
5
6
540 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
int MPI_Get_version(int *version, int *subversion) int MPI_Init(int *argc, char ***argv)
int MPI_Initialized(int *flag)
int MPI_Win_call_errhandler(MPI_Win win, int errorcode)
7int MPI_Win_create_errhandler(MPI_Win_errhandler_function *function,
8
9
MPI_Errhandler *errhandler)
10 int MPI_Win_get_errhandler(MPI_Win win, MPI_Errhandler *errhandler)
11 |
int MPI_Win_set_errhandler(MPI_Win win, MPI_Errhandler errhandler) |
|
|
||
12 |
|
|
13 |
|
|
14 |
A.2.7 The Info Object C Bindings |
|
|
||
15 |
int MPI_Info_create(MPI_Info *info) |
|
16 |
||
|
||
17 |
int MPI_Info_delete(MPI_Info info, char *key) |
|
|
||
18 |
int MPI_Info_dup(MPI_Info info, MPI_Info *newinfo) |
|
19 |
||
|
||
20 |
int MPI_Info_free(MPI_Info *info) |
|
|
||
21 |
|
|
22 |
int MPI_Info_get(MPI_Info info, char *key, int valuelen, char *value, |
|
|
||
23 |
int *flag) |
|
|
||
24 |
int MPI_Info_get_nkeys(MPI_Info info, int *nkeys) |
|
|
||
25 |
|
26int MPI_Info_get_nthkey(MPI_Info info, int n, char *key)
27int MPI_Info_get_valuelen(MPI_Info info, char *key, int *valuelen,
28
29
int *flag)
30
31
32
33
int MPI_Info_set(MPI_Info info, char *key, char *value)
A.2.8 Process Creation and Management C Bindings
34 int MPI_Close_port(char *port_name)
35
int MPI_Comm_accept(char *port_name, MPI_Info info, int root,
36
MPI_Comm comm, MPI_Comm *newcomm)
37
38 |
int MPI_Comm_connect(char *port_name, MPI_Info info, int root, |
|
|
39 |
MPI_Comm comm, MPI_Comm *newcomm) |
|
A.2. C BINDINGS |
541 |
int MPI_Comm_spawn_multiple(int count, char *array_of_commands[], char **array_of_argv[], int array_of_maxprocs[], MPI_Info array_of_info[], int root, MPI_Comm comm, MPI_Comm *intercomm, int array_of_errcodes[])
int MPI_Lookup_name(char *service_name, MPI_Info info, char *port_name) int MPI_Open_port(MPI_Info info, char *port_name)
int MPI_Publish_name(char *service_name, MPI_Info info, char *port_name) int MPI_Unpublish_name(char *service_name, MPI_Info info, char *port_name)
A.2.9 One-Sided Communications C Bindings
int MPI_Accumulate(void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count,
MPI_Datatype target_datatype, MPI_Op op, MPI_Win win)
int MPI_Get(void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win)
int MPI_Put(void *origin_addr, int origin_count, MPI_Datatype origin_datatype, int target_rank, MPI_Aint target_disp, int target_count, MPI_Datatype target_datatype, MPI_Win win)
int MPI_Win_complete(MPI_Win win)
int MPI_Win_create(void *base, MPI_Aint size, int disp_unit, MPI_Info info, MPI_Comm comm, MPI_Win *win)
int MPI_Win_fence(int assert, MPI_Win win) int MPI_Win_free(MPI_Win *win)
int MPI_Win_get_group(MPI_Win win, MPI_Group *group)
int MPI_Win_lock(int lock_type, int rank, int assert, MPI_Win win) int MPI_Win_post(MPI_Group group, int assert, MPI_Win win)
int MPI_Win_start(MPI_Group group, int assert, MPI_Win win) int MPI_Win_test(MPI_Win win, int *flag)
int MPI_Win_unlock(int rank, MPI_Win win) int MPI_Win_wait(MPI_Win win)
A.2.10 External Interfaces C Bindings
int MPI_Grequest_complete(MPI_Request request)
1
2
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
542 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1int MPI_Grequest_start(MPI_Grequest_query_function *query_fn,
2
3
4
5
MPI_Grequest_free_function *free_fn,
MPI_Grequest_cancel_function *cancel_fn, void *extra_state,
MPI_Request *request)
6int MPI_Init_thread(int *argc, char *((*argv)[]), int required,
7
8
9
int *provided)
int MPI_Is_thread_main(int *flag)
10int MPI_Query_thread(int *provided)
11int MPI_Status_set_cancelled(MPI_Status *status, int flag)
12
13
14
15
16
17
int MPI_Status_set_elements(MPI_Status *status, MPI_Datatype datatype,
int count)
A.2.11 I/O C Bindings
18 int MPI_File_close(MPI_File *fh)
19
int MPI_File_delete(char *filename, MPI_Info info)
20 |
|
|
21 |
int MPI_File_get_amode(MPI_File fh, int *amode) |
|
|
||
22 |
int MPI_File_get_atomicity(MPI_File fh, int *flag) |
|
23 |
||
|
||
24 |
int MPI_File_get_byte_offset(MPI_File fh, MPI_Offset offset, |
|
|
||
25 |
MPI_Offset *disp) |
|
|
||
26 |
|
|
27 |
int MPI_File_get_group(MPI_File fh, MPI_Group *group) |
|
|
||
28 |
int MPI_File_get_info(MPI_File fh, MPI_Info *info_used) |
|
|
||
29 |
|
30int MPI_File_get_position(MPI_File fh, MPI_Offset *offset)
31int MPI_File_get_position_shared(MPI_File fh, MPI_Offset *offset)
32 |
|
|
33 |
int MPI_File_get_size(MPI_File fh, MPI_Offset *size) |
|
34 |
int MPI_File_get_type_extent(MPI_File fh, MPI_Datatype datatype, |
|
|
||
35 |
MPI_Aint *extent) |
|
|
||
36 |
|
|
37 |
int MPI_File_get_view(MPI_File fh, MPI_Offset *disp, MPI_Datatype *etype, |
|
38 |
MPI_Datatype *filetype, char *datarep) |
|
39 |
int MPI_File_iread(MPI_File fh, void *buf, int count, |
|
|
||
40 |
MPI_Datatype datatype, MPI_Request *request) |
|
|
||
41 |
|
|
42 |
int MPI_File_iread_at(MPI_File fh, MPI_Offset offset, void *buf, int count, |
|
43 |
MPI_Datatype datatype, MPI_Request *request) |
|
44 |
int MPI_File_iread_shared(MPI_File fh, void *buf, int count, |
|
45 |
||
MPI_Datatype datatype, MPI_Request *request) |
||
46 |
||
|
||
47 |
int MPI_File_iwrite(MPI_File fh, void *buf, int count, |
|
48 |
MPI_Datatype datatype, MPI_Request *request) |
A.2. C BINDINGS |
543 |
int MPI_File_iwrite_at(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype, MPI_Request *request)
int MPI_File_iwrite_shared(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Request *request)
int MPI_File_open(MPI_Comm comm, char *filename, int amode, MPI_Info info, MPI_File *fh)
int MPI_File_preallocate(MPI_File fh, MPI_Offset size)
int MPI_File_read(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_read_all(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_read_all_begin(MPI_File fh, void *buf, int count, MPI_Datatype datatype)
int MPI_File_read_all_end(MPI_File fh, void *buf, MPI_Status *status)
int MPI_File_read_at(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_read_at_all(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_read_at_all_begin(MPI_File fh, MPI_Offset offset, void *buf, int count, MPI_Datatype datatype)
int MPI_File_read_at_all_end(MPI_File fh, void *buf, MPI_Status *status)
int MPI_File_read_ordered(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_read_ordered_begin(MPI_File fh, void *buf, int count, MPI_Datatype datatype)
int MPI_File_read_ordered_end(MPI_File fh, void *buf, MPI_Status *status)
int MPI_File_read_shared(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
int MPI_File_seek(MPI_File fh, MPI_Offset offset, int whence)
int MPI_File_seek_shared(MPI_File fh, MPI_Offset offset, int whence) int MPI_File_set_atomicity(MPI_File fh, int flag)
int MPI_File_set_info(MPI_File fh, MPI_Info info) int MPI_File_set_size(MPI_File fh, MPI_Offset size)
int MPI_File_set_view(MPI_File fh, MPI_Offset disp, MPI_Datatype etype, MPI_Datatype filetype, char *datarep, MPI_Info info)
1
2
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
int MPI_File_sync(MPI_File fh) |
48 |
1
2
3
544 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
int MPI_File_write(MPI_File fh, void *buf, int count, MPI_Datatype datatype, MPI_Status *status)
4int MPI_File_write_all(MPI_File fh, void *buf, int count,
5 |
MPI_Datatype datatype, MPI_Status *status) |
|
6int MPI_File_write_all_begin(MPI_File fh, void *buf, int count,
7
8
MPI_Datatype datatype)
9int MPI_File_write_all_end(MPI_File fh, void *buf, MPI_Status *status)
10 |
int MPI_File_write_at(MPI_File fh, MPI_Offset offset, void *buf, int count, |
|
|
||
11 |
MPI_Datatype datatype, MPI_Status *status) |
|
|
||
12 |
|
|
13 |
int MPI_File_write_at_all(MPI_File fh, MPI_Offset offset, void *buf, |
|
14 |
int count, MPI_Datatype datatype, MPI_Status *status) |
|
15 |
int MPI_File_write_at_all_begin(MPI_File fh, MPI_Offset offset, void *buf, |
|
|
||
16 |
int count, MPI_Datatype datatype) |
|
|
||
17 |
|
|
18 |
int MPI_File_write_at_all_end(MPI_File fh, void *buf, MPI_Status *status) |
|
19 |
int MPI_File_write_ordered(MPI_File fh, void *buf, int count, |
|
20 |
||
MPI_Datatype datatype, MPI_Status *status) |
||
21 |
||
|
||
22 |
int MPI_File_write_ordered_begin(MPI_File fh, void *buf, int count, |
|
23 |
MPI_Datatype datatype) |
|
24 |
int MPI_File_write_ordered_end(MPI_File fh, void *buf, MPI_Status *status) |
|
25 |
||
|
||
26 |
int MPI_File_write_shared(MPI_File fh, void *buf, int count, |
|
27 |
MPI_Datatype datatype, MPI_Status *status) |
|
28 |
|
int MPI_Register_datarep(char *datarep,
29
MPI_Datarep_conversion_function *read_conversion_fn,
30
MPI_Datarep_conversion_function *write_conversion_fn,
31
MPI_Datarep_extent_function *dtype_file_extent_fn,
32
void *extra_state)
33 |
|
34 |
|
35 |
A.2.12 Language Bindings C Bindings |
|
|
36 |
|
37int MPI_Type_create_f90_complex(int p, int r, MPI_Datatype *newtype)
38int MPI_Type_create_f90_integer(int r, MPI_Datatype *newtype)
39 |
|
40 |
int MPI_Type_create_f90_real(int p, int r, MPI_Datatype *newtype) |
41 |
int MPI_Type_match_size(int typeclass, int size, MPI_Datatype *type) |
|
|
42 |
|
43 |
MPI_Fint MPI_Comm_c2f(MPI_Comm comm) |
44 |
MPI_Comm MPI_Comm_f2c(MPI_Fint comm) |
|
|
45 |
|
46 |
MPI_Fint MPI_Errhandler_c2f(MPI_Errhandler errhandler) |
47 |
MPI_Errhandler MPI_Errhandler_f2c(MPI_Fint errhandler) |
|
48
A.2. C BINDINGS |
545 |
MPI_Fint MPI_File_c2f(MPI_File file)
MPI_File MPI_File_f2c(MPI_Fint file)
MPI_Fint MPI_Group_c2f(MPI_Group group)
MPI_Group MPI_Group_f2c(MPI_Fint group)
MPI_Fint MPI_Info_c2f(MPI_Info info)
MPI_Info MPI_Info_f2c(MPI_Fint info)
MPI_Fint MPI_Op_c2f(MPI_Op op)
MPI_Op MPI_Op_f2c(MPI_Fint op)
MPI_Fint MPI_Request_c2f(MPI_Request request)
MPI_Request MPI_Request_f2c(MPI_Fint request)
int MPI_Status_c2f(MPI_Status *c_status, MPI_Fint *f_status) int MPI_Status_f2c(MPI_Fint *f_status, MPI_Status *c_status) MPI_Fint MPI_Type_c2f(MPI_Datatype datatype)
MPI_Datatype MPI_Type_f2c(MPI_Fint datatype)
MPI_Fint MPI_Win_c2f(MPI_Win win)
MPI_Win MPI_Win_f2c(MPI_Fint win)
A.2.13 Pro ling Interface C Bindings
int MPI_Pcontrol(const int level, ...)
A.2.14 Deprecated C Bindings
int MPI_Address(void* location, MPI_Aint *address) int MPI_Attr_delete(MPI_Comm comm, int keyval)
int MPI_Attr_get(MPI_Comm comm, int keyval, void *attribute_val, int *flag) int MPI_Attr_put(MPI_Comm comm, int keyval, void* attribute_val)
int MPI_DUP_FN(MPI_Comm oldcomm, int keyval, void *extra_state,
void *attribute_val_in, void *attribute_val_out, int *flag)
int MPI_Errhandler_create(MPI_Handler_function *function, MPI_Errhandler *errhandler)
int MPI_Errhandler_get(MPI_Comm comm, MPI_Errhandler *errhandler) int MPI_Errhandler_set(MPI_Comm comm, MPI_Errhandler errhandler)
int MPI_Keyval_create(MPI_Copy_function *copy_fn, MPI_Delete_function *delete_fn, int *keyval, void* extra_state)
1
2
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
1
2
546 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
int MPI_Keyval_free(int *keyval)
3int MPI_NULL_COPY_FN(MPI_Comm oldcomm, int keyval, void *extra_state,
4 |
void *attribute_val_in, void *attribute_val_out, int *flag) |
|
5int MPI_NULL_DELETE_FN(MPI_Comm comm, int keyval, void *attribute_val,
6
7
void *extra_state)
8int MPI_Type_extent(MPI_Datatype datatype, MPI_Aint *extent)
9int MPI_Type_hindexed(int count, int *array_of_blocklengths,
10
11
12
MPI_Aint *array_of_displacements, MPI_Datatype oldtype, MPI_Datatype *newtype)
13 |
int MPI_Type_hvector(int count, int blocklength, MPI_Aint stride, |
14 |
MPI_Datatype oldtype, MPI_Datatype *newtype) |
15 |
int MPI_Type_lb(MPI_Datatype datatype, MPI_Aint* displacement) |
|
|
16 |
|
17 |
int MPI_Type_struct(int count, int *array_of_blocklengths, |
18 |
MPI_Aint *array_of_displacements, |
19 |
MPI_Datatype *array_of_types, MPI_Datatype *newtype) |
20
int MPI_Type_ub(MPI_Datatype datatype, MPI_Aint* displacement)
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
A.3. FORTRAN BINDINGS |
547 |
A.3 Fortran Bindings
A.3.1 Point-to-Point Communication Fortran Bindings
MPI_BSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, IERROR
MPI_BSEND_INIT(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER REQUEST, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
MPI_BUFFER_ATTACH(BUFFER, SIZE, IERROR) <type> BUFFER(*)
INTEGER SIZE, IERROR
MPI_BUFFER_DETACH(BUFFER_ADDR, SIZE, IERROR) <type> BUFFER_ADDR(*)
INTEGER SIZE, IERROR
MPI_CANCEL(REQUEST, IERROR)
INTEGER REQUEST, IERROR
MPI_GET_COUNT(STATUS, DATATYPE, COUNT, IERROR)
INTEGER STATUS(MPI_STATUS_SIZE), DATATYPE, COUNT, IERROR
MPI_IBSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
MPI_IPROBE(SOURCE, TAG, COMM, FLAG, STATUS, IERROR)
LOGICAL FLAG
INTEGER SOURCE, TAG, COMM, STATUS(MPI_STATUS_SIZE), IERROR
MPI_IRECV(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, SOURCE, TAG, COMM, REQUEST, IERROR
MPI_IRSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
MPI_ISEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
MPI_ISSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR) <type> BUF(*)
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
MPI_PROBE(SOURCE, TAG, COMM, STATUS, IERROR)
INTEGER SOURCE, TAG, COMM, STATUS(MPI_STATUS_SIZE), IERROR
MPI_RECV(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, STATUS, IERROR)
1
2
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
548 ANNEX A. LANGUAGE BINDINGS SUMMARY
1 |
<type> BUF(*) |
|
2INTEGER COUNT, DATATYPE, SOURCE, TAG, COMM, STATUS(MPI_STATUS_SIZE),
3
4
IERROR
5MPI_RECV_INIT(BUF, COUNT, DATATYPE, SOURCE, TAG, COMM, REQUEST, IERROR)
6 |
<type> BUF(*) |
|
7INTEGER COUNT, DATATYPE, SOURCE, TAG, COMM, REQUEST, IERROR
8
9
10
MPI_REQUEST_FREE(REQUEST, IERROR)
INTEGER REQUEST, IERROR
11MPI_REQUEST_GET_STATUS( REQUEST, FLAG, STATUS, IERROR)
12INTEGER REQUEST, STATUS(MPI_STATUS_SIZE), IERROR
13LOGICAL FLAG
14MPI_RSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR)
15<type> BUF(*)
16INTEGER COUNT, DATATYPE, DEST, TAG, COMM, IERROR
17
18MPI_RSEND_INIT(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR)
19<type> BUF(*)
20INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
21 |
MPI_SEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR) |
|
|
22 |
<type> BUF(*) |
|
|
23 |
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, IERROR |
|
|
24 |
|
25 |
MPI_SENDRECV(SENDBUF, SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVBUF, |
26 |
RECVCOUNT, RECVTYPE, SOURCE, RECVTAG, COMM, STATUS, IERROR) |
27<type> SENDBUF(*), RECVBUF(*)
28INTEGER SENDCOUNT, SENDTYPE, DEST, SENDTAG, RECVCOUNT, RECVTYPE,
29SOURCE, RECVTAG, COMM, STATUS(MPI_STATUS_SIZE), IERROR
30
MPI_SENDRECV_REPLACE(BUF, COUNT, DATATYPE, DEST, SENDTAG, SOURCE, RECVTAG,
31
COMM, STATUS, IERROR)
32
<type> BUF(*)
33
INTEGER COUNT, DATATYPE, DEST, SENDTAG, SOURCE, RECVTAG, COMM,
34
STATUS(MPI_STATUS_SIZE), IERROR
35
36MPI_SEND_INIT(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR)
37<type> BUF(*)
38INTEGER REQUEST, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
39
MPI_SSEND(BUF, COUNT, DATATYPE, DEST, TAG, COMM, IERROR)
40
<type> BUF(*)
41
INTEGER COUNT, DATATYPE, DEST, TAG, COMM, IERROR
42
43MPI_SSEND_INIT(BUF, COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR)
44<type> BUF(*)
45INTEGER COUNT, DATATYPE, DEST, TAG, COMM, REQUEST, IERROR
46
MPI_START(REQUEST, IERROR)
47
INTEGER REQUEST, IERROR
48
A.3. FORTRAN BINDINGS |
549 |
|
MPI_STARTALL(COUNT, ARRAY_OF_REQUESTS, IERROR) |
|
|
INTEGER COUNT, |
ARRAY_OF_REQUESTS(*), IERROR |
|
MPI_TEST(REQUEST, FLAG, STATUS, IERROR) |
|
|
LOGICAL FLAG |
|
|
INTEGER REQUEST, STATUS(MPI_STATUS_SIZE), IERROR |
|
|
MPI_TESTALL(COUNT, |
ARRAY_OF_REQUESTS, FLAG, ARRAY_OF_STATUSES, IERROR) |
|
LOGICAL FLAG |
|
|
INTEGER COUNT, |
ARRAY_OF_REQUESTS(*), |
|
ARRAY_OF_STATUSES(MPI_STATUS_SIZE,*), IERROR |
|
|
MPI_TESTANY(COUNT, |
ARRAY_OF_REQUESTS, INDEX, FLAG, STATUS, IERROR) |
|
LOGICAL FLAG |
|
|
INTEGER COUNT, |
ARRAY_OF_REQUESTS(*), INDEX, STATUS(MPI_STATUS_SIZE), |
|
IERROR |
|
|
MPI_TESTSOME(INCOUNT, ARRAY_OF_REQUESTS, OUTCOUNT, ARRAY_OF_INDICES, ARRAY_OF_STATUSES, IERROR)
INTEGER INCOUNT, ARRAY_OF_REQUESTS(*), OUTCOUNT, ARRAY_OF_INDICES(*), ARRAY_OF_STATUSES(MPI_STATUS_SIZE,*), IERROR
MPI_TEST_CANCELLED(STATUS, FLAG, IERROR)
LOGICAL FLAG
INTEGER STATUS(MPI_STATUS_SIZE), IERROR
MPI_WAIT(REQUEST, STATUS, IERROR)
INTEGER REQUEST, STATUS(MPI_STATUS_SIZE), IERROR
MPI_WAITALL(COUNT, ARRAY_OF_REQUESTS, ARRAY_OF_STATUSES, IERROR) INTEGER COUNT, ARRAY_OF_REQUESTS(*)
INTEGER ARRAY_OF_STATUSES(MPI_STATUS_SIZE,*), IERROR
MPI_WAITANY(COUNT, ARRAY_OF_REQUESTS, INDEX, STATUS, IERROR)
INTEGER COUNT, ARRAY_OF_REQUESTS(*), INDEX, STATUS(MPI_STATUS_SIZE), IERROR
MPI_WAITSOME(INCOUNT, ARRAY_OF_REQUESTS, OUTCOUNT, ARRAY_OF_INDICES, ARRAY_OF_STATUSES, IERROR)
INTEGER INCOUNT, ARRAY_OF_REQUESTS(*), OUTCOUNT, ARRAY_OF_INDICES(*), ARRAY_OF_STATUSES(MPI_STATUS_SIZE,*), IERROR
A.3.2 Datatypes Fortran Bindings
MPI_GET_ADDRESS(LOCATION, ADDRESS, IERROR) <type> LOCATION(*)
INTEGER IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) ADDRESS
MPI_GET_ELEMENTS(STATUS, DATATYPE, COUNT, IERROR)
INTEGER STATUS(MPI_STATUS_SIZE), DATATYPE, COUNT, IERROR
MPI_PACK(INBUF, INCOUNT, DATATYPE, OUTBUF, OUTSIZE, POSITION, COMM, IERROR)
1
2
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
550 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
1<type> INBUF(*), OUTBUF(*)
2INTEGER INCOUNT, DATATYPE, OUTSIZE, POSITION, COMM, IERROR
3
4MPI_PACK_EXTERNAL(DATAREP, INBUF, INCOUNT, DATATYPE, OUTBUF, OUTSIZE,
5
6
7
8
9
POSITION, IERROR)
INTEGER INCOUNT, DATATYPE, IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) OUTSIZE, POSITION
CHARACTER*(*) DATAREP
<type> INBUF(*), OUTBUF(*)
10MPI_PACK_EXTERNAL_SIZE(DATAREP, INCOUNT, DATATYPE, SIZE, IERROR)
11INTEGER INCOUNT, DATATYPE, IERROR
12INTEGER(KIND=MPI_ADDRESS_KIND) SIZE
13CHARACTER*(*) DATAREP
14
15MPI_PACK_SIZE(INCOUNT, DATATYPE, COMM, SIZE, IERROR)
16INTEGER INCOUNT, DATATYPE, COMM, SIZE, IERROR
17MPI_TYPE_COMMIT(DATATYPE, IERROR)
18INTEGER DATATYPE, IERROR
19
20 |
MPI_TYPE_CONTIGUOUS(COUNT, OLDTYPE, NEWTYPE, IERROR) |
21 |
INTEGER COUNT, OLDTYPE, NEWTYPE, IERROR |
22 |
MPI_TYPE_CREATE_DARRAY(SIZE, RANK, NDIMS, ARRAY_OF_GSIZES, |
|
|
23 |
ARRAY_OF_DISTRIBS, ARRAY_OF_DARGS, ARRAY_OF_PSIZES, ORDER, |
|
|
24 |
OLDTYPE, NEWTYPE, IERROR) |
|
|
25 |
INTEGER SIZE, RANK, NDIMS, ARRAY_OF_GSIZES(*), ARRAY_OF_DISTRIBS(*), |
|
|
26 |
ARRAY_OF_DARGS(*), ARRAY_OF_PSIZES(*), ORDER, OLDTYPE, NEWTYPE, IERROR |
|
|
27 |
|
28 |
MPI_TYPE_CREATE_HINDEXED(COUNT, ARRAY_OF_BLOCKLENGTHS, |
29 |
ARRAY_OF_DISPLACEMENTS, OLDTYPE, NEWTYPE, IERROR) |
30INTEGER COUNT, ARRAY_OF_BLOCKLENGTHS(*), OLDTYPE, NEWTYPE, IERROR
31INTEGER(KIND=MPI_ADDRESS_KIND) ARRAY_OF_DISPLACEMENTS(*)
32
MPI_TYPE_CREATE_HVECTOR(COUNT, BLOCKLENGTH, STRIDE, OLDTYPE, NEWTYPE,
33
IERROR)
34
35 |
INTEGER COUNT, BLOCKLENGTH, OLDTYPE, NEWTYPE, IERROR |
|
INTEGER(KIND=MPI_ADDRESS_KIND) STRIDE |
||
36 |
||
|
||
37 |
MPI_TYPE_CREATE_INDEXED_BLOCK(COUNT, BLOCKLENGTH, ARRAY_OF_DISPLACEMENTS, |
|
38 |
OLDTYPE, NEWTYPE, IERROR) |
39INTEGER COUNT, BLOCKLENGTH, ARRAY_OF_DISPLACEMENTS(*), OLDTYPE,
40NEWTYPE, IERROR
41
MPI_TYPE_CREATE_RESIZED(OLDTYPE, LB, EXTENT, NEWTYPE, IERROR)
42
43 |
INTEGER OLDTYPE, NEWTYPE, IERROR |
|
INTEGER(KIND=MPI_ADDRESS_KIND) LB, EXTENT |
||
44 |
||
|
||
45 |
MPI_TYPE_CREATE_STRUCT(COUNT, ARRAY_OF_BLOCKLENGTHS, |
|
46 |
ARRAY_OF_DISPLACEMENTS, ARRAY_OF_TYPES, NEWTYPE, IERROR) |
47INTEGER COUNT, ARRAY_OF_BLOCKLENGTHS(*), ARRAY_OF_TYPES(*), NEWTYPE,
48IERROR
A.3. FORTRAN BINDINGS |
551 |
INTEGER(KIND=MPI_ADDRESS_KIND) ARRAY_OF_DISPLACEMENTS(*)
MPI_TYPE_CREATE_SUBARRAY(NDIMS, ARRAY_OF_SIZES, ARRAY_OF_SUBSIZES, ARRAY_OF_STARTS, ORDER, OLDTYPE, NEWTYPE, IERROR)
INTEGER NDIMS, ARRAY_OF_SIZES(*), ARRAY_OF_SUBSIZES(*),
ARRAY_OF_STARTS(*), ORDER, OLDTYPE, NEWTYPE, IERROR
MPI_TYPE_DUP(TYPE, NEWTYPE, IERROR)
INTEGER TYPE, NEWTYPE, IERROR
MPI_TYPE_FREE(DATATYPE, IERROR)
INTEGER DATATYPE, IERROR
MPI_TYPE_GET_CONTENTS(DATATYPE, MAX_INTEGERS, MAX_ADDRESSES, MAX_DATATYPES, ARRAY_OF_INTEGERS, ARRAY_OF_ADDRESSES, ARRAY_OF_DATATYPES, IERROR)
INTEGER DATATYPE, MAX_INTEGERS, MAX_ADDRESSES, MAX_DATATYPES, ARRAY_OF_INTEGERS(*), ARRAY_OF_DATATYPES(*), IERROR INTEGER(KIND=MPI_ADDRESS_KIND) ARRAY_OF_ADDRESSES(*)
MPI_TYPE_GET_ENVELOPE(DATATYPE, NUM_INTEGERS, NUM_ADDRESSES, NUM_DATATYPES, COMBINER, IERROR)
INTEGER DATATYPE, NUM_INTEGERS, NUM_ADDRESSES, NUM_DATATYPES, COMBINER, IERROR
MPI_TYPE_GET_EXTENT(DATATYPE, LB, EXTENT, IERROR)
INTEGER DATATYPE, IERROR
INTEGER(KIND = MPI_ADDRESS_KIND) LB, EXTENT
MPI_TYPE_GET_TRUE_EXTENT(DATATYPE, TRUE_LB, TRUE_EXTENT, IERROR) INTEGER DATATYPE, IERROR
INTEGER(KIND = MPI_ADDRESS_KIND) TRUE_LB, TRUE_EXTENT
MPI_TYPE_INDEXED(COUNT, ARRAY_OF_BLOCKLENGTHS, ARRAY_OF_DISPLACEMENTS, OLDTYPE, NEWTYPE, IERROR)
INTEGER COUNT, ARRAY_OF_BLOCKLENGTHS(*), ARRAY_OF_DISPLACEMENTS(*), OLDTYPE, NEWTYPE, IERROR
MPI_TYPE_SIZE(DATATYPE, SIZE, IERROR)
INTEGER DATATYPE, SIZE, IERROR
MPI_TYPE_VECTOR(COUNT, BLOCKLENGTH, STRIDE, OLDTYPE, NEWTYPE, IERROR) INTEGER COUNT, BLOCKLENGTH, STRIDE, OLDTYPE, NEWTYPE, IERROR
MPI_UNPACK(INBUF, INSIZE, POSITION, OUTBUF, OUTCOUNT, DATATYPE, COMM, IERROR)
<type> INBUF(*), OUTBUF(*)
INTEGER INSIZE, POSITION, OUTCOUNT, DATATYPE, COMM, IERROR
MPI_UNPACK_EXTERNAL(DATAREP, INBUF, INSIZE, POSITION, OUTBUF, OUTCOUNT, DATATYPE, IERROR)
INTEGER OUTCOUNT, DATATYPE, IERROR
INTEGER(KIND=MPI_ADDRESS_KIND) INSIZE, POSITION
1
2
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
1
2
3
4
5
6
7
8
9
10
552 |
ANNEX A. LANGUAGE BINDINGS SUMMARY |
CHARACTER*(*) DATAREP
<type> INBUF(*), OUTBUF(*)
A.3.3 Collective Communication Fortran Bindings
MPI_ALLGATHER(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER SENDCOUNT, SENDTYPE, RECVCOUNT, RECVTYPE, COMM, IERROR
11 |
MPI_ALLGATHERV(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNTS, DISPLS, |
12 |
RECVTYPE, COMM, IERROR) |
13<type> SENDBUF(*), RECVBUF(*)
14INTEGER SENDCOUNT, SENDTYPE, RECVCOUNTS(*), DISPLS(*), RECVTYPE, COMM,
15IERROR
16
MPI_ALLREDUCE(SENDBUF, RECVBUF, COUNT, DATATYPE, OP, COMM, IERROR)
17
18 |
<type> SENDBUF(*), RECVBUF(*) |
|
INTEGER COUNT, DATATYPE, OP, COMM, IERROR |
||
19 |
||
|
||
20 |
MPI_ALLTOALL(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, |
|
21 |
COMM, IERROR) |
22<type> SENDBUF(*), RECVBUF(*)
23INTEGER SENDCOUNT, SENDTYPE, RECVCOUNT, RECVTYPE, COMM, IERROR
24
MPI_ALLTOALLV(SENDBUF, SENDCOUNTS, SDISPLS, SENDTYPE, RECVBUF, RECVCOUNTS,
25
RDISPLS, RECVTYPE, COMM, IERROR)
26
<type> SENDBUF(*), RECVBUF(*)
27
28 |
INTEGER SENDCOUNTS(*), SDISPLS(*), SENDTYPE, RECVCOUNTS(*), RDISPLS(*), |
|
RECVTYPE, COMM, IERROR |
||
29 |
||
|
||
30 |
MPI_ALLTOALLW(SENDBUF, SENDCOUNTS, SDISPLS, SENDTYPES, RECVBUF, RECVCOUNTS, |
|
31 |
RDISPLS, RECVTYPES, COMM, IERROR) |
32<type> SENDBUF(*), RECVBUF(*)
33INTEGER SENDCOUNTS(*), SDISPLS(*), SENDTYPES(*), RECVCOUNTS(*),
34RDISPLS(*), RECVTYPES(*), COMM, IERROR
35
MPI_BARRIER(COMM, IERROR)
36
INTEGER COMM, IERROR
37
38MPI_BCAST(BUFFER, COUNT, DATATYPE, ROOT, COMM, IERROR)
39<type> BUFFER(*)
40INTEGER COUNT, DATATYPE, ROOT, COMM, IERROR
41
42 |
MPI_EXSCAN(SENDBUF, RECVBUF, COUNT, DATATYPE, OP, COMM, IERROR) |
|
<type> SENDBUF(*), RECVBUF(*) |
||
43 |
||
INTEGER COUNT, DATATYPE, OP, COMM, IERROR |
||
44 |
||
|
||
45 |
MPI_GATHER(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, |
|
|
||
46 |
ROOT, COMM, IERROR) |
|
|
47<type> SENDBUF(*), RECVBUF(*)
48INTEGER SENDCOUNT, SENDTYPE, RECVCOUNT, RECVTYPE, ROOT, COMM, IERROR
A.3. FORTRAN BINDINGS |
553 |
MPI_GATHERV(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNTS, DISPLS, RECVTYPE, ROOT, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER SENDCOUNT, SENDTYPE, RECVCOUNTS(*), DISPLS(*), RECVTYPE, ROOT, COMM, IERROR
MPI_OP_COMMUTATIVE(OP, COMMUTE, IERROR)
LOGICAL COMMUTE
INTEGER OP, IERROR
MPI_OP_CREATE( FUNCTION, COMMUTE, OP, IERROR)
EXTERNAL FUNCTION
LOGICAL COMMUTE
INTEGER OP, IERROR
MPI_OP_FREE( OP, IERROR)
INTEGER OP, IERROR
MPI_REDUCE(SENDBUF, RECVBUF, COUNT, DATATYPE, OP, ROOT, COMM, IERROR) <type> SENDBUF(*), RECVBUF(*)
INTEGER COUNT, DATATYPE, OP, ROOT, COMM, IERROR
MPI_REDUCE_LOCAL(INBUF, INOUBUF, COUNT, DATATYPE, OP, IERROR) <type> INBUF(*), INOUTBUF(*)
INTEGER COUNT, DATATYPE, OP, IERROR
MPI_REDUCE_SCATTER(SENDBUF, RECVBUF, RECVCOUNTS, DATATYPE, OP, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER RECVCOUNTS(*), DATATYPE, OP, COMM, IERROR
MPI_REDUCE_SCATTER_BLOCK(SENDBUF, RECVBUF, RECVCOUNT, DATATYPE, OP, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER RECVCOUNT, DATATYPE, OP, COMM, IERROR
MPI_SCAN(SENDBUF, RECVBUF, COUNT, DATATYPE, OP, COMM, IERROR) <type> SENDBUF(*), RECVBUF(*)
INTEGER COUNT, DATATYPE, OP, COMM, IERROR
MPI_SCATTER(SENDBUF, SENDCOUNT, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, ROOT, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER SENDCOUNT, SENDTYPE, RECVCOUNT, RECVTYPE, ROOT, COMM, IERROR
MPI_SCATTERV(SENDBUF, SENDCOUNTS, DISPLS, SENDTYPE, RECVBUF, RECVCOUNT, RECVTYPE, ROOT, COMM, IERROR)
<type> SENDBUF(*), RECVBUF(*)
INTEGER SENDCOUNTS(*), DISPLS(*), SENDTYPE, RECVCOUNT, RECVTYPE, ROOT, COMM, IERROR
1
2
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