Skip to content

Commit

Permalink
Globus Refactor (#121)
Browse files Browse the repository at this point in the history
* test globus

* remove push

* increment version

* fix test

* remove push
  • Loading branch information
Angelyr authored Nov 9, 2024
1 parent e501152 commit e46d4f5
Show file tree
Hide file tree
Showing 8 changed files with 152 additions and 102 deletions.
47 changes: 47 additions & 0 deletions .github/workflows/frontier/install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# #!/bin/bash

branch=$1

cd /lustre/orion/phy122/scratch/castia5/globus-compute/omega_h-test

module load rocm
module load craype-accel-amd-gfx90a
module load cray-mpich
export CRAYPE_LINK_TYPE=dynamic
export MPICH_GPU_SUPPORT_ENABLED=1

# # Kokkos
# rm kokkos -rf
# rm build-kokkos -rf
# git clone -b 4.1.00 git@github.com:Kokkos/kokkos.git
# cmake -S kokkos -B build-kokkos \
# -DCMAKE_BUILD_TYPE=RelWithDebInfo \
# -DCMAKE_CXX_COMPILER=CC \
# -DCMAKE_CXX_EXTENSIONS=OFF \
# -DKokkos_ENABLE_TESTS=OFF \
# -DKokkos_ENABLE_EXAMPLES=OFF \
# -DKokkos_ENABLE_HIP=ON \
# -DKokkos_ARCH_VEGA90A=ON \
# -DKokkos_ENABLE_SERIAL=ON \
# -DKokkos_ENABLE_OPENMP=OFF \
# -DKokkos_ENABLE_DEBUG=OFF \
# -DCMAKE_INSTALL_PREFIX=build-kokkos/install
# cmake --build build-kokkos -j8 --target install

# Omega_h
rm omega_h -rf
rm build-omega_h -rf
git clone git@github.com:SCOREC/omega_h.git
cd omega_h && git checkout $branch && cd -
cmake -S omega_h -B build-omega_h \
-DCMAKE_INSTALL_PREFIX=build-omega_h/install \
-DCMAKE_BUILD_TYPE=RelWithDebInfo \
-DBUILD_SHARED_LIBS=OFF \
-DOmega_h_USE_MPI=ON \
-DOmega_h_USE_OpenMP=OFF \
-DCMAKE_CXX_COMPILER=CC \
-DOMEGA_H_USE_HIP=ON \
-DOmega_h_USE_Kokkos=ON \
-DKokkos_PREFIX=$PWD/build-kokkos/install \
-DBUILD_TESTING=ON
cmake --build build-omega_h -j24 --target install
15 changes: 15 additions & 0 deletions .github/workflows/frontier/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
#!/bin/bash

name=omega_h

cd /lustre/orion/phy122/scratch/castia5/globus-compute/$name-test

module load rocm
module load craype-accel-amd-gfx90a
module load cray-mpich
export CRAYPE_LINK_TYPE=dynamic
export MPICH_GPU_SUPPORT_ENABLED=1

cd build-$name
salloc --account=PHY122 --time=00:20:00 -q debug --nodes=1 --ntasks=1 --cpus-per-task=1 --gpus-per-task=1 --gpus=1 ctest
cat $PWD/Testing/Temporary/LastTest.log
19 changes: 19 additions & 0 deletions .github/workflows/globus-test.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
name: Globus-Systems
on:
schedule:
# Monday 6:35 UTC or 02:35 EDT
- cron: '35 6 * * 1'

jobs:

perlmutter-test:
uses: SCOREC/github-actions/.github/workflows/globus-test.yml@main
secrets: inherit
with:
machine: "perlmutter"

frontier-test:
uses: SCOREC/github-actions/.github/workflows/globus-test.yml@main
secrets: inherit
with:
machine: "frontier"
54 changes: 54 additions & 0 deletions .github/workflows/perlmutter/install.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,54 @@
# !/bin/bash -e

branch=$1

cd $SCRATCH/globus-compute/omega_h-test

export root=$PWD
module load PrgEnv-gnu
module load cudatoolkit
module load cmake

export kk=$root/build-kokkos/install # This is where kokkos will be (or is) installed
export oh=$root/build-omega_h/install # This is where omega_h will be (or is) installed
export CMAKE_PREFIX_PATH=$kk:$kk/lib64/cmake:$oh:$CMAKE_PREFIX_PATH
export MPICH_CXX=$root/kokkos/bin/nvcc_wrapper

export SLURM_CPU_BIND="cores"


# #kokkos
# rm ${kk%%install} -rf
# rm kokkos -rf
# git clone -b 4.2.00 https://github.com/kokkos/kokkos.git
# cmake -S kokkos -B ${kk%%install} \
# -DCMAKE_INSTALL_PREFIX=$kk \
# -DCMAKE_BUILD_TYPE="Release" \
# -DCMAKE_CXX_COMPILER=$root/kokkos/bin/nvcc_wrapper \
# -DKokkos_ARCH_AMPERE80=ON \
# -DKokkos_ENABLE_SERIAL=ON \
# -DKokkos_ENABLE_OPENMP=off \
# -DKokkos_ENABLE_CUDA=on \
# -DKokkos_ENABLE_CUDA_LAMBDA=on \
# -DKokkos_ENABLE_DEBUG=off
# cmake --build ${kk%%install} -j 24 --target install

#omegah
rm ${oh%%install} -rf
rm omega_h -rf
git clone https://github.com/SCOREC/omega_h.git
cd omega_h && git checkout $branch && cd -
cmake -S omega_h -B ${oh%%install} \
-DCMAKE_INSTALL_PREFIX=$oh \
-DCMAKE_BUILD_TYPE=Release \
-DBUILD_SHARED_LIBS=off \
-DOmega_h_USE_Kokkos=ON \
-DOmega_h_USE_CUDA=on \
-DOmega_h_CUDA_ARCH=80 \
-DOmega_h_USE_MPI=on \
-DMPIEXEC_EXECUTABLE=srun \
-DBUILD_TESTING=on \
-DCMAKE_C_COMPILER=cc \
-DCMAKE_CXX_COMPILER=CC \
-DKokkos_PREFIX=$kk/lib64/cmake
cmake --build ${oh%%install} -j 24 --target install
16 changes: 16 additions & 0 deletions .github/workflows/perlmutter/run.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
#!/bin/bash

name=omega_h

cd $SCRATCH/globus-compute/$name-test

export root=$PWD
module load PrgEnv-gnu
module load cudatoolkit
module load cmake
export MPICH_CXX=$root/kokkos/bin/nvcc_wrapper
export SLURM_CPU_BIND="cores"

cd build-$name
salloc --time 00:20:00 --constrain=gpu --qos=interactive --nodes=1 --ntasks-per-node=40 --cpus-per-task=1 --gpus=1 --account=m4564 ctest
cat $PWD/Testing/Temporary/LastTest.log
63 changes: 0 additions & 63 deletions .github/workflows/systems.yml

This file was deleted.

38 changes: 0 additions & 38 deletions .github/workflows/test_on_system.py

This file was deleted.

2 changes: 1 addition & 1 deletion CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
cmake_minimum_required(VERSION 3.18.0...${CMAKE_VERSION})

project(Omega_h VERSION 10.8.6 LANGUAGES CXX)
project(Omega_h VERSION 10.8.7 LANGUAGES CXX)
set(Omega_h_USE_STK_DEFAULT OFF)
option(Omega_h_USE_STK "Whether to build the STK interface" ${Omega_h_USE_STK_DEFAULT})

Expand Down

0 comments on commit e46d4f5

Please sign in to comment.