Logo AND Algorithmique Numérique Distribuée

Public GIT Repository
Merge branch 'v3_11_x'
[simgrid.git] / include / smpi / mpif.h.in
1 ! -*- fortran -*-
2 ! Copyright (c) 2010, 2012-2014. The SimGrid Team.
3 ! All rights reserved.
4
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.
7
8 ! SMPI's Fortran 77 include file
9
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)
16
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_TAG_UB, MPI_TAG_LB
22       integer MPI_SOURCE, MPI_TAG, MPI_ERROR
23       integer MPI_VERSION, MPI_SUBVERSION
24       parameter(MPI_MAX_PROCESSOR_NAME=100)
25       parameter(MPI_MAX_ERROR_STRING=100)
26       parameter(MPI_MAX_DATAREP_STRIN =100)
27       parameter(MPI_MAX_INFO_KEY=100)
28       parameter(MPI_MAX_INFO_VAL=100)
29       parameter(MPI_MAX_OBJECT_NAME=100)
30       parameter(MPI_MAX_PORT_NAME=100)
31       parameter(MPI_ANY_SOURCE=-555)
32       parameter(MPI_PROC_NULL=-666)
33       parameter(MPI_ANY_TAG=-444)
34       parameter(MPI_UNDEFINED=-333)
35       parameter(MPI_SOURCE=1)
36       parameter(MPI_TAG=2)
37       parameter(MPI_ERROR=3)
38       parameter(MPI_TAG_UB=0)
39       parameter(MPI_TAG_LB=0)
40       parameter(MPI_VERSION=1)
41       parameter(MPI_SUBVERSION=1)
42
43       integer MPI_SUCCESS, MPI_ERR_COMM, MPI_ERR_ARG, MPI_ERR_TYPE
44       integer MPI_ERR_REQUEST, MPI_ERR_INTERN, MPI_ERR_COUNT
45       integer MPI_ERR_RANK, MPI_ERR_OTHER, MPI_ERR_UNKNOWN
46       integer MPI_ERR_TAG, MPI_ERR_TRUNCATE, MPI_ERR_GROUP, MPI_ERR_OP
47       integer MPI_LASTUSEDCODE, MPI_ERR_LASTCODE
48       integer MPI_IDENT, MPI_SIMILAR, MPI_UNEQUAL, MPI_CONGRUENT
49       integer MPI_WTIME_IS_GLOBAL
50       parameter(MPI_SUCCESS=0)
51       parameter(MPI_ERR_COMM=1)
52       parameter(MPI_ERR_ARG=2)
53       parameter(MPI_ERR_TYPE=3)
54       parameter(MPI_ERR_REQUEST=4)
55       parameter(MPI_ERR_INTERN=5)
56       parameter(MPI_ERR_COUNT=6)
57       parameter(MPI_ERR_RANK=7)
58       parameter(MPI_ERR_TAG=8)
59       parameter(MPI_ERR_TRUNCATE=9)
60       parameter(MPI_ERR_GROUP=10)
61       parameter(MPI_ERR_OP=11)
62       parameter(MPI_ERR_OTHER=12)
63       parameter(MPI_ERR_UNKNOWN=13)
64       parameter(MPI_LASTUSEDCODE=0)
65       parameter(MPI_ERR_LASTCODE=0)
66       parameter(MPI_IDENT=0)
67       parameter(MPI_SIMILAR=1)
68       parameter(MPI_UNEQUAL=2)
69       parameter(MPI_CONGRUENT=3)
70       parameter(MPI_WTIME_IS_GLOBAL=1)
71
72       integer MPI_NULL_COPY_FN, MPI_NULL_DELETE_FN
73       parameter(MPI_NULL_COPY_FN =0)
74       parameter(MPI_NULL_DELETE_FN =0)
75       integer MPI_COMM_NULL_COPY_FN, MPI_COMM_NULL_DELETE_FN
76       parameter(MPI_COMM_NULL_COPY_FN =0)
77       parameter(MPI_COMM_NULL_DELETE_FN =0)
78       integer MPI_COMM_NULL_DUP_FN, MPI_COMM_DUP_FN
79       parameter(MPI_COMM_NULL_DUP_FN =0)
80       parameter(MPI_COMM_DUP_FN =0)
81       integer MPI_APPNUM, MPI_HOST, MPI_IO
82       parameter(MPI_APPNUM=0)
83       parameter(MPI_HOST=0)
84       parameter(MPI_IO=0)
85       integer MPI_ROOT, MPI_INFO_NULL,MPI_COMM_TYPE_SHARED
86       parameter(MPI_ROOT=0)
87       parameter(MPI_INFO_NULL=-1)
88       parameter(MPI_COMM_TYPE_SHARED=1)
89
90 ! These should be ordered as in smpi_f77.c
91       integer MPI_COMM_NULL, MPI_COMM_WORLD, MPI_COMM_SELF
92       integer MPI_UNIVERSE_SIZE
93       parameter(MPI_COMM_NULL=-1)
94       parameter(MPI_COMM_SELF=-2)
95       parameter(MPI_COMM_WORLD=0)
96       parameter(MPI_UNIVERSE_SIZE=0)
97
98
99       integer MPI_GROUP_NULL, MPI_GROUP_EMPTY
100       parameter(MPI_GROUP_NULL=-1)
101       parameter(MPI_GROUP_EMPTY=-2)
102
103       integer MPI_ERRORS_RETURN, MPI_ERRORS_ARE_FATAL
104       integer MPI_ERRHANDLER_NULL
105       parameter(MPI_ERRORS_RETURN=0)
106       parameter(MPI_ERRORS_ARE_FATAL=1)
107       parameter(MPI_ERRHANDLER_NULL=2)
108
109 ! This should be equal to the number of int fields in MPI_Status
110       integer MPI_STATUS_SIZE
111       parameter(MPI_STATUS_SIZE=4)
112
113 ! These should be ordered as in smpi_f77.c
114       integer MPI_IN_PLACE, MPI_BOTTOM
115       integer MPI_STATUS_IGNORE, MPI_STATUSES_IGNORE
116       common /smpi/ MPI_IN_PLACE, MPI_BOTTOM
117       common /smpi/ MPI_STATUS_IGNORE, MPI_STATUSES_IGNORE
118
119       integer MPI_REQUEST_NULL
120       parameter(MPI_REQUEST_NULL=-1)
121
122       integer MPI_INTEGER_KIND
123       parameter(MPI_INTEGER_KIND=4)
124
125       integer MPI_DATATYPE_NULL, MPI_BYTE, MPI_CHARACTER, MPI_LOGICAL
126       integer MPI_INTEGER, MPI_INTEGER1, MPI_INTEGER2, MPI_INTEGER4
127       integer MPI_INTEGER8, MPI_REAL, MPI_REAL4, MPI_REAL8
128       integer MPI_DOUBLE_PRECISION, MPI_COMPLEX, MPI_DOUBLE_COMPLEX
129       integer MPI_2INTEGER, MPI_LOGICAL1, MPI_LOGICAL2, MPI_LOGICAL4
130       integer MPI_LOGICAL8, MPI_2REAL, MPI_2DOUBLE_PRECISION
131       integer MPI_AINT, MPI_OFFSET, MPI_COUNT
132       integer MPI_REAL16, MPI_COMPLEX8,MPI_COMPLEX16,MPI_COMPLEX32
133       parameter(MPI_DATATYPE_NULL=-1)
134       parameter(MPI_BYTE=0)
135       parameter(MPI_CHARACTER=1)
136       parameter(MPI_LOGICAL=2)
137       parameter(MPI_INTEGER=3)
138       parameter(MPI_INTEGER1=4)
139       parameter(MPI_INTEGER2=5)
140       parameter(MPI_INTEGER4=6)
141       parameter(MPI_INTEGER8=7)
142       parameter(MPI_REAL=8)
143       parameter(MPI_REAL4=9)
144       parameter(MPI_REAL8=10)
145       parameter(MPI_DOUBLE_PRECISION=11)
146       parameter(MPI_COMPLEX=12)
147       parameter(MPI_DOUBLE_COMPLEX=13)
148       parameter(MPI_2INTEGER=14)
149       parameter(MPI_LOGICAL1=15)
150       parameter(MPI_LOGICAL2=16)
151       parameter(MPI_LOGICAL4=17)
152       parameter(MPI_LOGICAL8=18)
153       parameter(MPI_2REAL=19)
154       parameter(MPI_2DOUBLE_PRECISION=19)
155       parameter(MPI_AINT=20)
156       parameter(MPI_OFFSET=21)
157       parameter(MPI_COUNT=22)
158       parameter(MPI_REAL16=23)
159       parameter(MPI_COMPLEX8=24)
160       parameter(MPI_COMPLEX16=25)
161       parameter(MPI_COMPLEX32=26)
162
163
164
165 ! These should be ordered as in smpi_f77.c
166       integer MPI_OP_NULL,MPI_MAX, MPI_MIN, MPI_MAXLOC, MPI_MINLOC
167       integer MPI_SUM, MPI_PROD, MPI_LAND, MPI_LOR, MPI_LXOR, MPI_BAND
168       integer MPI_BOR, MPI_BXOR
169       parameter(MPI_OP_NULL=-1)
170       parameter(MPI_MAX=0)
171       parameter(MPI_MIN=1)
172       parameter(MPI_MAXLOC=2)
173       parameter(MPI_MINLOC=3)
174       parameter(MPI_SUM=4)
175       parameter(MPI_PROD=5)
176       parameter(MPI_LAND=6)
177       parameter(MPI_LOR=7)
178       parameter(MPI_LXOR=8)
179       parameter(MPI_BAND=9)
180       parameter(MPI_BOR=10)
181       parameter(MPI_BXOR=11)
182       
183       INTEGER MPI_ADDRESS_KIND, MPI_OFFSET_KIND
184       PARAMETER (MPI_ADDRESS_KIND=@MPI_ADDRESS_SIZE@)
185       PARAMETER (MPI_OFFSET_KIND=@MPI_ADDRESS_SIZE@)
186       
187       INTEGER MPI_MODE_NOPRECEDE
188       PARAMETER (MPI_MODE_NOPRECEDE=8192)
189
190       integer MPI_COMBINER_NAMED, MPI_COMBINER_DUP
191       integer MPI_COMBINER_CONTIGUOUS, MPI_COMBINER_VECTOR
192       integer MPI_COMBINER_HVECTOR_INTEGER, MPI_COMBINER_HVECTOR
193       integer MPI_COMBINER_INDEXED, MPI_COMBINER_HINDEXED_INTEGER
194       integer MPI_COMBINER_HINDEXED, MPI_COMBINER_INDEXED_BLOCK
195       integer MPI_COMBINER_STRUCT_INTEGER, MPI_COMBINER_STRUCT
196       integer MPI_COMBINER_SUBARRAY, MPI_COMBINER_DARRAY
197       integer MPI_COMBINER_F90_REAL, MPI_COMBINER_F90_COMPLEX
198       integer MPI_COMBINER_F90_INTEGER, MPI_COMBINER_RESIZED
199       integer MPI_COMBINER_HINDEXED_BLOCK
200
201       parameter( MPI_COMBINER_NAMED=0)
202       parameter( MPI_COMBINER_DUP=1)
203       parameter( MPI_COMBINER_CONTIGUOUS=2)
204       parameter( MPI_COMBINER_VECTOR=3)
205       parameter( MPI_COMBINER_HVECTOR_INTEGER=4)
206       parameter( MPI_COMBINER_HVECTOR=5)
207       parameter( MPI_COMBINER_INDEXED=6)
208       parameter( MPI_COMBINER_HINDEXED_INTEGER=7)
209       parameter( MPI_COMBINER_HINDEXED=8)
210       parameter( MPI_COMBINER_INDEXED_BLOCK=9)
211       parameter( MPI_COMBINER_STRUCT_INTEGER=10)
212       parameter( MPI_COMBINER_STRUCT=11)
213       parameter( MPI_COMBINER_SUBARRAY=12)
214       parameter( MPI_COMBINER_DARRAY=13)
215       parameter( MPI_COMBINER_F90_REAL=14)
216       parameter( MPI_COMBINER_F90_COMPLEX=15)
217       parameter( MPI_COMBINER_F90_INTEGER=16)
218       parameter( MPI_COMBINER_RESIZED=17)
219       parameter( MPI_COMBINER_HINDEXED_BLOCK=18)
220
221       integer MPI_ORDER_C, MPI_ORDER_FORTRAN
222       parameter(MPI_ORDER_C=1)
223       parameter(MPI_ORDER_FORTRAN=0)
224
225       external MPI_INIT, MPI_FINALIZE, MPI_ABORT
226       external MPI_COMM_RANK, MPI_COMM_SIZE, MPI_COMM_DUP
227       external MPI_SEND_INIT, MPI_ISEND, MPI_SEND, MPI_COMM_SPLIT
228       external MPI_RECV_INIT, MPI_IRECV, MPI_RECV
229       external MPI_START, MPI_STARTALL
230       external MPI_WAIT, MPI_WAITANY, MPI_WAITALL
231       external MPI_BCAST, MPI_BARRIER, MPI_REDUCE, MPI_ALLREDUCE
232       external MPI_SCATTER, MPI_GATHER, MPI_ALLGATHER, MPI_SCAN
233       external MPI_ALLTOALL, MPI_GATHERV, MPI_SENDRECV
234
235       external MPI_WTIME
236       external MPI_WTICK
237
238       double precision MPI_WTIME
239       double precision MPI_WTICK
240
241       external smpi_execute_flops
242       external smpi_execute
243       external smpi_get_host_power_peak_at
244       external smpi_get_host_current_power_peak
245       external smpi_get_host_nb_pstates
246       external smpi_set_host_power_peak_at
247       external smpi_get_host_consumed_energy
248
249       double precision smpi_get_host_power_peak_at
250       double precision smpi_get_host_current_power_peak
251       integer smpi_get_host_nb_pstates
252       double precision smpi_get_host_consumed_energy