X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=.gitlab-ci.yml;h=792bbfb13f7330aa40828631cbb57dc6e3f90342;hb=cc6a72a00261b057a662459dd7f00ebba5e28708;hp=5ca5703fc0ce557f7cff7d6df8d8cc589d8b202f;hpb=da1a5a19bddea47a1cbb512a89c6193c8fd1b197;p=mesa.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 5ca5703fc0c..792bbfb13f7 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -12,19 +12,16 @@ # 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. -# -# The format of the tag is "%Y-%m-%d-${counter}" where ${counter} stays -# at "01" unless you have multiple updates on the same day :) variables: UPSTREAM_REPO: mesa/mesa - UBUNTU_TAG: "2019-04-02" - UBUNTU_VERSION: bionic - UBUNTU_IMAGE: "$CI_REGISTRY_IMAGE/ubuntu/$UBUNTU_VERSION:$UBUNTU_TAG" + DEBIAN_TAG: "2019-07-23" + DEBIAN_VERSION: stretch-slim + DEBIAN_IMAGE: "$CI_REGISTRY_IMAGE/debian/$DEBIAN_VERSION:$DEBIAN_TAG" include: - project: 'wayland/ci-templates' ref: c73dae8b84697ef18e2dbbf4fed7386d9652b0cd - file: '/templates/ubuntu.yml' + file: '/templates/debian.yml' stages: - containers-build @@ -45,33 +42,38 @@ stages: # CONTAINERS -ubuntu: - extends: .ubuntu@container-ifnot-exists +debian: + extends: .debian@container-ifnot-exists stage: containers-build <<: *ci-run-policy variables: GIT_STRATEGY: none # no need to pull the whole tree for rebuilding the image - UBUNTU_EXEC: 'bash .gitlab-ci/ubuntu-install.sh' + DEBIAN_EXEC: 'bash .gitlab-ci/debian-install.sh' # BUILD .build: <<: *ci-run-policy - image: $UBUNTU_IMAGE + image: $DEBIAN_IMAGE stage: build+test cache: paths: - ccache artifacts: - when: on_failure - untracked: true + when: always + paths: + - _build/meson-logs/*.txt + # scons: + - _build/*/config.log + - shader-db + variables: + CCACHE_COMPILERCHECK: "content" # 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" - - export CCACHE_COMPILERCHECK=content - ccache --zero-stats || true - ccache --show-stats || true after_script: @@ -81,30 +83,7 @@ ubuntu: .meson-build: extends: .build script: - # We need to control the version of llvm-config we're using, so we'll - # generate a native file to do so. This requires meson >=0.49 - - if test -n "$LLVM_VERSION"; then - LLVM_CONFIG="llvm-config-${LLVM_VERSION}"; - echo -e "[binaries]\nllvm-config = '`which $LLVM_CONFIG`'" > native.file; - $LLVM_CONFIG --version; - else - touch native.file; - fi - - meson --version - - meson _build - --native-file=native.file - -D build-tests=true - -D libunwind=${UNWIND} - ${DRI_LOADERS} - -D dri-drivers=${DRI_DRIVERS:-[]} - ${GALLIUM_ST} - -D gallium-drivers=${GALLIUM_DRIVERS:-[]} - -D vulkan-drivers=${VULKAN_DRIVERS:-[]} - -D I-love-half-baked-turnips=true - - cd _build - - meson configure - - ninja -j4 - - ninja test + - .gitlab-ci/meson-build.sh .scons-build: extends: .build @@ -117,42 +96,34 @@ ubuntu: - scons $SCONS_TARGET - eval $SCONS_CHECK_COMMAND -autotools: - extends: .build - variables: - MAKEFLAGS: "-j8" - LLVM_CONFIG: llvm-config-7 - script: - - mkdir build - - cd build - - ../autogen.sh - --enable-autotools - --enable-debug - --disable-llvm-shared-libs - - make - - make check - # 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. -meson-gallium-swr: +# +# 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: extends: .meson-build variables: UNWIND: "true" DRI_LOADERS: > - -D glx=disabled - -D egl=false - -D gbm=false + -D glvnd=true + -D egl=true GALLIUM_ST: > - -D dri3=false + -D dri3=true -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 gallium-nine=true -D gallium-opencl=disabled - GALLIUM_DRIVERS: "swr" + -D osmesa=gallium + GALLIUM_DRIVERS: "swr,swrast,iris" LLVM_VERSION: "6.0" meson-clang: @@ -161,35 +132,32 @@ meson-clang: UNWIND: "true" DRI_DRIVERS: "auto" GALLIUM_DRIVERS: "auto" - CC: "ccache clang-7" - CXX: "ccache clang++-7" + 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 -meson-vulkan: - extends: .meson-build +scons-swr: + extends: .scons-build variables: - UNWIND: "false" - DRI_LOADERS: > - -D glx=disabled - -D gbm=false - -D egl=false - -D platforms=x11,wayland,drm - -D osmesa=none - GALLIUM_ST: > - -D dri3=true - -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 gallium-opencl=disabled - VULKAN_DRIVERS: intel,amd,freedreno - LLVM_VERSION: "7" + SCONS_TARGET: "swr=1" + SCONS_CHECK_COMMAND: "true" + LLVM_VERSION: "6.0" -meson-loader-classic-dri: +scons-win64: + extends: .scons-build + variables: + SCONS_TARGET: platform=windows machine=x86_64 + SCONS_CHECK_COMMAND: "true" + +meson-main: extends: .meson-build variables: - UNWIND: "false" + UNWIND: "true" DRI_LOADERS: > -D glx=dri -D gbm=true @@ -199,34 +167,22 @@ meson-loader-classic-dri: DRI_DRIVERS: "i915,i965,r100,r200,swrast,nouveau" GALLIUM_ST: > -D dri3=true - -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 gallium-opencl=disabled - -meson-glvnd: - extends: .meson-build - variables: - UNWIND: "true" - DRI_LOADERS: > - -D glvnd=true - -D egl=true - -D gbm=true - -D glx=dri - DRI_DRIVERS: "i965" - GALLIUM_ST: > - -D gallium-vdpau=false - -D gallium-xvmc=false - -D gallium-omx=disabled - -D gallium-va=false - -D gallium-xa=false + -D tools=drm-shim + -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_SHADERDB: "true" -meson-gallium-radeonsi: +meson-clover: extends: .meson-build variables: UNWIND: "true" @@ -242,20 +198,29 @@ meson-gallium-radeonsi: -D gallium-va=false -D gallium-xa=false -D gallium-nine=false - -D gallium-opencl=disabled - GALLIUM_DRIVERS: "radeonsi" - LLVM_VERSION: "7" + -D gallium-opencl=icd + script: + - export GALLIUM_DRIVERS="r600,radeonsi" + - .gitlab-ci/meson-build.sh + - LLVM_VERSION=7 .gitlab-ci/meson-build.sh + - export GALLIUM_DRIVERS="i915,r600" + - 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-gallium-drivers-other: +meson-vulkan: extends: .meson-build variables: - UNWIND: "true" + UNWIND: "false" DRI_LOADERS: > -D glx=disabled - -D egl=false -D gbm=false + -D egl=false + -D platforms=x11,wayland,drm + -D osmesa=none GALLIUM_ST: > - -D dri3=false + -D dri3=true -D gallium-vdpau=false -D gallium-xvmc=false -D gallium-omx=disabled @@ -263,17 +228,21 @@ meson-gallium-drivers-other: -D gallium-xa=false -D gallium-nine=false -D gallium-opencl=disabled - GALLIUM_DRIVERS: "i915,iris,nouveau,kmsro,r300,r600,freedreno,svga,swrast,v3d,vc4,virgl,etnaviv,panfrost,lima" - LLVM_VERSION: "5.0" + VULKAN_DRIVERS: intel,amd,freedreno + LLVM_VERSION: "7" + EXTRA_OPTION: > + -D vulkan-overlay-layer=true -meson-gallium-clover-llvm: +.meson-cross: extends: .meson-build variables: - UNWIND: "true" + UNWIND: "false" DRI_LOADERS: > -D glx=disabled - -D egl=false -D gbm=false + -D egl=false + -D platforms=surfaceless + -D osmesa=none GALLIUM_ST: > -D dri3=false -D gallium-vdpau=false @@ -282,36 +251,51 @@ meson-gallium-clover-llvm: -D gallium-va=false -D gallium-xa=false -D gallium-nine=false - -D gallium-opencl=icd - GALLIUM_DRIVERS: "r600,radeonsi" + -D llvm=false + CROSS: > + --cross /tmp/cross_file.txt -meson-gallium-clover-llvm39: - extends: meson-gallium-clover-llvm + 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 + - .gitlab-ci/meson-build.sh + +meson-armhf: + extends: .meson-cross variables: - GALLIUM_DRIVERS: "r600" - LLVM_VERSION: "3.9" + 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 -meson-gallium-st-other: - extends: .meson-build +meson-arm64: + extends: .meson-cross variables: - UNWIND: "true" - DRI_LOADERS: > - -D glx=disabled - -D egl=false - -D gbm=false - 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 - -D osmesa=gallium - GALLIUM_DRIVERS: "nouveau,swrast" - LLVM_VERSION: "5.0" + 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 + variables: + ARCH: i386 + VULKAN_DRIVERS: intel + 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 scons-nollvm: extends: .scons-build @@ -324,11 +308,6 @@ scons-llvm: variables: SCONS_TARGET: "llvm=1" SCONS_CHECK_COMMAND: "scons llvm=1 check" - LLVM_VERSION: "3.9" - -scons-swr: - extends: .scons-build - variables: - SCONS_TARGET: "swr=1" - SCONS_CHECK_COMMAND: "true" - LLVM_VERSION: "6.0" + LLVM_VERSION: "3.4" + # LLVM 3.4 packages were built with an old libstdc++ ABI + CXX: "g++ -D_GLIBCXX_USE_CXX11_ABI=0"