source: issm/trunk/test/MITgcm/code/CPP_EEOPTIONS.h@ 23189

Last change on this file since 23189 was 23189, checked in by Mathieu Morlighem, 7 years ago

merged trunk-jpl and trunk for revision 23187

File size: 6.9 KB
Line 
1CBOP
2C !ROUTINE: CPP_EEOPTIONS.h
3C !INTERFACE:
4C include "CPP_EEOPTIONS.h"
5C
6C !DESCRIPTION:
7C *==========================================================*
8C | CPP\_EEOPTIONS.h |
9C *==========================================================*
10C | C preprocessor "execution environment" supporting |
11C | flags. Use this file to set flags controlling the |
12C | execution environment in which a model runs - as opposed |
13C | to the dynamical problem the model solves. |
14C | Note: Many options are implemented with both compile time|
15C | and run-time switches. This allows options to be |
16C | removed altogether, made optional at run-time or |
17C | to be permanently enabled. This convention helps |
18C | with the data-dependence analysis performed by the |
19C | adjoint model compiler. This data dependency |
20C | analysis can be upset by runtime switches that it |
21C | is unable to recoginise as being fixed for the |
22C | duration of an integration. |
23C | A reasonable way to use these flags is to |
24C | set all options as selectable at runtime but then |
25C | once an experimental configuration has been |
26C | identified, rebuild the code with the appropriate |
27C | options set at compile time. |
28C *==========================================================*
29CEOP
30
31#ifndef _CPP_EEOPTIONS_H_
32#define _CPP_EEOPTIONS_H_
33
34C In general the following convention applies:
35C ALLOW - indicates an feature will be included but it may
36C CAN have a run-time flag to allow it to be switched
37C on and off.
38C If ALLOW or CAN directives are "undef'd" this generally
39C means that the feature will not be available i.e. it
40C will not be included in the compiled code and so no
41C run-time option to use the feature will be available.
42C
43C ALWAYS - indicates the choice will be fixed at compile time
44C so no run-time option will be present
45
46C=== Macro related options ===
47C-- Control storage of floating point operands
48C On many systems it improves performance only to use
49C 8-byte precision for time stepped variables.
50C Constant in time terms ( geometric factors etc.. )
51C can use 4-byte precision, reducing memory utilisation and
52C boosting performance because of a smaller working set size.
53C However, on vector CRAY systems this degrades performance.
54C Enable to switch REAL4_IS_SLOW from genmake2 (with LET_RS_BE_REAL4):
55#ifdef LET_RS_BE_REAL4
56#undef REAL4_IS_SLOW
57#else /* LET_RS_BE_REAL4 */
58#define REAL4_IS_SLOW
59#endif /* LET_RS_BE_REAL4 */
60
61C-- Control use of "double" precision constants.
62C Use D0 where it means REAL*8 but not where it means REAL*16
63#define D0 d0
64
65C-- Enable some old macro conventions for backward compatibility
66#undef USE_OLD_MACROS_R4R8toRSRL
67
68C=== IO related options ===
69C-- Flag used to indicate whether Fortran formatted write
70C and read are threadsafe. On SGI the routines can be thread
71C safe, on Sun it is not possible - if you are unsure then
72C undef this option.
73#undef FMTFTN_IO_THREAD_SAFE
74
75C-- Flag used to indicate whether Binary write to Local file (i.e.,
76C a different file for each tile) and read are thread-safe.
77#undef LOCBIN_IO_THREAD_SAFE
78
79C-- Flag to turn off the writing of error message to ioUnit zero
80#undef DISABLE_WRITE_TO_UNIT_ZERO
81
82C-- Alternative formulation of BYTESWAP, faster than
83C compiler flag -byteswapio on the Altix.
84#undef FAST_BYTESWAP
85
86C-- Flag to turn on old default of opening scratch files with the
87C STATUS='SCRATCH' option. This method, while perfectly FORTRAN-standard,
88C caused filename conflicts on some multi-node/multi-processor platforms
89C in the past and has been replace by something (hopefully) more robust.
90#undef USE_FORTRAN_SCRATCH_FILES
91
92C-- Flag defined for eeboot_minimal.F, eeset_parms.F and open_copy_data_file.F
93C to write STDOUT, STDERR and scratch files from process 0 only.
94C WARNING: to use only when absolutely confident that the setup is working
95C since any message (error/warning/print) from any proc <> 0 will be lost.
96#undef SINGLE_DISK_IO
97
98C=== MPI, EXCH and GLOBAL_SUM related options ===
99C-- Flag turns off MPI_SEND ready_to_receive polling in the
100C gather_* subroutines to speed up integrations.
101#undef DISABLE_MPI_READY_TO_RECEIVE
102
103C-- Control MPI based parallel processing
104CXXX We no longer select the use of MPI via this file (CPP_EEOPTIONS.h)
105CXXX To use MPI, use an appropriate genmake2 options file or use
106CXXX genmake2 -mpi .
107CXXX #undef ALLOW_USE_MPI
108
109C-- Control use of communication that might overlap computation.
110C Under MPI selects/deselects "non-blocking" sends and receives.
111#define ALLOW_ASYNC_COMMUNICATION
112#undef ALLOW_ASYNC_COMMUNICATION
113#undef ALWAYS_USE_ASYNC_COMMUNICATION
114C-- Control use of communication that is atomic to computation.
115C Under MPI selects/deselects "blocking" sends and receives.
116#define ALLOW_SYNC_COMMUNICATION
117#undef ALWAYS_USE_SYNC_COMMUNICATION
118
119C-- Control XY periodicity in processor to grid mappings
120C Note: Model code does not need to know whether a domain is
121C periodic because it has overlap regions for every box.
122C Model assume that these values have been
123C filled in some way.
124#undef ALWAYS_PREVENT_X_PERIODICITY
125#undef ALWAYS_PREVENT_Y_PERIODICITY
126#define CAN_PREVENT_X_PERIODICITY
127#define CAN_PREVENT_Y_PERIODICITY
128
129C-- disconnect tiles (no exchange between tiles, just fill-in edges
130C assuming locally periodic subdomain)
131#undef DISCONNECTED_TILES
132
133C-- Always cumulate tile local-sum in the same order by applying MPI allreduce
134C to array of tiles ; can get slower with large number of tiles (big set-up)
135#define GLOBAL_SUM_ORDER_TILES
136
137C-- Alternative way of doing global sum without MPI allreduce call
138C but instead, explicit MPI send & recv calls. Expected to be slower.
139#undef GLOBAL_SUM_SEND_RECV
140
141C-- Alternative way of doing global sum on a single CPU
142C to eliminate tiling-dependent roundoff errors. Note: This is slow.
143#undef CG2D_SINGLECPU_SUM
144
145C=== Other options (to add/remove pieces of code) ===
146C-- Flag to turn on checking for errors from all threads and procs
147C (calling S/R STOP_IF_ERROR) before stopping.
148#define USE_ERROR_STOP
149
150C-- Control use of communication with other component:
151C allow to import and export from/to Coupler interface.
152#undef COMPONENT_MODULE
153
154C-- Options used to couple MITgcm and ISSM
155C Eventually this option can probably be merged with COMPONENT_MODULE
156#define ALLOW_CPL_ISSM
157
158C-- Activate some pieces of code for coupling to GEOS AGCM
159#undef HACK_FOR_GMAO_CPL
160
161#endif /* _CPP_EEOPTIONS_H_ */
162
163#include "CPP_EEMACROS.h"
164
Note: See TracBrowser for help on using the repository browser.