2 ! Copyright (c) 2010. The SimGrid Team.
5 ! This program is free software; you can redistribute it and/or modify it
6 ! under the terms of the license (GNU LGPL) which comes with this package.
8 ! SMPI's Fortran 77 include file
10 integer MPI_THREAD_SINGLE, MPI_THREAD_FUNNELED
11 integer MPI_THREAD_SERIALIZED, MPI_THREAD_MULTIPLE
12 parameter(MPI_THREAD_SINGLE=0)
13 parameter(MPI_THREAD_FUNNELED=1)
14 parameter(MPI_THREAD_SERIALIZED=2)
15 parameter(MPI_THREAD_MULTIPLE=3)
17 integer MPI_MAX_PROCESSOR_NAME, MPI_MAX_ERROR_STRING
18 integer MPI_MAX_DATAREP_STRIN, MPI_MAX_INFO_KEY
19 integer MPI_MAX_INFO_VAL, MPI_MAX_OBJECT_NAME, MPI_MAX_PORT_NAME
20 integer MPI_ANY_SOURCE, MPI_PROC_NULL, MPI_ANY_TAG, MPI_UNDEFINED
21 integer MPI_IN_PLACE, MPI_TAG_UB, MPI_TAG_LB
22 parameter(MPI_MAX_PROCESSOR_NAME=100)
23 parameter(MPI_MAX_ERROR_STRING=100)
24 parameter(MPI_MAX_DATAREP_STRIN =100)
25 parameter(MPI_MAX_INFO_KEY=100)
26 parameter(MPI_MAX_INFO_VAL=100)
27 parameter(MPI_MAX_OBJECT_NAME=100)
28 parameter(MPI_MAX_PORT_NAME=100)
29 parameter(MPI_ANY_SOURCE=-555)
30 parameter(MPI_PROC_NULL=-666)
31 parameter(MPI_ANY_TAG=-444)
32 parameter(MPI_UNDEFINED=-333)
33 parameter(MPI_IN_PLACE=-222)
34 parameter(MPI_TAG_UB=0)
35 parameter(MPI_TAG_LB=0)
37 integer MPI_SUCCESS, MPI_ERR_COMM, MPI_ERR_ARG, MPI_ERR_TYPE
38 integer MPI_ERR_REQUEST, MPI_ERR_INTERN, MPI_ERR_COUNT
39 integer MPI_ERR_RANK, MPI_ERR_OTHER, MPI_ERR_UNKNOWN
40 integer MPI_ERR_TAG, MPI_ERR_TRUNCATE, MPI_ERR_GROUP, MPI_ERR_OP
41 integer MPI_IDENT, MPI_SIMILAR, MPI_UNEQUAL, MPI_CONGRUENT
42 integer MPI_WTIME_IS_GLOBAL
43 parameter(MPI_SUCCESS=0)
44 parameter(MPI_ERR_COMM=1)
45 parameter(MPI_ERR_ARG=2)
46 parameter(MPI_ERR_TYPE=3)
47 parameter(MPI_ERR_REQUEST=4)
48 parameter(MPI_ERR_INTERN=5)
49 parameter(MPI_ERR_COUNT=6)
50 parameter(MPI_ERR_RANK=7)
51 parameter(MPI_ERR_TAG=8)
52 parameter(MPI_ERR_TRUNCATE=9)
53 parameter(MPI_ERR_GROUP=10)
54 parameter(MPI_ERR_OP=11)
55 parameter(MPI_ERR_OTHER=12)
56 parameter(MPI_ERR_UNKNOWN=13)
57 parameter(MPI_IDENT=0)
58 parameter(MPI_SIMILAR=1)
59 parameter(MPI_UNEQUAL=2)
60 parameter(MPI_CONGRUENT=3)
61 parameter(MPI_WTIME_IS_GLOBAL=1)
63 ! These should be ordered as in smpi_f77.c
64 integer MPI_COMM_NULL, MPI_COMM_WORLD, MPI_COMM_SELF
65 parameter(MPI_COMM_NULL=-1)
66 parameter(MPI_COMM_SELF=-2)
67 parameter(MPI_COMM_WORLD=0)
69 integer MPI_GROUP_NULL, MPI_GROUP_EMPTY
70 parameter(MPI_GROUP_NULL=-1)
71 parameter(MPI_GROUP_EMPTY=-2)
73 ! This should be equal to the number of int fields in MPI_Status
74 integer MPI_STATUS_SIZE, MPI_STATUSES_IGNORE
75 parameter(MPI_STATUS_SIZE=4)
76 parameter(MPI_STATUSES_IGNORE=0)
78 integer MPI_STATUS_IGNORE(MPI_STATUS_SIZE)
79 common/smpi/ MPI_STATUS_IGNORE
81 integer MPI_REQUEST_NULL
82 parameter(MPI_REQUEST_NULL=-1)
84 ! These should be ordered as in smpi_f77.c
85 integer MPI_DATATYPE_NULL, MPI_BYTE, MPI_CHARACTER, MPI_LOGICAL
86 integer MPI_INTEGER, MPI_INTEGER1, MPI_INTEGER2, MPI_INTEGER4
87 integer MPI_INTEGER8, MPI_REAL, MPI_REAL4, MPI_REAL8
88 integer MPI_DOUBLE_PRECISION, MPI_COMPLEX, MPI_DOUBLE_COMPLEX
89 integer MPI_2INTEGER, MPI_LOGICAL1, MPI_LOGICAL2, MPI_LOGICAL4
90 integer MPI_LOGICAL8, MPI_2REAL, MPI_2DOUBLE_PRECISION
91 parameter(MPI_DATATYPE_NULL=-1)
93 parameter(MPI_CHARACTER=1)
94 parameter(MPI_LOGICAL=2)
95 parameter(MPI_INTEGER=3)
96 parameter(MPI_INTEGER1=4)
97 parameter(MPI_INTEGER2=5)
98 parameter(MPI_INTEGER4=6)
99 parameter(MPI_INTEGER8=7)
100 parameter(MPI_REAL=8)
101 parameter(MPI_REAL4=9)
102 parameter(MPI_REAL8=10)
103 parameter(MPI_DOUBLE_PRECISION=11)
104 parameter(MPI_COMPLEX=12)
105 parameter(MPI_DOUBLE_COMPLEX=13)
106 parameter(MPI_2INTEGER=14)
107 parameter(MPI_LOGICAL1=15)
108 parameter(MPI_LOGICAL2=16)
109 parameter(MPI_LOGICAL4=17)
110 parameter(MPI_LOGICAL8=18)
111 parameter(MPI_2REAL=19)
112 parameter(MPI_2DOUBLE_PRECISION=19)
114 ! These should be ordered as in smpi_f77.c
115 integer MPI_OP_NULL,MPI_MAX, MPI_MIN, MPI_MAXLOC, MPI_MINLOC
116 integer MPI_SUM, MPI_PROD, MPI_LAND, MPI_LOR, MPI_LXOR, MPI_BAND
117 integer MPI_BOR, MPI_BXOR
118 parameter(MPI_OP_NULL=-1)
121 parameter(MPI_MAXLOC=2)
122 parameter(MPI_MINLOC=3)
124 parameter(MPI_PROD=5)
125 parameter(MPI_LAND=6)
127 parameter(MPI_LXOR=8)
128 parameter(MPI_BAND=9)
129 parameter(MPI_BOR=10)
130 parameter(MPI_BXOR=11)
132 INTEGER MPI_ADDRESS_KIND, MPI_OFFSET_KIND
133 PARAMETER (MPI_ADDRESS_KIND=8)
134 PARAMETER (MPI_OFFSET_KIND=8)
136 INTEGER MPI_MODE_NOPRECEDE
137 PARAMETER (MPI_MODE_NOPRECEDE=8192)
139 external MPI_INIT, MPI_FINALIZE, MPI_ABORT
140 external MPI_COMM_RANK, MPI_COMM_SIZE, MPI_COMM_DUP, MPI_COMM_SPLIT
141 external MPI_SEND_INIT, MPI_ISEND, MPI_SEND
142 external MPI_RECV_INIT, MPI_IRECV, MPI_RECV
143 external MPI_START, MPI_STARTALL
144 external MPI_WAIT, MPI_WAITANY, MPI_WAITALL
145 external MPI_BCAST, MPI_BARRIER, MPI_REDUCE, MPI_ALLREDUCE
146 external MPI_SCATTER, MPI_GATHER, MPI_ALLGATHER, MPI_SCAN
147 external MPI_ALLTOALL, MPI_GATHERV, MPI_SENDRECV
152 double precision MPI_WTIME
153 double precision MPI_WTICK