1stages: 2 - test 3 4noether-rocm: 5 stage: test 6 tags: 7 - rocm 8 interruptible: true 9 script: 10 - rm -f .SUCCESS 11# Environment 12 - export COVERAGE=1 CC=gcc CXX=g++ FC=gfortran HIPCC=hipcc 13 - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=$(($(nproc)<8?$(nproc):8)) && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU 14 - echo "-------------- CC ------------------" && $CC --version 15 - echo "-------------- CXX -----------------" && $CXX --version 16 - echo "-------------- FC ------------------" && $FC --version 17 - echo "-------------- HIPCC ---------------" && $HIPCC --version 18 - echo "-------------- GCOV ----------------" && gcov --version 19# Libraries for backends 20# -- MAGMA from dev branch 21 - echo "-------------- MAGMA ---------------" 22 - export MAGMA_DIR=/projects/hipMAGMA && git -C $MAGMA_DIR describe 23# -- LIBXSMM v1.16.1 24 - cd .. && export XSMM_VERSION=libxsmm-1.16.1 && { [[ -d $XSMM_VERSION ]] || { git clone --depth 1 --branch 1.16.1 https://github.com/hfp/libxsmm.git $XSMM_VERSION && make -C $XSMM_VERSION -j$(nproc); }; } && export XSMM_DIR=$PWD/$XSMM_VERSION && cd libCEED 25 - echo "-------------- LIBXSMM -------------" && git -C $XSMM_DIR describe --tags 26# -- OCCA v1.1.0 27 - cd .. && export OCCA_VERSION=occa-1.1.0 OCCA_OPENCL_ENABLED=0 && { [[ -d $OCCA_VERSION ]] || { git clone --depth 1 --branch v1.1.0 https://github.com/libocca/occa.git $OCCA_VERSION && make -C $OCCA_VERSION -j$(nproc); }; } && export OCCA_DIR=$PWD/$OCCA_VERSION && cd libCEED 28 - echo "-------------- OCCA ----------------" && make -C $OCCA_DIR info 29# libCEED 30 - make configure HIP_DIR=/opt/rocm OPT='-O -march=native -ffp-contract=fast' 31# Note: OCCA backends currently disabled in CI 32 - BACKENDS_CPU=$(OCCA_DIR= make info-backends-all | grep -o '/cpu[^ ]*') && BACKENDS_GPU=$(OCCA_DIR= make info-backends | grep -o '/gpu[^ ]*') 33 - echo "-------------- libCEED -------------" && make info 34 - echo "-------------- BACKENDS_CPU --------" && echo $BACKENDS_CPU 35 - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU 36 - make -j$NPROC_CPU 37# Remove OCCA after verifying it compiles 38# CodeCov of OCCA backend not useful since testing is intentionally disabled 39 - export OCCA_DIR= && make -j$NPROC_CPU -W build/interface/ceed-register.o 40# -- libCEED only tests 41 - echo "-------------- core tests ----------" 42 - echo '[{"subject":"/","metrics":[{"name":"Transfer Size (KB)","value":"19.5","desiredSize":"smaller"},{"name":"Speed Index","value":0,"desiredSize":"smaller"},{"name":"Total Score","value":92,"desiredSize":"larger"},{"name":"Requests","value":4,"desiredSize":"smaller"}]}]' > performance.json 43# Note: PETSC_DIR is set by default in GitLab runner env, unsetting to isolate core tests 44 - export PETSC_DIR= PETSC_ARCH= 45 - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" junit realsearch=% 46 - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" junit realsearch=% 47# Libraries for examples 48# -- PETSc with HIP (minimal) 49 - export PETSC_DIR=/projects/petsc PETSC_ARCH=mpich-hip && git -C $PETSC_DIR describe 50 - echo "-------------- PETSc ---------------" && make -C $PETSC_DIR info 51 - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" junit search="petsc fluids solids" 52 - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" junit search="petsc fluids solids" 53# -- MFEM v4.2 54 - cd .. && export MFEM_VERSION=mfem-4.2 && { [[ -d $MFEM_VERSION ]] || { git clone --depth 1 --branch v4.2 https://github.com/mfem/mfem.git $MFEM_VERSION && make -C $MFEM_VERSION -j$(nproc) serial CXXFLAGS="-O -std=c++11"; }; } && export MFEM_DIR=$PWD/$MFEM_VERSION && cd libCEED 55 - echo "-------------- MFEM ----------------" && make -C $MFEM_DIR info 56 - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" junit search=mfem 57 - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" junit search=mfem 58# -- Nek5000 v19.0 59 - export COVERAGE=0 60 - cd .. && export NEK5K_VERSION=Nek5000-19.0 && { [[ -d $NEK5K_VERSION ]] || { git clone --depth 1 --branch v19.0 https://github.com/Nek5000/Nek5000.git $NEK5K_VERSION && cd $NEK5K_VERSION/tools && ./maketools genbox genmap reatore2 && cd ../..; }; } && export NEK5K_DIR=$PWD/$NEK5K_VERSION && export PATH=$NEK5K_DIR/bin:$PATH MPI=0 && cd libCEED 61 - echo "-------------- Nek5000 -------------" && git -C $NEK5K_DIR describe --tags 62 - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" junit search=nek 63 - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" junit search=nek 64# Clang-tidy 65 - echo "-------------- clang-tidy ----------" && clang-tidy --version 66 - TIDY_OPTS="-fix-errors" make -j$NPROC_CPU tidy && git diff --exit-code 67# Report status 68 - touch .SUCCESS 69 after_script: 70 - | 71 if [ -f .SUCCESS ]; then 72 lcov --directory . --capture --output-file coverage.info; 73 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface; 74 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery; 75 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends; 76 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests; 77 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples; 78 fi 79 artifacts: 80 paths: 81 - build/*.junit 82 reports: 83 junit: build/*.junit 84 performance: performance.json 85 86noether-float: 87 stage: test 88 tags: 89 - rocm 90 interruptible: true 91 script: 92# Environment 93 - export COVERAGE=1 CC=gcc CXX=g++ FC= HIPCC=hipcc 94 - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=$(($(nproc)<8?$(nproc):8)) && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU 95 - echo "-------------- CC ------------------" && $CC --version 96 - echo "-------------- CXX -----------------" && $CXX --version 97 - echo "-------------- HIPCC ---------------" && $HIPCC --version 98 - echo "-------------- GCOV ----------------" && gcov --version 99# Libraries for backends 100# -- MAGMA from dev branch 101 - echo "-------------- MAGMA ---------------" 102 - export MAGMA_DIR=/projects/hipMAGMA && git -C $MAGMA_DIR describe 103# -- LIBXSMM v1.16.1 104 - cd .. && export XSMM_VERSION=libxsmm-1.16.1 && { [[ -d $XSMM_VERSION ]] || { git clone --depth 1 --branch 1.16.1 https://github.com/hfp/libxsmm.git $XSMM_VERSION && make -C $XSMM_VERSION -j$(nproc); }; } && export XSMM_DIR=$PWD/$XSMM_VERSION && cd libCEED 105 - echo "-------------- LIBXSMM -------------" && git -C $XSMM_DIR describe --tags 106# libCEED 107# First change to single precision 108 - sed -i 's/ceed-f64/ceed-f32/1' include/ceed/ceed.h 109# Build libCEED 110 - make configure HIP_DIR=/opt/rocm OPT='-O -march=native -ffp-contract=fast' 111 - BACKENDS_CPU=$(make info-backends-all | grep -o '/cpu[^ ]*') && BACKENDS_GPU=$(make info-backends | grep -o '/gpu[^ ]*') 112 - echo "-------------- libCEED -------------" && make info 113 - echo "-------------- BACKENDS_CPU --------" && echo $BACKENDS_CPU 114 - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU 115 - make -j$NPROC_CPU 116# -- libCEED only tests 117 - echo "-------------- core tests ----------" 118 - echo '[{"subject":"/","metrics":[{"name":"Transfer Size (KB)","value":"19.5","desiredSize":"smaller"},{"name":"Speed Index","value":0,"desiredSize":"smaller"},{"name":"Total Score","value":92,"desiredSize":"larger"},{"name":"Requests","value":4,"desiredSize":"smaller"}]}]' > performance.json 119# Note: PETSC_DIR is set by default in GitLab runner env, unsetting to isolate core tests 120 - export PETSC_DIR= PETSC_ARCH= 121 - make -k -j$NPROC_CPU BACKENDS="$BACKENDS_CPU" junit realsearch=% 122 - make -k -j$NPROC_GPU BACKENDS="$BACKENDS_GPU" junit realsearch=% 123# Report status 124 - echo "SUCCESS" > .job_status 125 after_script: 126 - | 127 if [ $(cat .job_status) == "SUCCESS" ]; then 128 lcov --directory . --capture --output-file coverage.info; 129 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface; 130 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery; 131 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends; 132 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests; 133 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples; 134 fi 135 - sed -i 's/ceed-f32/ceed-f64/1' include/ceed/ceed.h 136 artifacts: 137 paths: 138 - build/*.junit 139 reports: 140 junit: build/*.junit 141 performance: performance.json 142 143lv-cuda: 144 stage: test 145 tags: 146 - cuda 147 interruptible: true 148 before_script: 149# Environment 150 - ulimit -v $[1024*1024*32] # 32 GiB in units of 1024 bytes 151 - . /opt/rh/gcc-toolset-10/enable 152 - export COVERAGE=1 CC=gcc CXX=g++ FC=gfortran 153 - export CUDA_DIR=/usr/local/cuda-11.4 154 - export CUDA_VISIBLE_DEVICES=GPU-c4529365-8229-f689-b43d-ccd7f1677079 # our RTX 2080 Super via nvidia-smi -L 155 - echo "-------------- nproc ---------------" && NPROC_CPU=$(nproc) && NPROC_GPU=1 && echo "NPROC_CPU" $NPROC_CPU && echo "NPROC_GPU" $NPROC_GPU 156 - echo "-------------- CC ------------------" && $CC --version 157 - echo "-------------- CXX -----------------" && $CXX --version 158 - echo "-------------- FC ------------------" && $FC --version 159 - echo "-------------- NVCC ----------------" && $CUDA_DIR/bin/nvcc --version 160# libCEED 161 - make configure OPT='-O -march=native -ffp-contract=fast' 162 - echo "-------------- libCEED -------------" && make info 163 - BACKENDS_GPU=$(make info-backends | grep -o '/gpu[^ ]*') 164 - echo "-------------- BACKENDS_GPU --------" && echo $BACKENDS_GPU 165 - export PETSC_DIR=/home/jeth8984/petsc PETSC_ARCH=cuda-O && git -C $PETSC_DIR describe 166 script: 167 - rm -f .SUCCESS 168 - nice make -k -j$NPROC_CPU -l$NPROC_CPU 169 - echo "-------------- quick CPU tests to get everything built (no junit) --------------" 170 - nice make -k -j$NPROC_CPU -l$NPROC_CPU test BACKENDS=/cpu/self/avx/blocked realsearch=% 171 - echo "-------------- CUDA tests without PETSc (makes *.junit) --------------" 172 - nice make -k -j$NPROC_GPU junit PETSC_DIR= BACKENDS="$BACKENDS_GPU" realsearch=% 173 - echo "-------------- CUDA tests with PETSc (makes *.junit) --------------" 174# skip fluids and solids due to CUDA_ERROR_LAUNCH_OUT_OF_RESOURCES on RTX 2080 Super 175 - nice make -k -j$NPROC_GPU junit BACKENDS="$BACKENDS_GPU" search="petsc" 176# Report status 177 - touch .SUCCESS 178 after_script: 179 - | 180 if [ -f .SUCCESS ]; then 181 lcov --directory . --capture --output-file coverage.info; 182 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F interface; 183 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F gallery; 184 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F backends; 185 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F tests; 186 bash <(curl -s https://codecov.io/bash) -f coverage.info -t ${CODECOV_ACCESS_TOKEN} -F examples; 187 fi 188 artifacts: 189 paths: 190 - build/*.junit 191 reports: 192 junit: build/*.junit 193