From f235bf0b18f05a15637d749433e82a46d1885d2f Mon Sep 17 00:00:00 2001 From: Balthasar Reuter <6384870+reuterbal@users.noreply.github.com> Date: Thu, 5 Dec 2024 14:24:42 +0100 Subject: [PATCH 1/2] Add ci-hpc plan to Github Actions (#44) --- .github/workflows/build-hpc.yml | 138 ++++++++++++++++++++++++++++++++ 1 file changed, 138 insertions(+) create mode 100644 .github/workflows/build-hpc.yml diff --git a/.github/workflows/build-hpc.yml b/.github/workflows/build-hpc.yml new file mode 100644 index 00000000..721360d4 --- /dev/null +++ b/.github/workflows/build-hpc.yml @@ -0,0 +1,138 @@ +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: ~ + +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 + + strategy: + fail-fast: false # false: try to complete all jobs + + matrix: + name: + - ac-gpu nvhpc 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 + + 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: | + modules: + - cmake + - fcm + - ninja + - ecbuild + - prgenv/nvidia + - hpcx-openmpi/2.14.0-cuda + - python3 + cmake_options: + - -DENABLE_MPI=ON + - -DENABLE_LOKI=ON + - -DENABLE_ACC=ON + - -DENABLE_CUDA=ON + - -DENABLE_GPU_AWARE_MPI=ON + - -DENABLE_SINGLE_PRECISION=ON + dependencies: + ecmwf/eccodes: + version: develop + cmake_options: + - -DENABLE_MEMFS=ON + - -DENABLE_JPG=OFF + - -DENABLE_PNG=OFF + ecmwf/fckit: + version: 0.13.0 + cmake_options: + - -DENABLE_TESTS=OFF + - -DENABLE_FCKIT_VENV=ON + ecmwf-ifs/fiat: + version: 1.4.1 + cmake_options: + - -DENABLE_MPI=ON + - -DENABLE_SINGLE_PRECISION=ON + - -DENABLE_DOUBLE_PRECISION=OFF + ecmwf-ifs/field_api: + version: v0.3.1 + cmake_options: + - -DENABLE_TESTS=OFF + - -DENABLE_ACC=ON + - -DENABLE_CUDA=ON + - -DENABLE_SINGLE_PRECISION=ON + - -DENABLE_DOUBLE_PRECISION=OFF + ecmwf-ifs/loki: + version: v0.2.9 + cmake_options: + - -DENABLE_TESTS=OFF + template: | + {% for module in modules %} + 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 %} + + mkdir -p ${{ github.repository }} + pushd ${{ github.repository }} + git init + git remote add origin ${{ github.server_url }}/${{ github.repository }} + git fetch origin ${{ github.sha }} + git reset --hard FETCH_HEAD + popd + + cmake -G Ninja -S ${{ github.repository }} -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 From c0ac31f3746752e7005b858f3bb2c1960443b43a Mon Sep 17 00:00:00 2001 From: Ahmad Nawab Date: Sun, 8 Dec 2024 14:13:48 +0000 Subject: [PATCH 2/2] WAVEMDL: fix bounds checking bug --- src/ecwam/wavemdl.F90 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/ecwam/wavemdl.F90 b/src/ecwam/wavemdl.F90 index 514dfef9..8b282623 100644 --- a/src/ecwam/wavemdl.F90 +++ b/src/ecwam/wavemdl.F90 @@ -954,7 +954,7 @@ SUBROUTINE WAVEMDL (CBEGDAT, PSTEP, KSTOP, KSTPW, & ALLOCATE(ZCOMCNT(NPROC)) ZCOMCNT=NCOMLOC CALL MPL_GATHERV(PSENDBUF=ZCOMBUFS(IST:IED),KROOT=IRECV, & - & PRECVBUF=ZCOMBUFR(:),KRECVCOUNTS=ZCOMCNT, & + & PRECVBUF=ZCOMBUFR,KRECVCOUNTS=ZCOMCNT, & & CDSTRING='WAVEMDL:') DEALLOCATE(ZCOMCNT)