-
Notifications
You must be signed in to change notification settings - Fork 15
Building and Running on Frontier
Angel Castillo edited this page Aug 10, 2023
·
4 revisions
The following instructions apply to the Frontier system.
Create a working directory to contain the build script, environment script, the source code, and build directories.
Create a script env.sh
with the following contents:
module reset
module load PrgEnv-amd
module load craype-accel-amd-gfx90a
module load cray-mpich
export CRAYPE_LINK_TYPE=dynamic
export MPICH_GPU_SUPPORT_ENABLED=1
Create a script named installAll.sh
with the following contents:
#!/bin/bash
# Kokkos
git clone -b 4.1.00 [email protected]:Kokkos/kokkos.git
bdir=$PWD/buildKokkosVega90a
rm -rf $bdir
cmake -S kokkos -B $bdir \
-DCMAKE_BUILD_TYPE=RelWithDebInfo\
-DCMAKE_CXX_COMPILER=CC\
-DCMAKE_CXX_EXTENSIONS=OFF\
-DKokkos_ENABLE_TESTS=OFF\
-DKokkos_ENABLE_EXAMPLES=OFF\
-DKokkos_ENABLE_SERIAL=ON\
-DKokkos_ENABLE_OPENMP=OFF\
-DKokkos_ENABLE_HIP=ON\
-DKokkos_ARCH_VEGA90A=ON\
-DKokkos_ENABLE_DEBUG=OFF\
-DCMAKE_INSTALL_PREFIX=$bdir/install
cmake --build $bdir -j8 --target install
#Omega_h
git clone -b reducedThrust [email protected]:SCOREC/omega_h.git
bdir=$PWD/buildOmegahVega90a
rm $bdir -rf
cmake -S omega_h -B $bdir \
-DCMAKE_INSTALL_PREFIX=$bdir/install \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DBUILD_SHARED_LIBS=OFF \
-DOmega_h_USE_CUDA=OFF \
-DOmega_h_USE_MPI=ON \
-DOmega_h_USE_OpenMP=OFF \
-DCMAKE_CXX_COMPILER=CC \
-DOmega_h_USE_Kokkos=ON \
-DOmega_h_USE_CUDA_AWARE_MPI=ON \
-DKokkos_PREFIX=$PWD/buildKokkosVega90a/install \
-DBUILD_TESTING=ON
cmake --build $bdir -j8 --target install
#Engpar
git clone [email protected]:SCOREC/EnGPar.git
bdir=$PWD/buildEngparVega90a
cmake -S EnGPar -B $bdir \
-DCMAKE_INSTALL_PREFIX=$bdir/install \
-DCMAKE_C_COMPILER="mpicc" \
-DCMAKE_CXX_COMPILER="mpicxx" \
-DCMAKE_CXX_FLAGS="-std=c++11" \
-DENABLE_PARMETIS=OFF \
-DENABLE_PUMI=OFF \
-DIS_TESTING=OFF
cmake --build $bdir -j8 --target install
#Cabana
git clone https://github.com/ECP-copa/Cabana.git cabana
bdir=$PWD/buildCabanaVega90a
rm $bdir -rf
cmake -S cabana -B $bdir \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DCMAKE_CXX_COMPILER=CC \
-DCMAKE_PREFIX_PATH=$PWD/buildKokkosVega90a/install \
-DCMAKE_INSTALL_PREFIX=$bdir/install
cmake --build $bdir -j8 --target install
#Pumi-Pic
git clone --recursive -b ac/replace-cuda-thrust [email protected]:SCOREC/pumi-pic.git
bdir=$PWD/buildPumiPicVega90a
rm -rf $bdir
cmake -S pumi-pic -B $bdir \
-DCMAKE_CXX_COMPILER=CC \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DIS_TESTING=ON \
-DPS_IS_TESTING=ON \
-DPS_USE_GPU_AWARE_MPI=ON \
-DTEST_DATA_DIR=$PWD/pumi-pic/pumipic-data \
-DOmega_h_PREFIX=$PWD/buildOmegahVega90a/install \
-DKokkos_PREFIX=$PWD/buildKokkosVega90a/install \
-DEnGPar_PREFIX=$PWD/buildEngparVega90a/install \
-DCabana_PREFIX=$PWD/buildCabanaVega90a/install \
-DENABLE_CABANA=on \
-DCMAKE_INSTALL_PREFIX=$bdir/install
cmake --build $bdir -j8 --target install
Make the script executable:
chmod +x installAll.sh
Source the environment file, and run the build script:
source env.sh
./installAll.sh
cd buildPumiPicVega90a
salloc -A PHY122 -t 00:10:00 -q debug -N 1 -n 1 -c1 --gpus-per-task=1
ctest