From 28b3bb204430d7d83c768f5de589be5eba3bcd0e Mon Sep 17 00:00:00 2001 From: Michele Rosso <mrosso@lbl.gov> Date: Fri, 14 Jun 2019 16:07:07 -0700 Subject: [PATCH] Update CMake doc --- docs/source/BuildingCMake.rst | 221 ++++++++++++++-------------------- 1 file changed, 89 insertions(+), 132 deletions(-) diff --git a/docs/source/BuildingCMake.rst b/docs/source/BuildingCMake.rst index b1674f2..c7f6920 100644 --- a/docs/source/BuildingCMake.rst +++ b/docs/source/BuildingCMake.rst @@ -1,179 +1,136 @@ Building MFiX-Exa with CMake ============================ -There are two options to building MFiX-Exa with cmake: +CMake build is a two-step process. First ``cmake`` is invoked to create +configuration files and makefiles in a chosen directory (``builddir``). +Next, the actual build is performed by invoking ``make`` from within ``builddir``. +The CMake build process is summarized as follows: -o **SUPERBUILD (default):** Utilities download and build AMReX as part -of the MFiX-Exa build process. This method is strongly encouraged as it -ensures configure options for MFiX-Exa and AMReX are consistent. +.. highlight:: console + +:: + + mkdir /path/to/builddir + cd /path/to/builddir + cmake [options] -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] /path/to/mfix + make + +In the above snippet, ``[options]`` indicates one or more options for the +customization of the build, as described later in this section. +If the option ``CMAKE_BUILD_TYPE`` is omitted, +``CMAKE_BUILD_TYPE=Release`` is assumed. + +There are two modes to build MFiX-Exa with cmake: -o **Using an existing AMReX Library:** MFiX-Exa is linked to an existing +o **STANDALONE:** MFiX-Exa source code is built separately and linked to an existing AMReX installation. This is ideal for continuous integration severs (CI) -and regression testing applications. AMReX library version must meet -MFiX-Exa requirements. +and regression testing applications. AMReX library version and configuration options +must meet MFiX-Exa requirements. -SUPERBUILD Instructions (recommended) -------------------------------------- +o **SUPERBUILD (recommended):** AMReX is downloaded and built as part +of the MFiX-Exa build process. This method is strongly encouraged as it +ensures that the configuration options for MFiX-Exa and AMReX are consistent. + + +**STANDALONE** instructions +--------------------------------------------------------------------- + +Build AMReX Library +~~~~~~~~~~~~~~~~~~~ -When building in **SUPERBUILD** mode, MFiX-Exa build system will take -care of downloading, configuring and installing AMReX as part of the -MFiX-Exa build. The following commands build MFiX-Exa and AMReX in a -single step. +Clone AMReX from the official Git repository and checkout the +*development* branch: + +.. code:: shell + + > git clone https://github.com/AMReX-Codes/amrex.git + > cd amrex + > git checkout development + +Next, configure, build and install AMReX as follows: + +.. code:: shell + + > mkdir build + > cd build + > cmake -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] -DENABLE_PARTICLES=yes -DENABLE_AMRDATA=yes -DENABLE_EB=yes [other amrex options] -DCMAKE_INSTALL_PREFIX:PATH=/absolute/path/to/installdir .. + > make install + +The options **ENABLE\_PARTICLES=yes**, **ENABLE\_AMRDATA=yes**, and **ENABLE\_EB=yes** are required by MFiX-Exa. ``[other amrex options]`` in the snippet above refers to any other AMReX configuration option in addition to the required ones. Please refer to the `AMReX user guide <https://amrex-codes.github.io/amrex/docs_html/BuildingAMReX.html#building-with-cmake>`_ for more details on building AMReX with CMake. + + +Building MFiX-Exa +~~~~~~~~~~~~~~~~~ + +Clone and build MFiX-Exa: .. code:: shell > git clone http://mfix.netl.doe.gov/gitlab/exa/mfix.git - > cd mfix > mkdir build > cd build - > cmake CONFIG_OPTIONS .. + > cmake -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] [mfix options] -DAMReX_ROOT=/absolute/path/to/amrex/installdir .. > make -j -AMReX is built the first time the ``make`` command is issued. No -external installation of AMReX is needed. However, internet access to -the AMReX github repository is required. The optional string -``CONFIG_OPTIONS`` allows to customize the build of both AMReX and -MFiX-Exa. ``CONFIG_OPTIONS`` is a list of one or more configuration -options given in the form **-D**\ *OPTION=VALUE*\ \`. + +Passing ``-DAMReX_ROOT=/absolute/path/to/amrex/installdir`` instructs CMake to search +``/absolute/path/to/amrex/installdir`` before searching system paths +for an available AMReX installation. +``AMReX_ROOT`` can also be set as an environmental variable instead of passing it as a command line option. + -The table below lists configuration options, possible values, and their -effect on the build. Options prefixed by ``AMREX_`` are specific to the -build of AMReX. +``[mfix options]`` indicates any of the configuration option listed in the table below. +-----------------+------------------------------+------------------+-------------+ | Option name | Description | Possible values | Default | | | | | value | +=================+==============================+==================+=============+ -| DEBUG | Build in debug mode | ON/OFF | OFF | +| CMAKE\_Fortran\ | User-defined Fortran flags | valid Fortran | None | +| _FLAGS | | compiler flags | | +-----------------+------------------------------+------------------+-------------+ -| CMAKE\_Fortran\ | User-defined Fortran flags | valid F90 | None | -| _FLAGS | for MFiX build | compiler flags | | +| CMAKE\_CXX\ | User-defined C++ flags | valid C++ | None | +| _FLAGS | | compiler flags | | +-----------------+------------------------------+------------------+-------------+ -| CMAKE\_CXX\_FLA | User-defined C++ flags for | valid C++ | None | -| GS | MFiX build | compiler flags | | +| CMAKE\_CUDA\ | User-defined CUDA flags | valid CUDA | None | +| _FLAGS | | compiler flags | | +-----------------+------------------------------+------------------+-------------+ -| AMREX\_Fortran\ | User-defined Fortran flags | valid F90 | None | -| _FLAGS | for AMReX build | compiler flags | | +| ENABLE\_MPI | Enable build with MPI | no/yes | yes | +| | | | | +-----------------+------------------------------+------------------+-------------+ -| AMREX\_CXX\_FLA | User-defined C++ flags for | valid C++ | None | -| GS | AMReX build | compiler flags | | +| ENABLE\_OMP | Enable build with OpenMP | no/yes | no | +| | | | | +-----------------+------------------------------+------------------+-------------+ -| ENABLE\_MPI | Enable build with MPI | 0/1 | 1 | +| ENABLE\_CUDA | Enable build with CUDA | no/yes | no | | | | | | +-----------------+------------------------------+------------------+-------------+ -| ENABLE\_OMP | Enable build with OpenMP | 0/1 | 0 | +| ENABLE\_HYPRE | Enable HYPRE support | no/yes | no | | | | | | +-----------------+------------------------------+------------------+-------------+ -| ENABLE\_FPE | Build with Floating-Point | 0/1 | 0 | +| ENABLE\_FPE | Build with Floating-Point | no/yes | no | | | Exceptions checks | | | +-----------------+------------------------------+------------------+-------------+ -| ENABLE\_PTESTS | Include tests for projection | 0/1 | 0 | -| | method in Ctest suite | | | -+-----------------+------------------------------+------------------+-------------+ -| ENABLE\_STESTS | Include tests for SIMPLE | 0/1 | 1 | -| | method in Ctest suite | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Enable build with MPI | 0/1 | 1 | -| MPI | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Enable build with OpenMP | 0/1 | 0 | -| OMP | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Enable double precision | 0/1 | 1 | -| DP | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Enable double precision in | 0/1 | 1 | -| DP\_PARTICLES | particles classes | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include profiling info | 0/1 | 0 | -| BASE\_PROFILE | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include tiny profiling info | 0/1 | 0 | -| TINY\_PROFILE | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include communicators | 0/1 | 0 | -| COMM\_PROFILE | profiling info | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include trace profiling info | 0/1 | 0 | -| TRACE\_PROFILE | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include memory profiling | 0/1 | 0 | -| MEM\_PROFILE | info | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include backtrace info | 0/1 | 0 | -| BACKTRACE | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Include profile parser | 0/1 | 0 | -| PROFPARSER | | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Build position-independent | 0/1 | 0 | -| PIC | code | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_ENABLE\_ | Build position-independent | 0/1 | 0 | -| ASSERTION | code | | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_GIT\_COM | AMReX commit to be used in | valid git commit | None | -| MIT | the build | id/branch | | -+-----------------+------------------------------+------------------+-------------+ -| AMREX\_INSTALL\ | Global path to AMReX install | valid global | None | -| _DIR | directory | path | (superbuild | -| | | | ) | -+-----------------+------------------------------+------------------+-------------+ - -``SUPERBUILD mode is enabled automatically when AMREX_INSTALL_DIR is not given.`` - -Example: build mfix with custom fortran flags, AMReX profiling enabled -and single precision particles: - -:: - - cmake -DMFiX_FFLAGS_OVERRIDES="custom flags" -DAMREX_ENABLE_BASE_PROFILE=1 -DAMREX_ENABLE_DP_PARTICLES=0 .. - -Building MFiX-Exa using a separate AMReX installation (no superbuild) ---------------------------------------------------------------------- -Build AMReX Library -~~~~~~~~~~~~~~~~~~~ - -Clone AMReX from the official Git repository and checkout the -*development* branch. - -.. code:: shell - > git clone https://github.com/AMReX-Codes/amrex.git - > cd amrex - > git checkout development - -Next, configure, build and install AMReX as follows: - -.. code:: shell - - > cmake AMREX_CONFIG_OPTIONS -DENABLE_PARTICLES=1 -DENABLE_AMRDATA=1 -DENABLE_EB=1 -DCMAKE_INSTALL_PREFIX:PATH=/absolute/path/to/installdir . - > make install +SUPERBUILD Instructions (recommended) +------------------------------------- -Here,\ ``AMREX_CONFIG_OPTIONS`` are optional configure options for -AMReX. Please refer to the AMReX user guide for a list of all the -possible configuration options. The only options required are -**-DENABLE\_PARTICLES=1**, **-DENABLE\_AMRDATA=1**, and -**-DENABLE\_EB=1**. +If no AMReX installation is found on the system, or if one is found but does not meet MFiX-Exa requirements, MFiX-Exa CMake falls back to **SUPERBUILD** mode. +When building in **SUPERBUILD** mode, the AMReX git repo is checked out via a git submodule before AMReX CMake build system is included into MFiX-Exa CMake infrastructure. Consequently, MFiX-Exa CMake inherents AMReX's CMake targets and configuration options, that is, MFiX-Exa and AMReX are configured and built as a single entity. -Building MFiX-Exa -~~~~~~~~~~~~~~~~~ -Clone and build MFiX-Exa. +Assuming no valid AMReX installation is present on the target system, and ``AMReX_ROOT`` is not set in the environment, the following code will build MFiX-Exa in **SUPERBUILD** mode: .. code:: shell > git clone http://mfix.netl.doe.gov/gitlab/exa/mfix.git + > cd mfix > mkdir build > cd build - > cmake CONFIG_OPTIONS -DAMREX_INSTALL_DIR=/absolute/path/to/amrex/installdir .. + > cmake [amrex options] -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] .. > make -j -Here, ``CONFIG_OPTIONS`` are MFiX-Exa specific configuration options, -that is, any option NOT prefixed by ``AMREX_`` in the table above. -Options prefixed by ``AMREX_`` are always ignored when using an external -AMReX installation. +``[amrex options]`` is a list of any of the AMReX configuration options listed in the `AMReX user guide <https://amrex-codes.github.io/amrex/docs_html/BuildingAMReX.html#building-with-cmake>`_ + Few more notes on building MFiX-Exa ----------------------------------- @@ -182,14 +139,14 @@ The system defaults compilers can be overwritten as follows: .. code:: shell - > cmake -DCMAKE_CXX_COMPILER=<c++-compiler> -DCMAKE_Fortran_COMPILER=<f90-compiler> CONFIG_OPTIONS .. + > cmake -DCMAKE_CXX_COMPILER=<c++-compiler> -DCMAKE_Fortran_COMPILER=<f90-compiler> [options] .. When building on a platform that uses the ``module`` utility, use either the above command (with full path to the compilers) or the following: .. code:: shell - > cmake -DCMAKE_CXX_COMPILER=CC -DCMAKE_Fortran_COMPILER=ftn CONFIG_OPTIONS .. + > cmake -DCMAKE_CXX_COMPILER=CC -DCMAKE_Fortran_COMPILER=ftn [options] .. MFiX-Exa uses the same compiler flags used to build AMReX, unless ``CMAKE_Fortran_FLAGS``/``CMAKE_CXX_FLAGS`` is explicitly provided, or -- GitLab