X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=.gitlab-ci.yml;h=fb8be02b7e546a74d7faa2f85e783ff5da8f9026;hb=7a57cfbed695c48915fdb3d7bec37505d3f18e81;hp=0a097ce3830ddf3c031223cfc0aaa8412786fbc0;hpb=3dc5faf5239828780ee31d711fda50360b6d4a00;p=mesa.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 0a097ce3830..fb8be02b7e5 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -16,52 +16,72 @@ # 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: - UBUNTU_TAG: 2019-01-31-01 - UBUNTU_IMAGE: "$CI_REGISTRY_IMAGE/ubuntu:$UBUNTU_TAG" + UPSTREAM_REPO: mesa/mesa + DEBIAN_TAG: "2019-04-16" + 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' stages: - containers-build - build+test +# 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 + + # CONTAINERS -containers:ubuntu: +debian: + extends: .debian@container-ifnot-exists stage: containers-build - image: docker:stable - services: - - docker:dind + <<: *ci-run-policy variables: - DOCKER_HOST: tcp://docker:2375 - DOCKER_DRIVER: overlay2 - script: - # Enable experimental features such as `docker manifest inspect` - - mkdir -p ~/.docker - - "echo '{\"experimental\": \"enabled\"}' > ~/.docker/config.json" - - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY - # Check if the image (with the specific tag) already exists - - docker manifest inspect $UBUNTU_IMAGE && exit || true - - docker build -t $UBUNTU_IMAGE -f .gitlab-ci/Dockerfile.ubuntu . - - docker push $UBUNTU_IMAGE - only: - changes: - - .gitlab-ci.yml - - .gitlab-ci/Dockerfile.ubuntu + GIT_STRATEGY: none # no need to pull the whole tree for rebuilding the image + DEBIAN_EXEC: 'bash .gitlab-ci/debian-install.sh' # BUILD .build: - image: $UBUNTU_IMAGE + <<: *ci-run-policy + image: $DEBIAN_IMAGE stage: build+test + cache: + paths: + - ccache artifacts: when: on_failure untracked: true + 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" + - ccache --zero-stats || true + - ccache --show-stats || true + after_script: + - export CCACHE_DIR="$PWD/ccache" + - ccache --show-stats .meson-build: extends: .build - before_script: + 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 @@ -74,6 +94,7 @@ containers:ubuntu: - meson --version - meson _build --native-file=native.file + -D buildtype=debug -D build-tests=true -D libunwind=${UNWIND} ${DRI_LOADERS} @@ -81,35 +102,11 @@ containers:ubuntu: ${GALLIUM_ST} -D gallium-drivers=${GALLIUM_DRIVERS:-[]} -D vulkan-drivers=${VULKAN_DRIVERS:-[]} + -D I-love-half-baked-turnips=true - cd _build - meson configure - script: - - ninja - - ninja test - -.make-build: - extends: .build - variables: - MAKEFLAGS: "-j4" - before_script: - - if test -n "$LLVM_VERSION"; then - export LLVM_CONFIG="llvm-config-${LLVM_VERSION}"; - fi - - mkdir build - - cd build - - ../autogen.sh - --enable-autotools - --enable-debug - $LIBUNWIND_FLAGS - $DRI_LOADERS - --with-dri-drivers=$DRI_DRIVERS - $GALLIUM_ST - --with-gallium-drivers=$GALLIUM_DRIVERS - --with-vulkan-drivers=$VULKAN_DRIVERS - --disable-llvm-shared-libs - script: - - make - - eval $MAKE_CHECK_COMMAND + - ninja -j4 + - LC_ALL=C.UTF-8 ninja test .scons-build: extends: .build @@ -122,7 +119,44 @@ containers:ubuntu: - scons $SCONS_TARGET - eval $SCONS_CHECK_COMMAND -build:meson-vulkan: +# 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: + extends: .meson-build + variables: + UNWIND: "true" + DRI_LOADERS: > + -D glx=disabled + -D egl=false + -D gbm=false + 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 gallium-opencl=disabled + GALLIUM_DRIVERS: "swr" + LLVM_VERSION: "6.0" + +meson-clang: + extends: .meson-build + variables: + UNWIND: "true" + DRI_DRIVERS: "auto" + GALLIUM_DRIVERS: "auto" + 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 variables: UNWIND: "false" @@ -141,10 +175,10 @@ build:meson-vulkan: -D gallium-xa=false -D gallium-nine=false -D gallium-opencl=disabled - VULKAN_DRIVERS: intel,amd + VULKAN_DRIVERS: intel,amd,freedreno LLVM_VERSION: "7" -build:meson-loader-classic-dri: +meson-loader-classic-dri: extends: .meson-build variables: UNWIND: "false" @@ -165,7 +199,7 @@ build:meson-loader-classic-dri: -D gallium-nine=false -D gallium-opencl=disabled -build:meson-glvnd: +meson-glvnd: extends: .meson-build variables: UNWIND: "true" @@ -184,30 +218,7 @@ build:meson-glvnd: -D gallium-nine=false -D gallium-opencl=disabled -# NOTE: Building SWR is 2x (yes two) times slower than all the other -# gallium drivers combined. -# Start this early so that it doesn't hunder the run time. -build:meson-gallium-swr: - extends: .meson-build - variables: - UNWIND: "true" - DRI_LOADERS: > - -D glx=disabled - -D egl=false - -D gbm=false - 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 gallium-opencl=disabled - GALLIUM_DRIVERS: "swr" - LLVM_VERSION: "6.0" - -build:meson-gallium-radeonsi: +meson-gallium-radeonsi: extends: .meson-build variables: UNWIND: "true" @@ -227,7 +238,7 @@ build:meson-gallium-radeonsi: GALLIUM_DRIVERS: "radeonsi" LLVM_VERSION: "7" -build:meson-gallium-drivers-other: +meson-gallium-drivers-other: extends: .meson-build variables: UNWIND: "true" @@ -244,10 +255,10 @@ build:meson-gallium-drivers-other: -D gallium-xa=false -D gallium-nine=false -D gallium-opencl=disabled - GALLIUM_DRIVERS: "i915,nouveau,kmsro,r300,r600,freedreno,svga,swrast,v3d,vc4,virgl,etnaviv" + GALLIUM_DRIVERS: "i915,iris,nouveau,kmsro,r300,r600,freedreno,svga,swrast,v3d,vc4,virgl,etnaviv,panfrost,lima" LLVM_VERSION: "5.0" -build:meson-gallium-clover-llvm5: +meson-gallium-clover-llvm: extends: .meson-build variables: UNWIND: "true" @@ -264,21 +275,15 @@ build:meson-gallium-clover-llvm5: -D gallium-xa=false -D gallium-nine=false -D gallium-opencl=icd - GALLIUM_DRIVERS: "r600" - LLVM_VERSION: "5.0" - -build:meson-gallium-clover-llvm6: - extends: build:meson-gallium-clover-llvm5 - variables: - LLVM_VERSION: "6.0" + GALLIUM_DRIVERS: "r600,radeonsi" -build:meson-gallium-clover-llvm7: - extends: build:meson-gallium-clover-llvm5 +meson-gallium-clover-llvm39: + extends: meson-gallium-clover-llvm variables: - GALLIUM_DRIVERS: "r600,radeonsi" - LLVM_VERSION: "7" + GALLIUM_DRIVERS: "r600" + LLVM_VERSION: "3.9" -build:meson-gallium-st-other: +meson-gallium-st-other: extends: .meson-build variables: UNWIND: "true" @@ -288,6 +293,7 @@ build:meson-gallium-st-other: -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 @@ -299,176 +305,22 @@ build:meson-gallium-st-other: GALLIUM_DRIVERS: "nouveau,swrast" LLVM_VERSION: "5.0" -build:make-vulkan: - extends: .make-build - variables: - MAKE_CHECK_COMMAND: "make -C src/gtest check && make -C src/intel check" - LLVM_VERSION: "7" - DRI_LOADERS: > - --disable-glx - --disable-gbm - --disable-egl - --with-platforms=x11,wayland,drm - DRI_DRIVERS: "" - GALLIUM_ST: > - --enable-dri - --enable-dri3 - --disable-opencl - --disable-xa - --disable-nine - --disable-xvmc - --disable-vdpau - --disable-va - --disable-omx-bellagio - --disable-gallium-osmesa - VULKAN_DRIVERS: intel,radeon - LIBUNWIND_FLAGS: --disable-libunwind - -build:make-loader-classic-dri: - extends: .make-build - variables: - MAKE_CHECK_COMMAND: "make check" - DRI_LOADERS: > - --enable-glx - --enable-gbm - --enable-egl - --with-platforms=x11,wayland,drm,surfaceless - --enable-osmesa - DRI_DRIVERS: "i915,i965,radeon,r200,swrast,nouveau" - GALLIUM_ST: > - --enable-dri - --disable-opencl - --disable-xa - --disable-nine - --disable-xvmc - --disable-vdpau - --disable-va - --disable-omx-bellagio - --disable-gallium-osmesa - LIBUNWIND_FLAGS: --disable-libunwind - -# NOTE: Building SWR is 2x (yes two) times slower than all the other -# gallium drivers combined. -# Start this early so that it doesn't hunder the run time. -build:make-gallium-drivers-swr: - extends: .make-build - variables: - MAKE_CHECK_COMMAND: "true" - LLVM_VERSION: "6.0" - DRI_LOADERS: > - --disable-glx - --disable-gbm - --disable-egl - GALLIUM_ST: > - --enable-dri - --disable-opencl - --disable-xa - --disable-nine - --disable-xvmc - --disable-vdpau - --disable-va - --disable-omx-bellagio - --disable-gallium-osmesa - GALLIUM_DRIVERS: "swr" - LIBUNWIND_FLAGS: --enable-libunwind - -build:make-gallium-drivers-radeonsi: - extends: build:make-gallium-drivers-swr - variables: - LLVM_VERSION: "7" - GALLIUM_DRIVERS: "radeonsi" - -build:make-gallium-drivers-other: - extends: build:make-gallium-drivers-swr - variables: - LLVM_VERSION: "3.9" - GALLIUM_DRIVERS: "i915,nouveau,kmsro,r300,r600,freedreno,svga,swrast,v3d,vc4,virgl,etnaviv" - -build:make-gallium-st-clover-llvm-39: - extends: .make-build - variables: - MAKE_CHECK_COMMAND: "true" - LLVM_VERSION: "3.9" - DRI_LOADERS: > - --disable-glx - --disable-gbm - --disable-egl - GALLIUM_ST: > - --disable-dri - --enable-opencl - --enable-opencl-icd - --enable-llvm - --disable-xa - --disable-nine - --disable-xvmc - --disable-vdpau - --disable-va - --disable-omx-bellagio - --disable-gallium-osmesa - GALLIUM_DRIVERS: "r600" - LIBUNWIND_FLAGS: --enable-libunwind - -build:make-gallium-st-clover-llvm-4: - extends: build:make-gallium-st-clover-llvm-39 - variables: - LLVM_VERSION: "4.0" - -build:make-gallium-st-clover-llvm-5: - extends: build:make-gallium-st-clover-llvm-39 - variables: - LLVM_VERSION: "5.0" - -build:make-gallium-st-clover-llvm-6: - extends: build:make-gallium-st-clover-llvm-39 - variables: - LLVM_VERSION: "6.0" - -build:make-gallium-st-clover-llvm-7: - extends: build:make-gallium-st-clover-llvm-39 - variables: - LLVM_VERSION: "7" - GALLIUM_DRIVERS: "r600,radeonsi" - -build:make-gallium-st-other: - extends: .make-build - variables: - MAKE_CHECK_COMMAND: "true" - # We should be testing 3.3, but 3.9 is the oldest that still exists in ubuntu - LLVM_VERSION: "3.9" - DRI_LOADERS: > - --disable-glx - --disable-gbm - --disable-egl - GALLIUM_ST: > - --enable-dri - --disable-opencl - --enable-xa - --enable-nine - --enable-xvmc - --enable-vdpau - --enable-va - --enable-omx-bellagio - --enable-gallium-osmesa - # We need swrast for osmesa and nine. - # i915 most likely doesn't work with most ST. - # Regardless - we're doing a quick build test here. - GALLIUM_DRIVERS: "i915,swrast" - LIBUNWIND_FLAGS: --enable-libunwind - -build:scons-nollvm: +scons-nollvm: extends: .scons-build variables: SCONS_TARGET: "llvm=0" SCONS_CHECK_COMMAND: "scons llvm=0 check" -build:scons-llvm: +scons-llvm: extends: .scons-build variables: SCONS_TARGET: "llvm=1" SCONS_CHECK_COMMAND: "scons llvm=1 check" - LLVM_VERSION: "3.9" + LLVM_VERSION: "3.4" + # LLVM 3.4 packages were built with an old libstdc++ ABI + CXX: "g++ -D_GLIBCXX_USE_CXX11_ABI=0" -build:scons-swr: +scons-swr: extends: .scons-build variables: SCONS_TARGET: "swr=1"