X-Git-Url: https://git.libre-soc.org/?a=blobdiff_plain;f=.gitlab-ci.yml;h=014e06b29dcb8978fa1a561621b9e4012a458100;hb=8a1ab9a166dd358f0e71a1cc98e8b6c20b5d8822;hp=e9af186083e2d325709bf9a06aaf8d5499e739c3;hpb=bbdc563c11e328bd9f3fc93c0e37eadf1a25fc3a;p=mesa.git diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index e9af186083e..014e06b29dc 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -16,18 +16,31 @@ # 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/$CI_PROJECT_PATH/ubuntu:$UBUNTU_TAG" + UBUNTU_TAG: 2019-03-05-01 + UBUNTU_IMAGE: "$CI_REGISTRY_IMAGE/ubuntu:$UBUNTU_TAG" + UBUNTU_IMAGE_MAIN: "registry.freedesktop.org/mesa/mesa/ubuntu:$UBUNTU_TAG" +cache: + paths: + - ccache stages: - containers-build - build+test +# When to automatically run the CI +.ci-run-policy: + only: + - master + - merge_requests + - /^ci([-/].*)?$/ + + # CONTAINERS -containers:ubuntu: +ubuntu: + extends: .ci-run-policy stage: containers-build image: docker:stable services: @@ -42,26 +55,38 @@ containers:ubuntu: - 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 + # Try to re-use the image from the main repository's registry + - docker image pull $UBUNTU_IMAGE_MAIN && + docker image tag $UBUNTU_IMAGE_MAIN $UBUNTU_IMAGE && + docker image push $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 # BUILD .build: + extends: .ci-run-policy image: $UBUNTU_IMAGE stage: build+test artifacts: when: on_failure untracked: true + # 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: + - 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 @@ -83,15 +108,14 @@ containers:ubuntu: -D vulkan-drivers=${VULKAN_DRIVERS:-[]} - cd _build - meson configure - script: - - ninja + - ninja -j4 - ninja test .make-build: extends: .build variables: MAKEFLAGS: "-j4" - before_script: + script: - if test -n "$LLVM_VERSION"; then export LLVM_CONFIG="llvm-config-${LLVM_VERSION}"; fi @@ -107,7 +131,6 @@ containers:ubuntu: --with-gallium-drivers=$GALLIUM_DRIVERS --with-vulkan-drivers=$VULKAN_DRIVERS --disable-llvm-shared-libs - script: - make - eval $MAKE_CHECK_COMMAND @@ -122,7 +145,7 @@ containers:ubuntu: - scons $SCONS_TARGET - eval $SCONS_CHECK_COMMAND -build:meson-vulkan: +meson-vulkan: extends: .meson-build variables: UNWIND: "false" @@ -144,7 +167,7 @@ build:meson-vulkan: VULKAN_DRIVERS: intel,amd LLVM_VERSION: "7" -build:meson-loader-classic-dri: +meson-loader-classic-dri: extends: .meson-build variables: UNWIND: "false" @@ -165,10 +188,29 @@ build:meson-loader-classic-dri: -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 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: +meson-gallium-swr: extends: .meson-build variables: UNWIND: "true" @@ -188,7 +230,7 @@ build:meson-gallium-swr: GALLIUM_DRIVERS: "swr" LLVM_VERSION: "6.0" -build:meson-gallium-radeonsi: +meson-gallium-radeonsi: extends: .meson-build variables: UNWIND: "true" @@ -208,7 +250,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" @@ -225,10 +267,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" LLVM_VERSION: "5.0" -build:meson-gallium-clover-llvm5: +meson-gallium-clover-llvm: extends: .meson-build variables: UNWIND: "true" @@ -245,21 +287,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" @@ -280,7 +316,7 @@ build:meson-gallium-st-other: GALLIUM_DRIVERS: "nouveau,swrast" LLVM_VERSION: "5.0" -build:make-vulkan: +make-vulkan: extends: .make-build variables: MAKE_CHECK_COMMAND: "make -C src/gtest check && make -C src/intel check" @@ -305,7 +341,7 @@ build:make-vulkan: VULKAN_DRIVERS: intel,radeon LIBUNWIND_FLAGS: --disable-libunwind -build:make-loader-classic-dri: +make-loader-classic-dri: extends: .make-build variables: MAKE_CHECK_COMMAND: "make check" @@ -328,20 +364,113 @@ build:make-loader-classic-dri: --disable-gallium-osmesa LIBUNWIND_FLAGS: --disable-libunwind -build:scons-nollvm: +# 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. +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 + +make-gallium-drivers-radeonsi: + extends: make-gallium-drivers-swr + variables: + LLVM_VERSION: "7" + GALLIUM_DRIVERS: "radeonsi" + +make-gallium-drivers-other: + extends: make-gallium-drivers-swr + variables: + LLVM_VERSION: "3.9" + GALLIUM_DRIVERS: "i915,nouveau,kmsro,r300,r600,freedreno,svga,swrast,v3d,vc4,virgl,etnaviv" + +make-gallium-st-clover-llvm: + extends: .make-build + variables: + MAKE_CHECK_COMMAND: "true" + 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 + LIBUNWIND_FLAGS: --enable-libunwind + GALLIUM_DRIVERS: "r600,radeonsi" + LLVM_VERSION: "7" + +make-gallium-st-clover-llvm-39: + extends: make-gallium-st-clover-llvm + variables: + LLVM_VERSION: "3.9" + GALLIUM_DRIVERS: "r600" + +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 + +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" -build:scons-swr: +scons-swr: extends: .scons-build variables: SCONS_TARGET: "swr=1"