Skip to content

Commit

Permalink
chore: upgrade Trilinos version (GEOS-DEV#288) (#3)
Browse files Browse the repository at this point in the history
* chore: upgrade Trilinos version

* enable zoltan (GEOS-DEV#287)

* enable zoltan

* specify clang17 in rockylinux build

* exclude clang from update after install

* update caliper to avoid error with std::filesystem linker errors

* try updating cuda image to 12.6.3

Co-authored-by: Matteo Cusini <[email protected]>
Co-authored-by: Randolph Settgast <[email protected]>
  • Loading branch information
3 people authored Dec 12, 2024
1 parent 79ac745 commit a81b489
Show file tree
Hide file tree
Showing 7 changed files with 50 additions and 19 deletions.
47 changes: 39 additions & 8 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,8 @@ message( "Running with NUM_PROC = ${NUM_PROC}")
set(TPL_MIRROR_DIR "${CMAKE_SOURCE_DIR}/tplMirror")
set(build_list )

set( CMAKE_POSITION_INDEPENDENT_CODE ON )

# Set up C flags
string(REPLACE "-Wall" "" C_FLAGS_NO_WARNINGS ${CMAKE_C_FLAGS})
string(REPLACE "-Wextra" "" C_FLAGS_NO_WARNINGS ${C_FLAGS_NO_WARNINGS})
Expand Down Expand Up @@ -222,7 +224,7 @@ ExternalProject_Add( hdf5
-D BUILD_STATIC_LIBS:BOOL=OFF
-D BUILD_TESTING:BOOL=OFF
-D HDF5_BUILD_EXAMPLES:BOOL=OFF
-D HDF5_BUILD_TOOLS:BOOL=OFF
-D HDF5_BUILD_TOOLS:BOOL=ON
-D HDF5_BUILD_UTILS:BOOL=OFF
)

Expand Down Expand Up @@ -352,6 +354,8 @@ ExternalProject_Add( raja
-D CMAKE_VERBOSE_MAKEFILE:BOOL=${CMAKE_VERBOSE_MAKEFILE}
-D ENABLE_CUDA:BOOL=${ENABLE_CUDA}
-D RAJA_ENABLE_CUDA:BOOL=${ENABLE_CUDA}
-D RAJA_ENABLE_NV_TOOLS_EXT:BOOL=${ENABLE_CUDA_NVTOOLSEXT}
-D RAJA_ENABLE_ROCTX:BOOL=${ENABLE_ROCTX}
-D CMAKE_CUDA_COMPILER=${CMAKE_CUDA_COMPILER}
-D CUDA_TOOLKIT_ROOT_DIR=${CUDA_TOOLKIT_ROOT_DIR}
-D CMAKE_CUDA_ARCHITECTURES:STRING=${CMAKE_CUDA_ARCHITECTURES}
Expand Down Expand Up @@ -445,7 +449,7 @@ if (ENABLE_CALIPER)


set(CALIPER_DIR "${CMAKE_INSTALL_PREFIX}/caliper")
set(CALIPER_URL "${TPL_MIRROR_DIR}/Caliper-2.11.0.tar.gz")
set(CALIPER_URL "${TPL_MIRROR_DIR}/Caliper-2.12.0.tar.gz")
message(STATUS "Building Caliper found at ${CALIPER_URL}")

set(CALIPER_WITH_CUPTI OFF)
Expand Down Expand Up @@ -562,12 +566,21 @@ list(APPEND build_list pugixml )
################################
if (ENABLE_TRILINOS)
set(TRILINOS_DIR "${CMAKE_INSTALL_PREFIX}/trilinos")
set(TRILINOS_URL "${TPL_MIRROR_DIR}/trilinos-release-15-1-1.tar.gz")
set(TRILINOS_URL "${TPL_MIRROR_DIR}/trilinos-release-16-0-0.tar.gz")

message(STATUS "Building TRILINOS found at ${TRILINOS_URL}")

set(TRILINOS_C_FLAGS "-fPIC ${C_FLAGS_NO_WARNINGS}")
set(TRILINOS_CXX_FLAGS "-fPIC ${CXX_FLAGS_NO_WARNINGS} -include cstdint")
if ( CMAKE_CXX_COMPILER_ID STREQUAL "Clang" AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 16.0 )
set(TRILINOS_C_FLAGS "-fPIC ${C_FLAGS_NO_WARNINGS}")
set(TRILINOS_CXX_FLAGS "-fPIC ${CXX_FLAGS_NO_WARNINGS} -include cstdint")
set(TRILINOS_Fortran_FLAGS "-fPIC ${CMAKE_Fortran_FLAGS}")
else()
set(TRILINOS_C_FLAGS "${C_FLAGS_NO_WARNINGS}")
set(TRILINOS_CXX_FLAGS "${CXX_FLAGS_NO_WARNINGS} -include cstdint")
set(TRILINOS_Fortran_FLAGS "${CMAKE_Fortran_FLAGS}")
endif()



if( ENABLE_MKL )
set( TRILINOS_EXTRA_ARGS ${TRILINOS_EXTRA_ARGS}
Expand Down Expand Up @@ -617,6 +630,7 @@ if (ENABLE_TRILINOS)
-D CMAKE_CXX_FLAGS:STRING=${TRILINOS_CXX_FLAGS}
-D CMAKE_CXX_FLAGS_RELEASE:STRING=${CMAKE_CXX_FLAGS_RELEASE}
-D CMAKE_Fortran_COMPILER:PATH=${TRILINOS_Fortran_COMPILER}
-D CMAKE_Fortran_FLAGS:STRING=${TRILINOS_Fortran_FLAGS}
-D CMAKE_Fortran_FLAGS_RELEASE:STRING=${CMAKE_Fortran_FLAGS_RELEASE}
-D CMAKE_BUILD_TYPE:STRING=${CMAKE_BUILD_TYPE}
-D CMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR>
Expand All @@ -641,11 +655,17 @@ if (ENABLE_TRILINOS)
-D Trilinos_ENABLE_AztecOO:BOOL=ON
-D Trilinos_ENABLE_Ifpack:BOOL=ON
-D Trilinos_ENABLE_Teuchos:BOOL=ON
-D Trilinos_ENABLE_Zoltan:BOOL=ON
-D Trilinos_ENABLE_ML:BOOL=ON
-D Trilinos_ENABLE_Thyra:BOOL=ON
-D Trilinos_ENABLE_STK:BOOL=OFF
-D Trilinos_ENABLE_TrilinosCouplings:BOOL=ON
-D Trilinos_ENABLE_EXPLICIT_INSTANTIATION:BOOL=ON
-D Epetra_SHOW_DEPRECATED_WARNINGS::BOOL=OFF
-D EpetraExt_SHOW_DEPRECATED_WARNINGS::BOOL=OFF
-D ML_SHOW_DEPRECATED_WARNINGS::BOOL=OFF
-D AztecOO_SHOW_DEPRECATED_WARNINGS::BOOL=OFF
-D Ifpack_SHOW_DEPRECATED_WARNINGS::BOOL=OFF
${TRILINOS_EXTRA_ARGS}
)

Expand Down Expand Up @@ -721,6 +741,17 @@ if( ENABLE_MPI )
set(SUPERLU_DIR "${CMAKE_INSTALL_PREFIX}/superlu_dist")
set(SUPERLU_URL "${TPL_MIRROR_DIR}/superlu_dist-0f6efc3.tar.gz")

if ( CMAKE_CXX_COMPILER_ID STREQUAL "Clang" AND CMAKE_CXX_COMPILER_VERSION VERSION_GREATER 16.0 )
set(SUPERLU_C_FLAGS "-fPIC ${C_FLAGS_NO_WARNINGS}")
set(SUPERLU_CXX_FLAGS "-fPIC ${CXX_FLAGS_NO_WARNINGS}")
set(SUPERLU_Fortran_FLAGS "-fPIC ${CMAKE_Fortran_FLAGS}")
else()
set(SUPERLU_C_FLAGS "${C_FLAGS_NO_WARNINGS}")
set(SUPERLU_CXX_FLAGS "${CXX_FLAGS_NO_WARNINGS}")
set(SUPERLU_Fortran_FLAGS "${CMAKE_Fortran_FLAGS}")
endif()


set(PARMETIS_INCLUDE_DIRS ${CMAKE_INSTALL_PREFIX}/parmetis/include;${CMAKE_INSTALL_PREFIX}/metis/include)
set(PARMETIS_LIBRARIES ${CMAKE_INSTALL_PREFIX}/parmetis/lib/libparmetis.a;${CMAKE_INSTALL_PREFIX}/metis/lib/libmetis.a)

Expand All @@ -745,11 +776,11 @@ if( ENABLE_MPI )
-D MPI_C_COMPILER=${MPI_C_COMPILER}
-D MPI_CXX_COMPILER=${MPI_CXX_COMPILER}
-D CMAKE_C_STANDARD=99
-D CMAKE_C_FLAGS=${C_FLAGS_NO_WARNINGS}
-D CMAKE_C_FLAGS=${SUPERLU_C_FLAGS}
-D CMAKE_C_FLAGS_RELEASE=${CMAKE_C_FLAGS_RELEASE}
-D CMAKE_CXX_FLAGS=${CXX_FLAGS_NO_WARNINGS}
-D CMAKE_CXX_FLAGS=${SUPERLU_CXX_FLAGS}
-D CMAKE_CXX_FLAGS_RELEASE=${CMAKE_CXX_FLAGS_RELEASE}
-D CMAKE_Fortran_FLAGS=${CMAKE_Fortran_FLAGS}
-D CMAKE_Fortran_FLAGS=${SUPERLU_Fortran_FLAGS}
-D CMAKE_Fortran_FLAGS_RELEASE=${CMAKE_Fortran_FLAGS_RELEASE}
-D CMAKE_POSITION_INDEPENDENT_CODE=${CMAKE_POSITION_INDEPENDENT_CODE}
-D CMAKE_INSTALL_PREFIX:PATH=<INSTALL_DIR>
Expand Down
2 changes: 1 addition & 1 deletion docker/install-cmake.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
set -xe

# Installing latest `CMake` version available
VERSION=${1-3.28.3}
VERSION=${1-3.28.6}
PREFIX=${2-/usr/local}

curl -s https://cmake.org/files/v${VERSION%.[0-9]*}/cmake-$VERSION-linux-x86_64.tar.gz | \
Expand Down
8 changes: 4 additions & 4 deletions docker/tpl-rockylinux-clang-cuda-12.Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ ARG TMP_DIR=/tmp
ARG SRC_DIR=$TMP_DIR/thirdPartyLibs
ARG BLD_DIR=$TMP_DIR/build

FROM nvidia/cuda:12.5.0-devel-rockylinux8 AS tpl_toolchain_intersect_geosx_toolchain
FROM nvidia/cuda:12.6.3-devel-rockylinux8 AS tpl_toolchain_intersect_geosx_toolchain
ARG SRC_DIR

ARG INSTALL_DIR
Expand All @@ -14,7 +14,7 @@ RUN dnf clean all && \
dnf -y update && \
dnf -y install \
which \
clang \
clang-17.0.6 \
gcc-gfortran \
python3 \
zlib-devel \
Expand Down Expand Up @@ -66,7 +66,7 @@ ENV OMPI_FC=$FC

# Install required packages using dnf
RUN dnf clean all && \
dnf -y update && \
dnf -y update --exclude=clang*,compiler-rt,libomp*,llvm* && \
dnf -y install \
tbb-devel \
bc \
Expand Down Expand Up @@ -112,7 +112,7 @@ RUN dnf clean all && \
rm -rf /var/cache/dnf && \
dnf -y install dnf-plugins-core && \
dnf config-manager --set-enabled devel && \
dnf -y update && \
dnf -y update --exclude=clang*,compiler-rt,libomp*,llvm* && \
dnf -y install \
openssh-clients \
ca-certificates \
Expand Down
3 changes: 0 additions & 3 deletions tplMirror/Caliper-2.11.0.tar.gz

This file was deleted.

3 changes: 3 additions & 0 deletions tplMirror/Caliper-2.12.0.tar.gz
Git LFS file not shown
3 changes: 0 additions & 3 deletions tplMirror/trilinos-release-15-1-1.tar.gz

This file was deleted.

3 changes: 3 additions & 0 deletions tplMirror/trilinos-release-16-0-0.tar.gz
Git LFS file not shown

0 comments on commit a81b489

Please sign in to comment.