FMS
2024.03
Flexible Modeling System
|
The following external libraries are required when building libFMS
We strive to have libFMS built with as many C and Fortran compilers on as many Unix/Linux type systems as possible. However, internally, we only use libFMS compiled with the Intel compilers. Some groups have had success using libFMS when compiled with the GNU C and Fortran compilers.
The default way to build libFMS is with MPI support. We have found that using the MPI aware compiler, or the MPI compiler wrappers (mpif90, mpicc, etc.), in general, offer the best results when building with MPI support. If you decide to not use an MPI aware compiler, you should pass the include and library locations to the build system.
libFMS can be built without MPI support (sometimes called "no-comm mode"). To build libFMS without MPI support, pass to configure
the --with-mpi=no
flag.
The FMS repository has two build systems in place, GNU autotools and CMake. It is also compiled with the GFDL's internally-developed build tool, mkmf
CMake and Autotools have some variation in options and the resulting build targets.
Autotools will build with 64 bit real defaults unless configured with --enable-mixed-mode
in which case it will default to 32 bit reals and add overloads to allow for both 32 bit and 64 bit operations. This results in one library with both 32 bit and 64 bit routines (defaulting to 32 bit reals).
By default CMake will build the library with 32 bit reals. It also has an option for 64 bit defaults , and if enabled will build an additional library with 64 bit reals. This results in distinct 32 bit and 64 bit libraries (libfms_r4.a and libfms_r8.a)
In many cases, running the shell command ./configure && make && make install
will build and install this package. Since libFMS requires the netCDF libraries, you will likely need to tell configure where to find the C and Fortran netCDF headers and libraries via the CPPFLAGS
, FCFLAGS
and LDFLAGS
variables
When building from a GitHub clone, the user must run autoreconf -i
before running the ./configure
script.
The ./configure
script will guess as many compiler options as required to build libFMS. In some cases you may be required to supply additional compiler flags for your system. Additional compiler options can be passed to the build with the CPPFLAGS
, CFLAGS
and FCFLAGS
variable. The ./configure
option --disable-setting-flags
will not guess required compiler flags. Using this configure option will require the user to give all required flags.
Run ./configure --help
to see other available configure options.
For more information on building with autotools and build options please see BUILD_SYSTEM.md
To build using CMake, follow the instructions in CMAKE_INSTRUCTIONS.mk. Currently the CMake configuration is the most restrictive build option as the compiler flags are immutable.
Make Makefile (MKMF) is the GFDL developed makefile generator application. MKMF uses a list of file, or a list of directories that contain Fortran or C file, a Make template file, and writes a Makefile with the correct dependencies to build a library or executable. To use MKMF to build libFMS, do the following.
git clone https://github.com/NOAA-GFDL/mkmf.git
mkmf/bin
directory to your PATH export PATH=/path/to/mkmf/bin:${PATH}
or setenv PATH /path/to/mkmf/bin:${PATH}
list_paths
command, on the FMS directory list_paths path/to/FMS
This will create a path_names file in the current directorymkmf/templates
directory that most closely matches you system and compiler. Make any modifications as needmkmf
libfms.a
, *.mod
, include/\*
files in your install location.While MKMF has been the build system used by GFDL to build all the GFDL models for some time, this build method requires the most user intervention when building libFMS on a new system.