Feature: Add basic NCCL communication space backend #321
Workflow file for this run
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Linux-Install | |
# only run most recent workflow in branch | |
concurrency: | |
group: ${{ github.workflow }}-${{ github.ref }} | |
cancel-in-progress: true | |
on: | |
pull_request: | |
paths-ignore: | |
- README.md | |
- 'docs/**' | |
types: [ opened, reopened, synchronize ] | |
jobs: | |
Kokkos-master-OpenMPI: | |
env: | |
KOKKOS_SRC: ${{ github.workspace }}/_deps/kokkos | |
KOKKOS_BUILD: ${{ github.workspace }}/_deps/kokkos-build | |
KOKKOS_INSTALL: ${{ github.workspace }}/_deps/kokkos-install | |
COMM_SRC: ${{ github.workspace }} | |
COMM_BUILD: ${{ github.workspace }}/build | |
COMM_INSTALL: ${{ github.workspace }}/install | |
COMM_UNIT_TESTS_BUILD: ${{ github.workspace }}/unit-tests-build | |
COMM_PERF_TESTS_BUILD: ${{ github.workspace }}/perf-tests-build | |
runs-on: ubuntu-latest | |
timeout-minutes: 10 | |
steps: | |
- name: Install MPI | |
run: | | |
sudo apt-get update && sudo apt-get install -y libopenmpi-dev openmpi-bin cmake | |
which mpirun | |
mpirun --version | |
which mpicxx | |
mpicxx --version | |
- name: Check out repository code | |
uses: actions/checkout@v4 | |
- name: List files in the repository | |
run: ls ${{ github.workspace }} | |
- name: Build Kokkos | |
run: | | |
git clone https://github.com/kokkos/kokkos.git --branch master --depth 1 "$KOKKOS_SRC" | |
cmake -S "$KOKKOS_SRC" -B "$KOKKOS_BUILD" -DCMAKE_INSTALL_PREFIX="$KOKKOS_INSTALL" -DCMAKE_BUILD_TYPE=RelWithDebInfo -DKokkos_ENABLE_SERIAL=ON -DKokkos_ENABLE_OPENMP=ON | |
cmake --build "$KOKKOS_BUILD" --parallel $(nproc) -t install | |
- name: Configure KokkosComm | |
run: | | |
cmake -S "$COMM_SRC" -B "$COMM_BUILD" -DKokkos_ROOT="$KOKKOS_INSTALL" -DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_INSTALL_PREFIX="$COMM_INSTALL" | |
- name: Build and Install KokkosComm | |
run: | | |
VERBOSE=1 cmake --build "$COMM_BUILD" --target install | |
- name: Remove remnants of KokkosComm build | |
run: | | |
rm -rf $"COMM_BUILD" | |
- name: Configure KokkosComm Unit Tests against Installed | |
run: | | |
cmake -S "$COMM_SRC"/unit_tests -B "$COMM_UNIT_TESTS_BUILD" -DKokkos_ROOT="$KOKKOS_INSTALL" -DKokkosComm_ROOT="$COMM_INSTALL" -DCMAKE_BUILD_TYPE=RelWithDebInfo | |
- name: Build KokkosComm Unit Tests | |
run: | | |
VERBOSE=1 cmake --build "$COMM_UNIT_TESTS_BUILD" | |
- name: Run KokkosComm Unit Tests against Install | |
run: | | |
ctest -V --test-dir "$COMM_UNIT_TESTS_BUILD" | |
- name: Configure KokkosComm Perf Tests against Installed | |
run: | | |
cmake -S "$COMM_SRC"/perf_tests -B "$COMM_PERF_TESTS_BUILD" -DKokkos_ROOT="$KOKKOS_INSTALL" -DKokkosComm_ROOT="$COMM_INSTALL" -DCMAKE_BUILD_TYPE=RelWithDebInfo | |
- name: Build KokkosComm Perf Tests | |
run: | | |
VERBOSE=1 cmake --build "$COMM_PERF_TESTS_BUILD" | |
- name: Run KokkosComm Perf Tests against Install | |
run: | | |
ctest -V --test-dir "$COMM_PERF_TESTS_BUILD" |