From b98fe3c4c0ae92e9f339af6d2f319a4fa10a2c9b Mon Sep 17 00:00:00 2001 From: aurianer Date: Wed, 15 Nov 2023 22:55:14 +0100 Subject: [PATCH] Add a pipeline with cuda12 --- .gitlab/includes/gcc12_cuda12_pipeline.yml | 74 ++++++++++++++++++++++ .gitlab/pipeline.yml | 1 + 2 files changed, 75 insertions(+) create mode 100644 .gitlab/includes/gcc12_cuda12_pipeline.yml diff --git a/.gitlab/includes/gcc12_cuda12_pipeline.yml b/.gitlab/includes/gcc12_cuda12_pipeline.yml new file mode 100644 index 000000000..6cf35755e --- /dev/null +++ b/.gitlab/includes/gcc12_cuda12_pipeline.yml @@ -0,0 +1,74 @@ +# Copyright (c) 2023 ETH Zurich +# +# SPDX-License-Identifier: BSL-1.0 +# Distributed under the Boost Software License, Version 1.0. (See accompanying +# file BOOST_LICENSE_1_0.rst or copy at http://www.boost.org/LICENSE_1_0.txt) + +include: + - local: '.gitlab/includes/common_pipeline.yml' + - local: '.gitlab/includes/common_spack_pipeline.yml' + +.variables_gcc12_cuda12_config: + variables: + ARCH: linux-ubuntu22.04-zen3 + BUILD_TYPE: Debug + COMPILER: gcc@12.1.0 + CXXSTD: 17 + SPACK_SPEC: "pika@main arch=$ARCH %${COMPILER} +cuda malloc=system cxxstd=$CXXSTD \ + ^boost@1.82.0 ^hwloc@2.9.1 ^cuda@12.0.0 ^fmt@10.0.0" + +gcc12_cuda12_spack_image: + stage: spack_configs + needs: [base_spack_image] + extends: + - .container-builder + - .variables_gcc12_cuda12_config + before_script: + - CONFIG_TAG=`echo $SPACK_SPEC-$SPACK_COMMIT | sha256sum - | head -c 16` + - compiler=${COMPILER/@/-} + - export PERSIST_IMAGE_NAME=$CSCS_REGISTRY_PATH/pika-$compiler:$CONFIG_TAG + - echo -e "compiler=$compiler\nBASE_IMAGE=$PERSIST_IMAGE_NAME" >> compiler.env + variables: + BASE_IMAGE: $CSCS_REGISTRY_PATH/pika-spack-base:$SPACK_COMMIT + DOCKERFILE: .gitlab/docker/Dockerfile.spack_compiler + DOCKER_BUILD_ARGS: '["BASE_IMAGE","ARCH","COMPILER","SPACK_SPEC"]' + artifacts: + reports: + dotenv: compiler.env + +gcc12_cuda12_debug_build: + stage: build + extends: + - .container-builder + - .variables_gcc12_cuda12_config + - .cmake_variables_common + needs: + - gcc12_cuda12_spack_image + before_script: + - build_type=`echo $BUILD_TYPE | tr '[:upper:]' '[:lower:]'` + - configuration=$CMAKE_COMMON_FLAGS-$CMAKE_FLAGS-$CI_COMMIT_SHORT_SHA + - configuration=${configuration//-D/} + - CONFIG_TAG=`echo $configuration | sha256sum - | head -c 16` + - export PERSIST_IMAGE_NAME=$CSCS_REGISTRY_PATH/pika-$compiler-$build_type-build:$CONFIG_TAG + - echo -e "PERSIST_IMAGE_NAME=$PERSIST_IMAGE_NAME" > build.env + variables: + DOCKERFILE: .gitlab/docker/Dockerfile.spack_build + CMAKE_FLAGS: "-DCMAKE_BUILD_TYPE=$BUILD_TYPE -DPIKA_WITH_CXX_STANDARD=$CXXSTD \ + -DPIKA_WITH_CUDA=ON -DPIKA_WITH_MALLOC=system \ + -DCMAKE_CUDA_ARCHITECTURE=60 -DPIKA_WITH_CXX_LAMBDA_CAPTURE_DECLTYPE=OFF" +# PIKA_WITH_CXX_LAMBDA_CAPTURE_DECLTYPE is OFF to test the fallback implementation of PIKA_FORWARD. + DOCKER_BUILD_ARGS: '["BASE_IMAGE","SOURCE_DIR","BUILD_DIR","CMAKE_COMMON_FLAGS","CMAKE_FLAGS"]' + artifacts: + reports: + dotenv: build.env + +gcc12_cuda12_debug_test: + extends: + - .variables_gcc12_cuda12_config + - .test_common_gpu_clariden_cuda + needs: + - gcc12_cuda12_debug_build + script: + - spack arch + - spack build-env $spack_spec -- bash -c "ctest --label-exclude COMPILE_ONLY --test-dir ${BUILD_DIR} -j$(nproc) --timeout 120 --output-on-failure --no-compress-output --no-tests=error" + image: $PERSIST_IMAGE_NAME diff --git a/.gitlab/pipeline.yml b/.gitlab/pipeline.yml index ab844d3c0..0891e1422 100644 --- a/.gitlab/pipeline.yml +++ b/.gitlab/pipeline.yml @@ -9,6 +9,7 @@ include: - local: '.gitlab/includes/gcc9_pipeline.yml' - local: '.gitlab/includes/gcc11_pipeline.yml' - local: '.gitlab/includes/gcc12_pipeline.yml' + - local: '.gitlab/includes/gcc12_cuda12_pipeline.yml' - local: '.gitlab/includes/gcc13_pipeline.yml' - local: '.gitlab/includes/clang11_pipeline.yml' - local: '.gitlab/includes/clang12_pipeline.yml'