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

Last change on this file since 26744 was 26744, checked in by Mathieu Morlighem, 3 years ago

merged trunk-jpl and trunk for revision 26742

File size: 6.8 KB
RevLine 
[22681]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=== IO related options ===
66C-- Flag used to indicate whether Fortran formatted write
67C and read are threadsafe. On SGI the routines can be thread
68C safe, on Sun it is not possible - if you are unsure then
69C undef this option.
70#undef FMTFTN_IO_THREAD_SAFE
71
72C-- Flag used to indicate whether Binary write to Local file (i.e.,
73C a different file for each tile) and read are thread-safe.
74#undef LOCBIN_IO_THREAD_SAFE
75
76C-- Flag to turn off the writing of error message to ioUnit zero
77#undef DISABLE_WRITE_TO_UNIT_ZERO
78
79C-- Alternative formulation of BYTESWAP, faster than
80C compiler flag -byteswapio on the Altix.
81#undef FAST_BYTESWAP
82
83C-- Flag to turn on old default of opening scratch files with the
84C STATUS='SCRATCH' option. This method, while perfectly FORTRAN-standard,
85C caused filename conflicts on some multi-node/multi-processor platforms
86C in the past and has been replace by something (hopefully) more robust.
87#undef USE_FORTRAN_SCRATCH_FILES
88
89C-- Flag defined for eeboot_minimal.F, eeset_parms.F and open_copy_data_file.F
90C to write STDOUT, STDERR and scratch files from process 0 only.
91C WARNING: to use only when absolutely confident that the setup is working
92C since any message (error/warning/print) from any proc <> 0 will be lost.
93#undef SINGLE_DISK_IO
94
95C=== MPI, EXCH and GLOBAL_SUM related options ===
96C-- Flag turns off MPI_SEND ready_to_receive polling in the
97C gather_* subroutines to speed up integrations.
98#undef DISABLE_MPI_READY_TO_RECEIVE
99
100C-- Control MPI based parallel processing
101CXXX We no longer select the use of MPI via this file (CPP_EEOPTIONS.h)
102CXXX To use MPI, use an appropriate genmake2 options file or use
103CXXX genmake2 -mpi .
104CXXX #undef ALLOW_USE_MPI
105
106C-- Control use of communication that might overlap computation.
107C Under MPI selects/deselects "non-blocking" sends and receives.
108#define ALLOW_ASYNC_COMMUNICATION
109#undef ALLOW_ASYNC_COMMUNICATION
110#undef ALWAYS_USE_ASYNC_COMMUNICATION
111C-- Control use of communication that is atomic to computation.
112C Under MPI selects/deselects "blocking" sends and receives.
113#define ALLOW_SYNC_COMMUNICATION
114#undef ALWAYS_USE_SYNC_COMMUNICATION
115
116C-- Control XY periodicity in processor to grid mappings
117C Note: Model code does not need to know whether a domain is
118C periodic because it has overlap regions for every box.
119C Model assume that these values have been
120C filled in some way.
121#undef ALWAYS_PREVENT_X_PERIODICITY
122#undef ALWAYS_PREVENT_Y_PERIODICITY
123#define CAN_PREVENT_X_PERIODICITY
124#define CAN_PREVENT_Y_PERIODICITY
125
126C-- disconnect tiles (no exchange between tiles, just fill-in edges
127C assuming locally periodic subdomain)
128#undef DISCONNECTED_TILES
129
130C-- Always cumulate tile local-sum in the same order by applying MPI allreduce
131C to array of tiles ; can get slower with large number of tiles (big set-up)
132#define GLOBAL_SUM_ORDER_TILES
133
134C-- Alternative way of doing global sum without MPI allreduce call
135C but instead, explicit MPI send & recv calls. Expected to be slower.
136#undef GLOBAL_SUM_SEND_RECV
137
138C-- Alternative way of doing global sum on a single CPU
139C to eliminate tiling-dependent roundoff errors. Note: This is slow.
140#undef CG2D_SINGLECPU_SUM
141
142C=== Other options (to add/remove pieces of code) ===
143C-- Flag to turn on checking for errors from all threads and procs
144C (calling S/R STOP_IF_ERROR) before stopping.
145#define USE_ERROR_STOP
146
147C-- Control use of communication with other component:
148C allow to import and export from/to Coupler interface.
149#undef COMPONENT_MODULE
150
151C-- Options used to couple MITgcm and ISSM
152C Eventually this option can probably be merged with COMPONENT_MODULE
153#define ALLOW_CPL_ISSM
154
155C-- Activate some pieces of code for coupling to GEOS AGCM
156#undef HACK_FOR_GMAO_CPL
157
158#endif /* _CPP_EEOPTIONS_H_ */
159
160#include "CPP_EEMACROS.h"
161
Note: See TracBrowser for help on using the repository browser.