X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=.gitlab-ci.yml;h=50b7f9ef896eed5996d90af81f3b854ea1f5c65a;hb=01443dc7383f4634e4a66fa194ed51db74186128;hp=a8a16f6c1fb505bbb8a9b6098de55fe8088721da;hpb=dd3d0b2897b8e7874a6b1958e1c097150c5b2996;p=mesa.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index a8a16f6c1fb..50b7f9ef896 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,87 @@ -# This is the tag of the docker image used for the build jobs. If the -# image doesn't exist yet, the containers-build stage generates it. +variables: + UPSTREAM_REPO: mesa/mesa + +include: + - project: 'wayland/ci-templates' + ref: b7030c2cd0d6ccc5f6d4f8299bafa4daa9240d71 + file: '/templates/debian.yml' + - local: '.gitlab-ci/lava-gitlab-ci.yml' + +stages: + - container + - build + - test + - success + + +# When to automatically run the CI +.ci-run-policy: + rules: + # Run pipeline by default for merge requests changing files affecting it + - if: '$CI_MERGE_REQUEST_SOURCE_BRANCH_NAME == $CI_COMMIT_REF_NAME' + changes: &paths + - VERSION + - bin/**/* + # GitLab CI + - .gitlab-ci.yml + - .gitlab-ci/**/* + # Meson + - meson* + - build-support/**/* + - subprojects/**/* + # SCons + - SConstruct + - scons/**/* + - common.py + # Source code + - include/**/* + - src/**/* + when: on_success + # Run pipeline by default in the main project if files affecting it were + # changed + - if: '$CI_PROJECT_PATH == "mesa/mesa"' + changes: + *paths + when: on_success + # Allow triggering jobs manually on branches of forked projects + - if: '$CI_PROJECT_PATH != "mesa/mesa" && $CI_MERGE_REQUEST_SOURCE_BRANCH_NAME != $CI_COMMIT_REF_NAME' + when: manual + # Otherwise, most jobs won't run + - when: never + retry: + max: 2 + when: + - runner_system_failure + # Cancel CI run if a newer commit is pushed to the same branch + interruptible: true + +success: + stage: success + image: debian:stable-slim + only: + - merge_requests + except: + changes: + *paths + variables: + GIT_STRATEGY: none + script: + - echo "Dummy job to make sure every merge request pipeline runs at least one job" + + +.ci-deqp-artifacts: + artifacts: + when: always + untracked: false + paths: + # Watch out! Artifacts are relative to the build dir. + # https://gitlab.com/gitlab-org/gitlab-ce/commit/8788fb925706cad594adf6917a6c5f6587dd1521 + - artifacts + +# Build the CI docker images. +# +# DEBIAN_TAG is the tag of the docker image used by later stage jobs. If the +# image doesn't exist yet, the container stage job generates it. # # In order to generate a new image, one should generally change the tag. # While removing the image from the registry would also work, that's not @@ -12,133 +94,278 @@ # main repository, it's recommended to remove the image from the source # repository's container registry, so that the image from the main # repository's registry will be used there as well. -variables: - UPSTREAM_REPO: mesa/mesa - DEBIAN_TAG: "2019-07-11" - DEBIAN_VERSION: stretch-slim - DEBIAN_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_VERSION:$DEBIAN_TAG" -include: - - project: 'wayland/ci-templates' - ref: c73dae8b84697ef18e2dbbf4fed7386d9652b0cd - file: '/templates/debian.yml' +.container: + stage: container + extends: + - .ci-run-policy + variables: + DEBIAN_VERSION: buster-slim + REPO_SUFFIX: $CI_JOB_NAME + DEBIAN_EXEC: 'bash .gitlab-ci/container/${CI_JOB_NAME}.sh' + # no need to pull the whole repo to build the container image + GIT_STRATEGY: none -stages: - - containers-build - - build+test +# Debian 10 based x86 build image +x86_build: + extends: + - .debian@container-ifnot-exists + - .container + variables: + DEBIAN_TAG: &x86_build "2020-02-05" +.use-x86_build: + variables: + TAG: *x86_build + image: "$CI_REGISTRY_IMAGE/debian/x86_build:$TAG" + needs: + - x86_build -# When to automatically run the CI -.ci-run-policy: &ci-run-policy - only: - - branches@mesa/mesa - - merge_requests - - /^ci([-/].*)?$/ - retry: - max: 2 - when: - - runner_system_failure +# Debian 10 based x86 test image for GL +x86_test-gl: + extends: x86_build + variables: + DEBIAN_TAG: &x86_test-gl "2020-01-30" + +# Debian 10 based x86 test image for VK +x86_test-vk: + extends: x86_build + variables: + DEBIAN_TAG: &x86_test-vk "2020-01-14" + # Can only be triggered manually on personal branches because RADV is the only + # driver that does Vulkan testing at the moment. + rules: + # Never build the test image for VK by default in the main project. + - if: '$CI_PROJECT_PATH == "mesa/mesa"' + when: never + # Never build the test image for VK by default for merge requests. + - if: '$CI_MERGE_REQUEST_SOURCE_BRANCH_NAME == $CI_COMMIT_REF_NAME' + when: never + # Otherwise, allow building it manually for personal branches. + - when: manual -# CONTAINERS +# Debian 9 based x86 build image (old LLVM) +x86_build_old: + extends: x86_build + variables: + DEBIAN_TAG: &x86_build_old "2019-09-18" + DEBIAN_VERSION: stretch-slim + +.use-x86_build_old: + variables: + TAG: *x86_build_old + image: "$CI_REGISTRY_IMAGE/debian/x86_build_old:$TAG" + needs: + - x86_build_old -debian: - extends: .debian@container-ifnot-exists - stage: containers-build - <<: *ci-run-policy +# Debian 10 based ARM build image +arm_build: + extends: + - .debian@container-ifnot-exists@arm64v8 + - .container variables: - GIT_STRATEGY: none # no need to pull the whole tree for rebuilding the image - DEBIAN_EXEC: 'bash .gitlab-ci/debian-install.sh' + DEBIAN_TAG: &arm_build "2020-02-05" + +.use-arm_build: + variables: + TAG: *arm_build + image: "$CI_REGISTRY_IMAGE/debian/arm_build:$TAG" + needs: + - arm_build + +# Debian 10 based ARM test image +arm_test: + extends: arm_build + variables: + DEBIAN_TAG: &arm_test "2020-01-30" + +.use-arm_test: + variables: + TAG: *arm_test + image: "$CI_REGISTRY_IMAGE/debian/arm_test:$TAG" + needs: + - meson-arm64 + - arm_test # BUILD -.build: - <<: *ci-run-policy - image: $DEBIAN_IMAGE - stage: build+test - cache: - paths: - - ccache +# Shared between windows and Linux +.build-common: + extends: .ci-run-policy + stage: build artifacts: when: always paths: - _build/meson-logs/*.txt # scons: - - _build/*/config.log + - build/*/config.log + - shader-db + +# Just Linux +.build-linux: + extends: .build-common variables: CCACHE_COMPILERCHECK: "content" + CCACHE_COMPRESS: "true" + CCACHE_DIR: /cache/mesa/ccache # Use ccache transparently, and print stats before/after before_script: - export PATH="/usr/lib/ccache:$PATH" - export CCACHE_BASEDIR="$PWD" - - export CCACHE_DIR="$PWD/ccache" - - ccache --zero-stats || true - - ccache --show-stats || true + - ccache --show-stats after_script: - - export CCACHE_DIR="$PWD/ccache" - ccache --show-stats +.build-windows: + extends: .build-common + tags: + - mesa-windows + cache: + key: ${CI_JOB_NAME} + paths: + - subprojects/packagecache + .meson-build: - extends: .build + extends: + - .build-linux + - .use-x86_build + variables: + LLVM_VERSION: 9 script: - .gitlab-ci/meson-build.sh .scons-build: - extends: .build + extends: + - .build-linux + - .use-x86_build variables: SCONSFLAGS: "-j4" script: - - if test -n "$LLVM_VERSION"; then - export LLVM_CONFIG="llvm-config-${LLVM_VERSION}"; - fi - - scons $SCONS_TARGET - - eval $SCONS_CHECK_COMMAND - -# NOTE: Building SWR is 2x (yes two) times slower than all the other -# gallium drivers combined. -# Start this early so that it doesn't limit the total run time. -# -# We also put softpipe (and therefore gallium nine, which requires -# it) here, since softpipe/llvmpipe can't be built alongside classic -# swrast. -# -# Putting glvnd here is arbitrary, but we want it in one of the builds -# for coverage. -meson-swr-glvnd: + - .gitlab-ci/scons-build.sh + +meson-testing: + extends: + - .meson-build + - .ci-deqp-artifacts + variables: + UNWIND: "true" + DRI_LOADERS: > + -D glx=dri + -D gbm=true + -D egl=true + -D platforms=x11,drm,surfaceless + GALLIUM_ST: > + -D dri3=true + GALLIUM_DRIVERS: "swrast" + VULKAN_DRIVERS: amd + BUILDTYPE: "debugoptimized" + script: + - .gitlab-ci/meson-build.sh + - .gitlab-ci/prepare-artifacts.sh + +meson-main: extends: .meson-build variables: UNWIND: "true" DRI_LOADERS: > - -D glvnd=true + -D glx=dri + -D gbm=true -D egl=true + -D platforms=x11,wayland,drm,surfaceless + DRI_DRIVERS: "i915,i965,r100,r200,nouveau" GALLIUM_ST: > -D dri3=true + -D gallium-extra-hud=true + -D gallium-vdpau=true + -D gallium-xvmc=true + -D gallium-omx=bellagio + -D gallium-va=true + -D gallium-xa=true + -D gallium-nine=true + -D gallium-opencl=disabled + GALLIUM_DRIVERS: "iris,nouveau,kmsro,r300,r600,freedreno,swr,swrast,svga,v3d,vc4,virgl,etnaviv,panfrost,lima,zink" + EXTRA_OPTION: > + -D osmesa=gallium + -D tools=all + script: + - .gitlab-ci/meson-build.sh + - .gitlab-ci/run-shader-db.sh + +.meson-cross: + extends: + - .meson-build + variables: + UNWIND: "false" + DRI_LOADERS: > + -D glx=disabled + -D gbm=false + -D egl=true + -D platforms=surfaceless + -D osmesa=none + GALLIUM_ST: > + -D dri3=false -D gallium-vdpau=false -D gallium-xvmc=false -D gallium-omx=disabled -D gallium-va=false -D gallium-xa=false - -D gallium-nine=true - -D gallium-opencl=disabled - -D osmesa=gallium - GALLIUM_DRIVERS: "swr,swrast,iris" - LLVM_VERSION: "6.0" + -D gallium-nine=false + LLVM_VERSION: "8" + +.meson-arm: + extends: + - .meson-cross + - .use-arm_build + variables: + VULKAN_DRIVERS: freedreno + GALLIUM_DRIVERS: "etnaviv,freedreno,kmsro,lima,nouveau,panfrost,swrast,tegra,v3d,vc4" + BUILDTYPE: "debugoptimized" + tags: + - aarch64 + +meson-armhf: + extends: + - .meson-arm + - .ci-deqp-artifacts + variables: + CROSS: armhf + LLVM_VERSION: "7" + script: + - .gitlab-ci/meson-build.sh + - .gitlab-ci/prepare-artifacts.sh + +meson-arm64: + extends: + - .meson-arm + - .ci-deqp-artifacts + variables: + VULKAN_DRIVERS: "freedreno,amd" + script: + - .gitlab-ci/meson-build.sh + - .gitlab-ci/prepare-artifacts.sh meson-clang: extends: .meson-build variables: UNWIND: "true" + DRI_LOADERS: > + -D glvnd=true DRI_DRIVERS: "auto" GALLIUM_DRIVERS: "auto" VULKAN_DRIVERS: intel,amd,freedreno - CC: "ccache clang-8" - CXX: "ccache clang++-8" + CC: "ccache clang-9" + CXX: "ccache clang++-9" + +.meson-windows: + extends: + - .build-windows before_script: - - export CCACHE_BASEDIR="$PWD" CCACHE_DIR="$PWD/ccache" - - ccache --zero-stats --show-stats || true - # clang++ breaks if it picks up the GCC 8 directory without libstdc++.so - - apt-get remove -y libgcc-8-dev + - $ENV:ARCH = "x86" + - $ENV:VERSION = "2019\Community" + script: + - cmd /C .gitlab-ci\meson-build.bat scons-swr: extends: .scons-build @@ -153,32 +380,6 @@ scons-win64: SCONS_TARGET: platform=windows machine=x86_64 SCONS_CHECK_COMMAND: "true" -meson-main: - extends: .meson-build - variables: - UNWIND: "true" - DRI_LOADERS: > - -D glx=dri - -D gbm=true - -D egl=true - -D platforms=x11,wayland,drm,surfaceless - -D osmesa=classic - DRI_DRIVERS: "i915,i965,r100,r200,swrast,nouveau" - GALLIUM_ST: > - -D dri3=true - -D gallium-extra-hud=true - -D gallium-vdpau=true - -D gallium-xvmc=true - -D gallium-omx=bellagio - -D gallium-va=true - -D gallium-xa=true - -D gallium-nine=false - -D gallium-opencl=disabled - GALLIUM_DRIVERS: "iris,nouveau,kmsro,r300,r600,freedreno,svga,v3d,vc4,virgl,etnaviv,panfrost,lima" - LLVM_VERSION: "7" - EXTRA_OPTION: > - -D tools=all - meson-clover: extends: .meson-build variables: @@ -199,12 +400,27 @@ meson-clover: script: - export GALLIUM_DRIVERS="r600,radeonsi" - .gitlab-ci/meson-build.sh - - LLVM_VERSION=7 .gitlab-ci/meson-build.sh + - LLVM_VERSION=8 .gitlab-ci/meson-build.sh - export GALLIUM_DRIVERS="i915,r600" + - LLVM_VERSION=6.0 .gitlab-ci/meson-build.sh + - LLVM_VERSION=7 .gitlab-ci/meson-build.sh + +meson-clover-old-llvm: + extends: + - meson-clover + - .use-x86_build_old + variables: + UNWIND: "false" + DRI_LOADERS: > + -D glx=disabled + -D egl=false + -D gbm=false + -D platforms=drm,surfaceless + GALLIUM_DRIVERS: "i915,r600" + script: - LLVM_VERSION=3.9 .gitlab-ci/meson-build.sh - LLVM_VERSION=4.0 .gitlab-ci/meson-build.sh - LLVM_VERSION=5.0 .gitlab-ci/meson-build.sh - - LLVM_VERSION=6.0 .gitlab-ci/meson-build.sh meson-vulkan: extends: .meson-build @@ -225,86 +441,267 @@ meson-vulkan: -D gallium-xa=false -D gallium-nine=false -D gallium-opencl=disabled + -D b_sanitize=undefined + -D c_args=-fno-sanitize-recover=all + -D cpp_args=-fno-sanitize-recover=all + UBSAN_OPTIONS: "print_stacktrace=1" VULKAN_DRIVERS: intel,amd,freedreno - LLVM_VERSION: "7" EXTRA_OPTION: > -D vulkan-overlay-layer=true -.meson-cross: - extends: .meson-build +# While the main point of this build is testing the i386 cross build, +# we also use this one to test some other options that are exclusive +# with meson-main's choices (classic swrast and osmesa) +meson-i386: + extends: .meson-cross variables: - UNWIND: "false" - DRI_LOADERS: > - -D glx=disabled - -D gbm=false - -D egl=false - -D platforms=surfaceless - -D osmesa=none - GALLIUM_ST: > - -D dri3=false - -D gallium-vdpau=false - -D gallium-xvmc=false - -D gallium-omx=disabled - -D gallium-va=false - -D gallium-xa=false - -D gallium-nine=false + CROSS: i386 + VULKAN_DRIVERS: intel + DRI_DRIVERS: "swrast" + GALLIUM_DRIVERS: "iris" + EXTRA_OPTION: > + -D vulkan-overlay-layer=true -D llvm=false - CROSS: > - --cross /tmp/cross_file.txt + -D osmesa=classic + -D werror=true +meson-s390x: + extends: + - .meson-cross + variables: + CROSS: s390x + GALLIUM_DRIVERS: "swrast" + LLVM_VERSION: "7" script: - - /usr/share/meson/debcrossgen --arch ${ARCH} -o /tmp/cross_file.txt - # Work around a bug in debcrossgen that should be fixed in the next release - - sed -i "s|cpu_family = 'i686'|cpu_family = 'x86'|g" /tmp/cross_file.txt + - dpkg -i /var/cache/apt/archives/$CROSS/*.deb - .gitlab-ci/meson-build.sh -meson-armhf: - extends: .meson-cross +meson-ppc64el: + extends: + - meson-s390x variables: - ARCH: armhf - VULKAN_DRIVERS: freedreno - GALLIUM_DRIVERS: "etnaviv,freedreno,kmsro,lima,nouveau,panfrost,tegra,v3d,vc4" - # Disable the tests since we're cross compiling. - EXTRA_OPTION: > - -D build-tests=false - -D I-love-half-baked-turnips=true - -D vulkan-overlay-layer=true + CROSS: ppc64el + GALLIUM_DRIVERS: "nouveau,radeonsi,swrast,virgl" + LLVM_VERSION: "8" + VULKAN_DRIVERS: "amd" -meson-arm64: - extends: .meson-cross - variables: - ARCH: arm64 - VULKAN_DRIVERS: freedreno - GALLIUM_DRIVERS: "etnaviv,freedreno,kmsro,lima,nouveau,panfrost,tegra,v3d,vc4" - # Disable the tests since we're cross compiling. - EXTRA_OPTION: > - -D build-tests=false - -D I-love-half-baked-turnips=true - -D vulkan-overlay-layer=true - -meson-i386: - extends: .meson-cross +meson-mingw32-x86_64: + extends: .meson-build variables: - ARCH: i386 - VULKAN_DRIVERS: intel + UNWIND: "false" + DRI_DRIVERS: "" GALLIUM_DRIVERS: "swrast" - # Disable i386 tests, because u_format_tests gets precision - # failures in dxtn unpacking EXTRA_OPTION: > - -D build-tests=false - -D vulkan-overlay-layer=true + -Dllvm=false + -Dosmesa=gallium + --cross-file=.gitlab-ci/x86_64-w64-mingw32 -scons-nollvm: +scons: extends: .scons-build variables: - SCONS_TARGET: "llvm=0" - SCONS_CHECK_COMMAND: "scons llvm=0 check" + SCONS_TARGET: "llvm=1" + SCONS_CHECK_COMMAND: "scons llvm=1 force_scons=1 check" + script: + - SCONS_TARGET="" SCONS_CHECK_COMMAND="scons check force_scons=1" .gitlab-ci/scons-build.sh + - LLVM_VERSION=9 .gitlab-ci/scons-build.sh -scons-llvm: - extends: .scons-build +scons-old-llvm: + extends: + - scons + - .use-x86_build_old + script: + - LLVM_VERSION=3.9 .gitlab-ci/scons-build.sh + +.test: + extends: + - .ci-run-policy + stage: test variables: - SCONS_TARGET: "llvm=1" - SCONS_CHECK_COMMAND: "scons llvm=1 check" - LLVM_VERSION: "3.4" - # LLVM 3.4 packages were built with an old libstdc++ ABI - CXX: "g++ -D_GLIBCXX_USE_CXX11_ABI=0" + GIT_STRATEGY: none # testing doesn't build anything from source + before_script: + # Note: Build dir (and thus install) may be dirty due to GIT_STRATEGY + - rm -rf install + - tar -xf artifacts/install.tar + - LD_LIBRARY_PATH=install/lib find install/lib -name "*.so" -print -exec ldd {} \; + artifacts: + when: always + name: "$CI_JOB_NAME-$CI_COMMIT_REF_NAME" + paths: + - results/ + dependencies: + - meson-testing + +.test-gl: + extends: + - .test + variables: + TAG: *x86_test-gl + image: "$CI_REGISTRY_IMAGE/debian/x86_test-gl:$TAG" + needs: + - meson-testing + - x86_test-gl + +.test-vk: + extends: + - .test + variables: + TAG: *x86_test-vk + image: "$CI_REGISTRY_IMAGE/debian/x86_test-vk:$TAG" + needs: + - meson-testing + - x86_test-vk + +.piglit-test: + extends: .test-gl + artifacts: + when: on_failure + name: "$CI_JOB_NAME-$CI_COMMIT_REF_NAME" + paths: + - summary/ + variables: + LIBGL_ALWAYS_SOFTWARE: 1 + PIGLIT_NO_WINDOW: 1 + script: + - artifacts/piglit/run.sh + +piglit-quick_gl: + extends: .piglit-test + variables: + LP_NUM_THREADS: 0 + NIR_VALIDATE: 0 + PIGLIT_OPTIONS: > + --process-isolation false + -x arb_gpu_shader5 + -x egl_ext_device_ + -x egl_ext_platform_device + -x ext_timer_query@time-elapsed + -x glx-multithread-clearbuffer + -x glx-multithread-shader-compile + -x max-texture-size + -x maxsize + PIGLIT_PROFILES: quick_gl + +piglit-glslparser: + extends: .piglit-test + variables: + LP_NUM_THREADS: 0 + NIR_VALIDATE: 0 + PIGLIT_PROFILES: glslparser + +piglit-quick_shader: + extends: .piglit-test + variables: + LP_NUM_THREADS: 1 + NIR_VALIDATE: 0 + PIGLIT_PROFILES: quick_shader + +.deqp-test: + variables: + DEQP_SKIPS: deqp-default-skips.txt + script: + - ./artifacts/deqp-runner.sh + +.deqp-test-gl: + extends: + - .test-gl + - .deqp-test + +.deqp-test-vk: + extends: + - .test-vk + - .deqp-test + variables: + DEQP_VER: vk + +test-llvmpipe-gles2: + variables: + DEQP_VER: gles2 + DEQP_PARALLEL: 4 + NIR_VALIDATE: 0 + # Don't use threads inside llvmpipe, we've already got all 4 cores + # busy with DEQP_PARALLEL. + LP_NUM_THREADS: 0 + DEQP_EXPECTED_FAILS: deqp-llvmpipe-fails.txt + LIBGL_ALWAYS_SOFTWARE: "true" + extends: .deqp-test-gl + +test-softpipe-gles2: + extends: test-llvmpipe-gles2 + variables: + DEQP_EXPECTED_FAILS: deqp-softpipe-fails.txt + DEQP_SKIPS: deqp-softpipe-skips.txt + GALLIUM_DRIVER: "softpipe" + +test-softpipe-gles3: + parallel: 2 + variables: + DEQP_VER: gles3 + extends: test-softpipe-gles2 + +test-softpipe-gles31: + parallel: 4 + variables: + DEQP_VER: gles31 + extends: test-softpipe-gles2 + +.arm64_a630_gles2: + extends: + - .deqp-test-gl + - .use-arm_test + variables: + DEQP_VER: gles2 + DEQP_EXPECTED_FAILS: deqp-freedreno-a630-fails.txt + DEQP_SKIPS: deqp-freedreno-a630-skips.txt + NIR_VALIDATE: 0 + DEQP_PARALLEL: 4 + FLAKES_CHANNEL: "#freedreno-ci" + tags: + - mesa-cheza + dependencies: + - meson-arm64 + +.arm64_a630_gles31: + extends: .arm64_a630_gles2 + variables: + DEQP_VER: gles31 + +.arm64_a630_gles3: + extends: .arm64_a630_gles2 + variables: + DEQP_VER: gles3 + +arm64_a306_gles2: + extends: .arm64_a630_gles2 + variables: + DEQP_EXPECTED_FAILS: deqp-freedreno-a307-fails.txt + DEQP_SKIPS: deqp-default-skips.txt + tags: + - db410c + +# RADV CI +.test-radv: + variables: + VK_DRIVER: radeon + RADV_DEBUG: checkir + # Can only be triggered manually on personal branches because RADV is the only + # driver that does Vulkan testing at the moment. + rules: + # Never test RADV by default in the main project. + - if: '$CI_PROJECT_PATH == "mesa/mesa"' + when: never + # Never test RADV by default for merge requests. + - if: '$CI_MERGE_REQUEST_SOURCE_BRANCH_NAME == $CI_COMMIT_REF_NAME' + when: never + # Otherwise, allow testing RADV if the test image for VK has been manually + # started. + - when: on_success + +radv_polaris10_vkcts: + extends: + - .deqp-test-vk + - .test-radv + variables: + DEQP_PARALLEL: 4 + DEQP_SKIPS: deqp-radv-polaris10-skips.txt + tags: + - polaris10