X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=.gitlab-ci.yml;h=f245ee687c11e3b54ad2349274afbfb1c497ee7c;hb=9560c9b498032341413f9e2870c8770ef1fff6e9;hp=d5dc20348a0a9d509d588af7021eef47ec054663;hpb=6f0dc087b7a57fb8e0cdb4b2a884086953429afd;p=mesa.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index d5dc20348a0..f245ee687c1 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -1,5 +1,5 @@ # 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. +# image doesn't exist yet, the containers stage 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 @@ -14,26 +14,31 @@ # repository's registry will be used there as well. variables: UPSTREAM_REPO: mesa/mesa - DEBIAN_TAG: "2019-09-11" + DEBIAN_TAG: "2019-09-30" DEBIAN_ARM64_TAG: "arm64v8-2019-08-09" - DEBIAN_VERSION: stretch-slim - DEBIAN_ARM64_VERSION: buster-slim + STRETCH_TAG: "2019-09-18" + DEBIAN_VERSION: buster-slim + STRETCH_VERSION: stretch-slim DEBIAN_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_VERSION:$DEBIAN_TAG" - DEBIAN_ARM64_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_ARM64_VERSION:$DEBIAN_ARM64_TAG" + DEBIAN_ARM64_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_VERSION:$DEBIAN_ARM64_TAG" + STRETCH_IMAGE: "$CI_REGISTRY_IMAGE/debian/$STRETCH_VERSION:$STRETCH_TAG" include: - project: 'wayland/ci-templates' - ref: 1f7f57c6 + ref: 1f7f57c64ff4ebbf7292e3b7a13600518b8cb24c file: '/templates/debian.yml' +include: + - local: '/.gitlab-ci/lava-gitlab-ci.yml' + stages: - - containers-build - - build+test + - containers + - build - test # When to automatically run the CI -.ci-run-policy: &ci-run-policy +.ci-run-policy: only: - branches@mesa/mesa - merge_requests @@ -43,7 +48,7 @@ stages: when: - runner_system_failure -.ci-deqp-artifacts: &ci-deqp-artifacts +.ci-deqp-artifacts: artifacts: when: always untracked: false @@ -52,33 +57,51 @@ stages: # https://gitlab.com/gitlab-org/gitlab-ce/commit/8788fb925706cad594adf6917a6c5f6587dd1521 - artifacts -# Builds the normal CI native and cross-build docker image. -debian: - extends: .debian@container-ifnot-exists - stage: containers-build - <<: *ci-run-policy +# Build the normal CI native and cross-build docker images. + +debian-10: + extends: + - .debian@container-ifnot-exists + - .ci-run-policy + stage: containers variables: GIT_STRATEGY: none # no need to pull the whole tree for rebuilding the image DEBIAN_EXEC: 'bash .gitlab-ci/debian-install.sh' +debian-9: + extends: debian-10 + variables: + DEBIAN_TAG: $STRETCH_TAG + DEBIAN_VERSION: $STRETCH_VERSION + DEBIAN_IMAGE: $STRETCH_IMAGE + DEBIAN_EXEC: 'bash .gitlab-ci/debian-stretch-install.sh' + +.use-debian-9: + image: $STRETCH_IMAGE + needs: + - debian-9 + # Builds a Docker image with the native environment and VK-GL-CTS for testing. test-container:arm64: - extends: .debian@container-ifnot-exists@arm64v8 - <<: *ci-run-policy - stage: containers-build + extends: + - .debian@container-ifnot-exists@arm64v8 + - .ci-run-policy + stage: containers variables: DEBIAN_TAG: "$DEBIAN_ARM64_TAG" - DEBIAN_VERSION: "$DEBIAN_ARM64_VERSION" GIT_STRATEGY: none # no need to pull the whole tree for rebuilding the image DEBIAN_EXEC: 'bash .gitlab-ci/debian-test-install.sh' # BUILD .build: - <<: *ci-run-policy + extends: .ci-run-policy image: $DEBIAN_IMAGE - stage: build+test + needs: + - debian-10 + stage: build cache: + key: ${CI_JOB_NAME} paths: - ccache artifacts: @@ -95,6 +118,7 @@ test-container:arm64: - export PATH="/usr/lib/ccache:$PATH" - export CCACHE_BASEDIR="$PWD" - export CCACHE_DIR="$PWD/ccache" + - ccache --max-size=1500M - ccache --zero-stats || true - ccache --show-stats || true after_script: @@ -117,14 +141,12 @@ test-container:arm64: 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 + - .gitlab-ci/scons-build.sh meson-main: - extends: .meson-build + extends: + - .meson-build + - .ci-deqp-artifacts variables: UNWIND: "true" DRI_LOADERS: > @@ -150,7 +172,48 @@ meson-main: -D tools=all MESON_SHADERDB: "true" BUILDTYPE: "debugoptimized" - <<: *ci-deqp-artifacts + +.meson-cross: + extends: + - .meson-build + - .ci-deqp-artifacts + 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=false + -D llvm=false + script: + - .gitlab-ci/meson-build.sh + +meson-armhf: + extends: .meson-cross + variables: + CROSS: 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 + +meson-arm64: + extends: meson-armhf + variables: + CROSS: arm64 + BUILDTYPE: "debugoptimized" # NOTE: Building SWR is 2x (yes two) times slower than all the other # gallium drivers combined. @@ -186,11 +249,6 @@ meson-clang: VULKAN_DRIVERS: intel,amd,freedreno CC: "ccache clang-8" CXX: "ccache clang++-8" - 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 scons-swr: extends: .scons-build @@ -227,11 +285,25 @@ meson-clover: - .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-debian-9 + 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 - - LLVM_VERSION=7 .gitlab-ci/meson-build.sh meson-vulkan: extends: .meson-build @@ -257,54 +329,6 @@ meson-vulkan: EXTRA_OPTION: > -D vulkan-overlay-layer=true -.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=false - -D llvm=false - <<: *ci-deqp-artifacts - script: - - .gitlab-ci/meson-build.sh - -meson-armhf: - extends: .meson-cross - variables: - CROSS: 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 - -meson-arm64: - extends: .meson-cross - variables: - CROSS: 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 - BUILDTYPE: "debugoptimized" - # 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) @@ -315,29 +339,33 @@ meson-i386: VULKAN_DRIVERS: intel DRI_DRIVERS: "swrast" GALLIUM_DRIVERS: "iris" - # Disable i386 tests, because u_format_tests gets precision - # failures in dxtn unpacking EXTRA_OPTION: > - -D build-tests=false -D vulkan-overlay-layer=true -D llvm=false -D osmesa=classic -scons-nollvm: - extends: .scons-build - variables: - SCONS_TARGET: "llvm=0" - SCONS_CHECK_COMMAND: "scons llvm=0 check" - -scons-llvm: +scons: extends: .scons-build variables: SCONS_TARGET: "llvm=1" SCONS_CHECK_COMMAND: "scons llvm=1 check" - LLVM_VERSION: "3.9" + script: + - SCONS_TARGET="" SCONS_CHECK_COMMAND="scons check" .gitlab-ci/scons-build.sh + - LLVM_VERSION=6.0 .gitlab-ci/scons-build.sh + - LLVM_VERSION=7 .gitlab-ci/scons-build.sh + - LLVM_VERSION=8 .gitlab-ci/scons-build.sh + +scons-old-llvm: + extends: + - scons + - .use-debian-9 + script: + - LLVM_VERSION=3.9 .gitlab-ci/scons-build.sh + - LLVM_VERSION=4.0 .gitlab-ci/scons-build.sh + - LLVM_VERSION=5.0 .gitlab-ci/scons-build.sh .deqp-test: - <<: *ci-run-policy + extends: .ci-run-policy stage: test image: $DEBIAN_IMAGE variables: @@ -353,6 +381,9 @@ scons-llvm: name: "$CI_JOB_NAME-$CI_COMMIT_REF_NAME" paths: - results/ + dependencies: + - meson-main + needs: [meson-main] test-llvmpipe-gles2: parallel: 4 @@ -362,22 +393,13 @@ test-llvmpipe-gles2: LIBGL_ALWAYS_SOFTWARE: "true" DEQP_RENDERER_MATCH: "llvmpipe" extends: .deqp-test - dependencies: - - meson-main - needs: [meson-main] test-softpipe-gles2: - parallel: 4 + extends: test-llvmpipe-gles2 variables: - DEQP_VER: gles2 DEQP_EXPECTED_FAILS: deqp-softpipe-fails.txt - LIBGL_ALWAYS_SOFTWARE: "true" DEQP_RENDERER_MATCH: "softpipe" GALLIUM_DRIVER: "softpipe" - extends: .deqp-test - dependencies: - - meson-main - needs: [meson-main] # The GLES2 CTS run takes about 8 minutes of CPU time, while GLES3 is # 25 minutes. Until we can get its runtime down, just do a partial @@ -392,28 +414,12 @@ test-softpipe-gles3-limited: CI_NODE_INDEX: 1 CI_NODE_TOTAL: 10 extends: .deqp-test - dependencies: - - meson-main - needs: [meson-main] -arm64_a306_gles2: +arm64_a630_gles2: extends: .deqp-test - parallel: 4 image: $DEBIAN_ARM64_IMAGE variables: DEQP_VER: gles2 - DEQP_EXPECTED_FAILS: deqp-freedreno-a307-fails.txt - NIR_VALIDATE: 0 - DEQP_RENDERER_MATCH: "FD307" - tags: - - db410c - dependencies: - - meson-arm64 - -.cheza-test: - image: $DEBIAN_ARM64_IMAGE - extends: .deqp-test - variables: DEQP_RENDERER_MATCH: "FD630" DEQP_EXPECTED_FAILS: deqp-freedreno-a630-fails.txt DEQP_SKIPS: deqp-freedreno-a630-skips.txt @@ -422,21 +428,28 @@ arm64_a306_gles2: - mesa-cheza dependencies: - meson-arm64 - needs: [ meson-arm64 ] + needs: + - meson-arm64 + - test-container:arm64 -arm64_a630_gles2: - extends: .cheza-test +arm64_a630_gles31: + extends: arm64_a630_gles2 + parallel: 4 variables: - DEQP_VER: gles2 + DEQP_VER: gles31 arm64_a630_gles3: parallel: 6 - extends: .cheza-test + extends: arm64_a630_gles2 variables: DEQP_VER: gles3 -arm64_a630_gles31: +arm64_a306_gles2: parallel: 4 - extends: .cheza-test + extends: arm64_a630_gles2 variables: - DEQP_VER: gles31 + DEQP_EXPECTED_FAILS: deqp-freedreno-a307-fails.txt + DEQP_SKIPS: deqp-default-skips.txt + DEQP_RENDERER_MATCH: "FD307" + tags: + - db410c