# repository's registry will be used there as well.
variables:
UPSTREAM_REPO: mesa/mesa
- DEBIAN_TAG: "2019-09-11"
+ DEBIAN_TAG: "2019-10-07_1"
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
+ - container
- build
- test
# https://gitlab.com/gitlab-org/gitlab-ce/commit/8788fb925706cad594adf6917a6c5f6587dd1521
- artifacts
-# Builds the normal CI native and cross-build docker image.
-debian:
+# Build the normal CI native and cross-build docker images.
+
+.container:
+ stage: container
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
+ # no need to pull the whole repo to build the container image
+ GIT_STRATEGY: none
+
+debian-10:
+ extends:
+ - .debian@container-ifnot-exists
+ - .container
+ variables:
DEBIAN_EXEC: 'bash .gitlab-ci/debian-install.sh'
+.use-debian-10:
+ image: $DEBIAN_IMAGE
+ needs:
+ - debian-10
+
+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
+ - .container
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:
extends: .ci-run-policy
- image: $DEBIAN_IMAGE
stage: build
cache:
+ key: ${CI_JOB_NAME}
paths:
- ccache
artifacts:
- 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:
- ccache --show-stats
.meson-build:
- extends: .build
+ extends:
+ - .build
+ - .use-debian-10
script:
- .gitlab-ci/meson-build.sh
.scons-build:
- extends: .build
+ extends:
+ - .build
+ - .use-debian-10
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_SHADERDB: "true"
BUILDTYPE: "debugoptimized"
+.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
+
+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.
# Start this early so that it doesn't limit the total run time.
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
- .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
EXTRA_OPTION: >
-D vulkan-overlay-layer=true
-.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"
-
# 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)
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
+.meson-mingw32-x86_64:
+ extends: .meson-build
variables:
- SCONS_TARGET: "llvm=0"
- SCONS_CHECK_COMMAND: "scons llvm=0 check"
+ UNWIND: "false"
+ DRI_DRIVERS: ""
+ GALLIUM_DRIVERS: "swrast"
+ EXTRA_OPTION: >
+ -Dllvm=false
+ -Dosmesa=gallium
+ --cross-file=.gitlab-ci/x86_64-w64-mingw32
-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:
- extends: .ci-run-policy
+ extends: .use-debian-10
stage: test
- image: $DEBIAN_IMAGE
variables:
GIT_STRATEGY: none # testing doesn't build anything from source
DEQP_SKIPS: deqp-default-skips.txt
- mesa-cheza
dependencies:
- meson-arm64
- needs: [ meson-arm64 ]
+ needs:
+ - meson-arm64
+ - test-container:arm64
arm64_a630_gles31:
extends: arm64_a630_gles2