Avoid global field during allocation #187
Workflow file for this run
This file contains hidden or 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: build-hpc | |
# Controls when the action will run | |
on: | |
# Trigger the workflow on all pull requests | |
pull_request: ~ | |
# Allow workflow to be dispatched on demand | |
workflow_dispatch: ~ | |
# Trigger after public PR approved for CI | |
pull_request_target: | |
types: [labeled] | |
env: | |
ECWAM_TOOLS: ${{ github.workspace }}/.github/tools | |
CTEST_PARALLEL_LEVEL: 1 | |
CACHE_SUFFIX: v1 # Increase to force new cache to be created | |
jobs: | |
ci-hpc: | |
name: ci-hpc | |
if: ${{ !github.event.pull_request.head.repo.fork && github.event.action != 'labeled' || github.event.label.name == 'approved-for-ci' }} | |
strategy: | |
fail-fast: false # false: try to complete all jobs | |
matrix: | |
name: | |
- ac-gpu nvhpc sp | |
- ac-cpu intel sp | |
include: | |
- name: ac-gpu nvhpc sp | |
site: ac-batch | |
sbatch_options: | | |
#SBATCH --time=00:20:00 | |
#SBATCH --nodes=1 | |
#SBATCH --ntasks=4 | |
#SBATCH --cpus-per-task=32 | |
#SBATCH --gpus-per-task=1 | |
#SBATCH --mem=0 | |
#SBATCH --qos=dg | |
modules: | |
- cmake | |
- fcm | |
- ninja | |
- ecbuild | |
- prgenv/nvidia | |
- nvidia/22.11 | |
- hpcx-openmpi/2.14.0-cuda | |
- python3/3.11.10-01 | |
gpu: 1 | |
- name: ac-cpu intel sp | |
site: ac-batch | |
sbatch_options: | | |
#SBATCH --time=00:20:00 | |
#SBATCH --nodes=1 | |
#SBATCH --ntasks=4 | |
#SBATCH --cpus-per-task=32 | |
#SBATCH --hint=nomultithread | |
#SBATCH --mem=60GB | |
#SBATCH --qos=np | |
modules: | |
- cmake | |
- fcm | |
- ninja | |
- ecbuild | |
- prgenv/intel | |
- intel/2021.4.0 | |
- hpcx-openmpi/2.9.0 | |
- python3 | |
gpu: 0 | |
runs-on: [self-hosted, linux, hpc] | |
env: | |
GH_TOKEN: ${{ github.token }} | |
steps: | |
- uses: ecmwf-actions/reusable-workflows/ci-hpc-generic@v2 | |
with: | |
site: ${{ matrix.site }} | |
troika_user: ${{ secrets.HPC_CI_SSH_USER }} | |
sbatch_options: ${{ matrix.sbatch_options }} | |
template_data: | | |
cmake_options: | |
- -DENABLE_MPI=ON | |
- -DENABLE_LOKI=${{ matrix.gpu }} | |
- -DENABLE_ACC=${{ matrix.gpu }} | |
- -DENABLE_CUDA=${{ matrix.gpu }} | |
- -DENABLE_GPU_AWARE_MPI=${{ matrix.gpu }} | |
- -DENABLE_SINGLE_PRECISION=ON | |
- -DENABLE_DOUBLE_PRECISION=OFF | |
- -DBUILD_SHARED_LIBS=${{ !matrix.gpu }} | |
dependencies: | |
ecmwf/eccodes: | |
version: 2.44.0 | |
cmake_options: | |
- -DENABLE_MEMFS=ON | |
- -DENABLE_JPG=OFF | |
- -DENABLE_PNG=OFF | |
- -DBUILD_SHARED_LIBS=${{ !matrix.gpu }} | |
ecmwf/fckit: | |
version: 0.13.0 | |
cmake_options: | |
- -DENABLE_TESTS=OFF | |
- -DENABLE_FCKIT_VENV=ON | |
- -DBUILD_SHARED_LIBS=${{ !matrix.gpu }} | |
ecmwf-ifs/fiat: | |
version: 1.5.1 | |
cmake_options: | |
- -DENABLE_MPI=ON | |
- -DENABLE_SINGLE_PRECISION=ON | |
- -DENABLE_DOUBLE_PRECISION=OFF | |
- -DBUILD_SHARED_LIBS=${{ !matrix.gpu }} | |
- -DENABLE_DR_HOOK_NVTX=OFF | |
ecmwf-ifs/field_api: | |
version: v0.3.4 | |
cmake_options: | |
- -DENABLE_TESTS=OFF | |
- -DENABLE_ACC=${{ matrix.gpu }} | |
- -DENABLE_CUDA=${{ matrix.gpu }} | |
- -DENABLE_SINGLE_PRECISION=ON | |
- -DENABLE_DOUBLE_PRECISION=OFF | |
- -DBUILD_SHARED_LIBS=${{ !matrix.gpu }} | |
ecmwf-ifs/loki: | |
version: 0.3.2 | |
cmake_options: | |
- -DENABLE_NO_INSTALL=${{ !matrix.gpu }} | |
- -DENABLE_TESTS=OFF | |
template: | | |
{% for module in "${{ join(matrix.modules, ',') }}".split(',') %} | |
module load {{module}} | |
{% endfor %} | |
BASEDIR=$PWD | |
{% for name, options in dependencies.items() %} | |
mkdir -p {{name}} | |
pushd {{name}} | |
git init | |
git remote add origin ${{ github.server_url }}/{{name}} | |
git fetch origin {{options['version']}} | |
git reset --hard FETCH_HEAD | |
cmake -G Ninja -S . -B build \ | |
{% for name in dependencies %} | |
{% set org, proj = name.split('/') %} | |
-D{{proj}}_ROOT=$BASEDIR/{{name}}/installation \ | |
{% endfor %} | |
{{ options['cmake_options']|join(' ') }} | |
cmake --build build | |
cmake --install build --prefix installation | |
popd | |
{% endfor %} | |
REPO=${{ github.event.pull_request.head.repo.full_name || github.repository }} | |
SHA=${{ github.event.pull_request.head.sha || github.sha }} | |
mkdir -p $REPO | |
pushd $REPO | |
git init | |
git remote add origin ${{ github.server_url }}/$REPO | |
git fetch origin $SHA | |
git reset --hard FETCH_HEAD | |
popd | |
cmake -G Ninja -S $REPO -B build \ | |
{% for name in dependencies %} | |
{% set org, proj = name.split('/') %} | |
-D{{proj}}_ROOT=$BASEDIR/{{name}}/installation \ | |
{% endfor %} | |
{{ cmake_options|join(' ') }} | |
cmake --build build | |
ctest --test-dir build |