diff --git a/docs/source/BuildingCMake.rst b/docs/source/BuildingCMake.rst index 9e886ae9016067a246374bcadd7abe052c3b1ddd..c7f6920d1c84aac9da8b3400b9ed0a4415de2df6 100644 --- a/docs/source/BuildingCMake.rst +++ b/docs/source/BuildingCMake.rst @@ -1,271 +1,153 @@ Building MFiX-Exa with CMake ============================ -To build MFiX-Exa, first get the source, run ``cmake`` to configure and generate -Makefiles, and run ``make`` to build MFiX-Exa. - -Throughout this section, ``builddir`` will be used as the name of the directory -used for building MFiX-Exa. - - -Getting the Source ------------------- - -Use Git to clone MFiX-Exa from the Gitlab repository. (Requires a user account -for the NETL MFiX-Exa Gitlab server.) - -.. code:: shell - - > git clone http://mfix.netl.doe.gov/gitlab/exa/mfix.git - > cd mfix - -The rest of the build instructions assume that the current directory is -``mfix``, the top directory of the MFiX-Exa repo. - - -Default AMReX (recommended) -~~~~~~~~~~~~~~~~~~~~~~~~~~~ - -By default, AMReX is downloaded and built as part of the MFiX-Exa build process -(**SUPERBUILD** mode). This method is recommended to ensure the -configuration options for MFiX-Exa and AMReX are compatible. - -Proceed to :ref:`Configuring`. - -.. note:: - - When running ``cmake``, ``subprojects/amrex`` will be cloned from - https://github.com/AMReX-Codes/amrex if it does not already exist. You can - also clone it manually if you want: - - .. code:: shell - - > git submodule update --init --recursive # OPTIONAL: cmake will do this automatically - -Custom AMReX -~~~~~~~~~~~~ - -For MFiX-Exa development or testing, you may need to build with a different -branch or release of AMReX. - -The ``subprojects/amrex`` directory is a Git repo, so use all standard Git -commands. Either ``cd subprojects/amrex`` to run Git commands in the ``amrex`` -directory, or use ``git -C subprojects/amrex`` in the MFiX-Exa repo. For -instance, to build with the ``my-amrex-branch`` branch of the AMReX repo: - -.. code:: shell - - > git -C subprojects/amrex checkout my-amrex-branch - > git status - ... - modified: subprojects/amrex (new commits) - -The ``my-amrex-branch`` will then be used when building MFiX-Exa. - -To revert to the default version of the AMReX submodule, run ``git submodule -update``: - -.. code:: shell - - > git submodule update - > git status - ... - nothing to commit, working tree clean - -You can edit, commit, pull, and push AMReX changes from ``subprojects/amrex``. -AMReX development is outside the scope of this document. Run ``git status`` in -the top-level MFix-Exa repo to see whether the AMReX submodule has new commits, -modified files, or untracked files. - -To update the AMReX submodule reference by MFiX-Exa: - -.. code:: shell - - > git add subprojects/amrex - > git commit -m 'Updating AMReX version' - -This will only update the AMReX SHA-1 referenced by MFiX-Exa. Uncommitted AMReX -changes and untracked AMReX files under ``subprojects/amrex`` are not added by -``git add subprojects/amrex``. Change directories to ``subprojects/amrex`` and -commit any AMReX changes first before ``git add subprojects/amrex``. - -.. note:: - - Only update the AMReX submodule reference in coordination with the other - MFiX-Exa developers! - -Proceed to :ref:`Configuring`. - - -.. _external_amrex: - -External AMReX -~~~~~~~~~~~~~~ - -It is also possible to build MFiX-Exa with an existing AMReX installation. - -For instructions on building AMReX with CMake, refer to the `AMReX user guide -<https://amrex-codes.github.io/amrex/docs_html/BuildingAMReX.html#building-with-cmake>`_ - -When building AMReX, the options ``ENABLE\_PARTICLES=yes``, -``ENABLE\_AMRDATA=yes``, and ``ENABLE\_EB=yes`` are required by MFiX-Exa. - -.. highlight:: console - -:: - - > cd /path/to/amrex/source - > cmake -S . -B build \ - -DENABLE_PARTICLES=yes \ - -DENABLE_AMRDATA=yes \ - -DENABLE_EB=yes \ - [other amrex options] \ - -DCMAKE_INSTALL_PREFIX:PATH=/absolute/path/to/installdir - > make -C build install - -If AMReX is built with the option: - -.. highlight:: console - -:: - - -DCMAKE_INSTALL_PREFIX:PATH=/absolute/path/to/amrex/installdir - -Then MFiX-Exa should set ``AMREX_ROOT`` to that directory when running -``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: .. highlight:: console :: - -DAMREX_ROOT=/absolute/path/to/amrex/installdir + mkdir /path/to/builddir + cd /path/to/builddir + cmake [options] -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] /path/to/mfix + make -Proceed to :ref:`Configuring`. +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: -.. _Configuring: +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 and configuration options +must meet MFiX-Exa requirements. -Configuring and Generating Makefiles ------------------------------------- +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. -Run ``cmake`` to generate Makefiles for building MFiX-Exa: -.. highlight:: console - -:: +**STANDALONE** instructions +--------------------------------------------------------------------- - > cmake -S . -B builddir +Build AMReX Library +~~~~~~~~~~~~~~~~~~~ -Proceed to :ref:`Building`. - -.. note:: - - By default MFiX-Exa is built with MPI support. Use ``-DENABLE_MPI=NO`` to - build without MPI. - - -Specifying Options -~~~~~~~~~~~~~~~~~~ - -.. highlight:: console - -:: - - > cmake -S . -B builddir \ - [amrex options] \ - [mfix options] - - -In the above snippet, ``[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>`_ -``[mfix options]`` indicates any of the configuration option listed in the table -below. - -+-------------------------+----------------------------+--------------------------------+----------+ -| Option name | Description | Possible values | Default | -| | | | value | -+=========================+============================+================================+==========+ -| ``CMAKE_BUILD_TYPE`` | Debug vs Release build | Debug, Release, RelWithDebInfo| Release | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``CMAKE_Fortran_FLAGS`` | User-defined Fortran flags | See your compiler manual | None | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``CMAKE_CXX_FLAGS`` | User-defined C++ flags | See your compiler manual | None | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``CMAKE_CUDA_FLAGS`` | User-defined CUDA flags | See your compiler manual | None | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``ENABLE_MPI`` | Enable MPI support | no/yes | yes | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``ENABLE_OMP`` | Enable OpenMP support | no/yes | no | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``ENABLE_CUDA`` | Enable CUDA support | no/yes | no | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``ENABLE_HYPRE`` | Enable HYPRE support | no/yes | no | -+-------------------------+----------------------------+--------------------------------+----------+ -| ``ENABLE_FPE`` | Build with Floating-Point | no/yes | no | -| | Exceptions checks | | | -+-------------------------+----------------------------+--------------------------------+----------+ - - -Specifying Compilers -~~~~~~~~~~~~~~~~~~~~ - -The default system default compilers can be overwritten as follows: +Clone AMReX from the official Git repository and checkout the +*development* branch: .. code:: shell - > cmake -S . -B builddir \ - -DCMAKE_CXX_COMPILER=<c++-compiler> \ - -DCMAKE_Fortran_COMPILER=<f90-compiler> - -.. note:: + > git clone https://github.com/AMReX-Codes/amrex.git + > cd amrex + > git checkout development - If ``ENABLE_MPI`` is set (the default), then ``CMAKE_CXX_COMPILER`` should - be a compiler wrapper such as ``mpic++``, or there will likely be build - errors. Likewise, ``CMAKE_Fortran_COMPILER`` should be set to ``mpifort`` - (or whatever is your MPI Fortran wrapper). +Next, configure, build and install AMReX as follows: +.. code:: shell -Specifying external AMReX -~~~~~~~~~~~~~~~~~~~~~~~~~ + > 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 -If building with :ref:`external_amrex`, specify the path to AMReX with -``-DAMREX_ROOT``: +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. -.. highlight:: console -:: +Building MFiX-Exa +~~~~~~~~~~~~~~~~~ - > cmake -S . -B builddir \ - -DAMREX_ROOT=/absolute/path/to/amrex/installdir +Clone and build MFiX-Exa: -Passing ``-DAMREX_ROOT=/absolute/path/to/amrex/installdir`` instructs CMake to -search ``/absolute/path/to/amrex/installdir``, and then search system paths, for -an available AMReX installation. +.. code:: shell -Alternatively, set the ``AMREX_ROOT`` environmental variable instead of passing -it as a command line option. + > git clone http://mfix.netl.doe.gov/gitlab/exa/mfix.git + > mkdir build + > cd build + > cmake -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] [mfix options] -DAMReX_ROOT=/absolute/path/to/amrex/installdir .. + > make -j + + +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. + + +``[mfix options]`` indicates any of the configuration option listed in the table below. + ++-----------------+------------------------------+------------------+-------------+ +| Option name | Description | Possible values | Default | +| | | | value | ++=================+==============================+==================+=============+ +| CMAKE\_Fortran\ | User-defined Fortran flags | valid Fortran | None | +| _FLAGS | | compiler flags | | ++-----------------+------------------------------+------------------+-------------+ +| CMAKE\_CXX\ | User-defined C++ flags | valid C++ | None | +| _FLAGS | | compiler flags | | ++-----------------+------------------------------+------------------+-------------+ +| CMAKE\_CUDA\ | User-defined CUDA flags | valid CUDA | None | +| _FLAGS | | compiler flags | | ++-----------------+------------------------------+------------------+-------------+ +| ENABLE\_MPI | Enable build with MPI | no/yes | yes | +| | | | | ++-----------------+------------------------------+------------------+-------------+ +| ENABLE\_OMP | Enable build with OpenMP | no/yes | no | +| | | | | ++-----------------+------------------------------+------------------+-------------+ +| ENABLE\_CUDA | Enable build with CUDA | no/yes | no | +| | | | | ++-----------------+------------------------------+------------------+-------------+ +| ENABLE\_HYPRE | Enable HYPRE support | no/yes | no | +| | | | | ++-----------------+------------------------------+------------------+-------------+ +| ENABLE\_FPE | Build with Floating-Point | no/yes | no | +| | Exceptions checks | | | ++-----------------+------------------------------+------------------+-------------+ + + +SUPERBUILD Instructions (recommended) +------------------------------------- + +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. + + +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: -.. note:: +.. code:: shell - MFiX-Exa needs to be built with the same CMake options used to build the - external AMReX installation. This is another reason when the default - (Superbuild) option is recommended. + > git clone http://mfix.netl.doe.gov/gitlab/exa/mfix.git + > cd mfix + > mkdir build + > cd build + > cmake [amrex options] -DCMAKE_BUILD_TYPE=[Debug|Release|RelWithDebInfo|MinSizeRel] .. + > make -j +``[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>`_ -.. _Building: -Building --------- +Few more notes on building MFiX-Exa +----------------------------------- -To build MFiX-Exa: +The system defaults compilers can be overwritten as follows: .. code:: shell - > make -C builddir + > cmake -DCMAKE_CXX_COMPILER=<c++-compiler> -DCMAKE_Fortran_COMPILER=<f90-compiler> [options] .. -To build all test cases: +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 - > make -C builddir build_tests + > 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 +the environmental variables ``FFLAGS``/``CXXFLAGS`` are set.