diff options
Diffstat (limited to 'lib/mesa/.gitlab-ci')
77 files changed, 4399 insertions, 296 deletions
diff --git a/lib/mesa/.gitlab-ci/all-skips.txt b/lib/mesa/.gitlab-ci/all-skips.txt index 52a8e87f3..526debd4e 100644 --- a/lib/mesa/.gitlab-ci/all-skips.txt +++ b/lib/mesa/.gitlab-ci/all-skips.txt @@ -6,12 +6,12 @@ # reliable to be run in parallel with other tests due to CPU-side timing. dEQP-GLES[0-9]*.functional.flush_finish.* -# https://gitlab.freedesktop.org/mesa/mesa/-/issues/4575 -dEQP-VK.wsi.display.get_display_plane_capabilities - # piglit: WGL is Windows-only wgl@.* # These are sensitive to CPU timing, and would need to be run in isolation # on the system rather than in parallel with other tests. glx@glx_arb_sync_control@timing.* + +# This test is not built with waffle, while we do build tests with waffle +spec@!opengl 1.1@windowoverlap diff --git a/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-off.sh b/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-off.sh new file mode 100755 index 000000000..2234ee796 --- /dev/null +++ b/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-off.sh @@ -0,0 +1,17 @@ +#!/bin/bash + +if [ -z "$BM_POE_INTERFACE" ]; then + echo "Must supply the PoE Interface to power down" + exit 1 +fi + +if [ -z "$BM_POE_ADDRESS" ]; then + echo "Must supply the PoE Switch host" + exit 1 +fi + +SNMP_KEY="1.3.6.1.4.1.9.9.402.1.2.1.1.1.$BM_POE_INTERFACE" +SNMP_ON="i 1" +SNMP_OFF="i 4" + +snmpset -v2c -r 3 -t 30 -cmesaci $BM_POE_ADDRESS $SNMP_KEY $SNMP_OFF diff --git a/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-on.sh b/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-on.sh new file mode 100755 index 000000000..60d7d726a --- /dev/null +++ b/lib/mesa/.gitlab-ci/bare-metal/cisco-2960-poe-on.sh @@ -0,0 +1,21 @@ +#!/bin/bash + +if [ -z "$BM_POE_INTERFACE" ]; then + echo "Must supply the PoE Interface to power up" + exit 1 +fi + +if [ -z "$BM_POE_ADDRESS" ]; then + echo "Must supply the PoE Switch host" + exit 1 +fi + +set -ex + +SNMP_KEY="1.3.6.1.4.1.9.9.402.1.2.1.1.1.$BM_POE_INTERFACE" +SNMP_ON="i 1" +SNMP_OFF="i 4" + +snmpset -v2c -r 3 -t 10 -cmesaci $BM_POE_ADDRESS $SNMP_KEY $SNMP_OFF +sleep 3s +snmpset -v2c -r 3 -t 10 -cmesaci $BM_POE_ADDRESS $SNMP_KEY $SNMP_ON diff --git a/lib/mesa/.gitlab-ci/bare-metal/cros_servo_run.py b/lib/mesa/.gitlab-ci/bare-metal/cros_servo_run.py index 995e11210..042465e98 100755 --- a/lib/mesa/.gitlab-ci/bare-metal/cros_servo_run.py +++ b/lib/mesa/.gitlab-ci/bare-metal/cros_servo_run.py @@ -50,12 +50,18 @@ class CrosServoRun: target=self.iter_feed_queue, daemon=True, args=(self.cpu_ser.lines(),)) self.iter_feed_cpu.start() + def close(self): + self.ec_ser.close() + self.cpu_ser.close() + self.iter_feed_ec.join() + self.iter_feed_cpu.join() + # Feed lines from our serial queues into the merged queue, marking when our # input is done. def iter_feed_queue(self, it): for i in it: self.serial_queue.put(i) - self.serial_queue.put(sentinel) + self.serial_queue.put(self.sentinel) # Return the next line from the queue, counting how many threads have # terminated and joining when done @@ -150,6 +156,10 @@ class CrosServoRun: "Detected spontaneous reboot, restarting run...") return 2 + if re.search("arm-smmu 5040000.iommu: TLB sync timed out -- SMMU may be deadlocked", line): + self.print_error("Detected cheza MMU fail, restarting run...") + return 2 + result = re.search("hwci: mesa: (\S*)", line) if result: if result.group(1) == "pass": @@ -179,6 +189,8 @@ def main(): # power down the CPU on the device servo.ec_write("power off\n") + servo.close() + sys.exit(retval) diff --git a/lib/mesa/.gitlab-ci/bare-metal/fastboot_run.py b/lib/mesa/.gitlab-ci/bare-metal/fastboot_run.py index 3654c7c80..0521a387d 100755 --- a/lib/mesa/.gitlab-ci/bare-metal/fastboot_run.py +++ b/lib/mesa/.gitlab-ci/bare-metal/fastboot_run.py @@ -36,6 +36,9 @@ class FastbootRun: self.ser = SerialBuffer(args.dev, "results/serial-output.txt", "R SERIAL> ", timeout=600) self.fastboot="fastboot boot -s {ser} artifacts/fastboot.img".format(ser=args.fbserial) + def close(self): + self.ser.close() + def print_error(self, message): RED = '\033[0;31m' NO_COLOR = '\033[0m' @@ -67,7 +70,13 @@ class FastbootRun: if self.logged_system(self.fastboot) != 0: return 1 + print_more_lines = -1 for line in self.ser.lines(): + if print_more_lines == 0: + return 2 + if print_more_lines > 0: + print_more_lines -= 1 + if re.search("---. end Kernel panic", line): return 1 @@ -89,6 +98,18 @@ class FastbootRun: "Detected network device failure, restarting run...") return 2 + # A3xx recovery doesn't quite work. Sometimes the GPU will get + # wedged and recovery will fail (because power can't be reset?) + # This assumes that the jobs are sufficiently well-tested that GPU + # hangs aren't always triggered, so just try again. But print some + # more lines first so that we get better information on the cause + # of the hang. Once a hang happens, it's pretty chatty. + if "[drm:adreno_recover] *ERROR* gpu hw init failed: -22" in line: + self.print_error( + "Detected GPU hang, restarting run...") + if print_more_lines == -1: + print_more_lines = 30 + result = re.search("hwci: mesa: (\S*)", line) if result: if result.group(1) == "pass": @@ -111,6 +132,7 @@ def main(): while True: retval = fastboot.run() + fastboot.close() if retval != 2: break diff --git a/lib/mesa/.gitlab-ci/bare-metal/poe-powered.sh b/lib/mesa/.gitlab-ci/bare-metal/poe-powered.sh index 3dd7330cd..4bd005745 100755 --- a/lib/mesa/.gitlab-ci/bare-metal/poe-powered.sh +++ b/lib/mesa/.gitlab-ci/bare-metal/poe-powered.sh @@ -20,18 +20,6 @@ if [ -z "$BM_POE_ADDRESS" ]; then exit 1 fi -if [ -z "$BM_POE_USERNAME" ]; then - echo "Must set BM_POE_USERNAME in your gitlab-runner config.toml [[runners]] environment" - echo "This is the PoE switch username." - exit 1 -fi - -if [ -z "$BM_POE_PASSWORD" ]; then - echo "Must set BM_POE_PASSWORD in your gitlab-runner config.toml [[runners]] environment" - echo "This is the PoE switch password." - exit 1 -fi - if [ -z "$BM_POE_INTERFACE" ]; then echo "Must set BM_POE_INTERFACE in your gitlab-runner config.toml [[runners]] environment" echo "This is the PoE switch interface where the device is connected." @@ -107,11 +95,25 @@ fi # Install kernel modules (it could be either in /lib/modules or # /usr/lib/modules, but we want to install in the latter) -[ -d $BM_BOOTFS/usr/lib/modules ] && rsync -a --delete $BM_BOOTFS/usr/lib/modules/ /nfs/usr/lib/modules/ -[ -d $BM_BOOTFS/lib/modules ] && rsync -a --delete $BM_BOOTFS/lib/modules/ /nfs/usr/lib/modules/ +[ -d $BM_BOOTFS/usr/lib/modules ] && rsync -a $BM_BOOTFS/usr/lib/modules/ /nfs/usr/lib/modules/ +[ -d $BM_BOOTFS/lib/modules ] && rsync -a $BM_BOOTFS/lib/modules/ /nfs/lib/modules/ # Install kernel image + bootloader files -rsync -a --delete $BM_BOOTFS/boot/ /tftp/ +rsync -aL --delete $BM_BOOTFS/boot/ /tftp/ + +# Set up the pxelinux config for Jetson Nano +mkdir -p /tftp/pxelinux.cfg +cat <<EOF >/tftp/pxelinux.cfg/default-arm-tegra210-p3450-0000 +PROMPT 0 +TIMEOUT 30 +DEFAULT primary +MENU TITLE jetson nano boot options +LABEL primary + MENU LABEL CI kernel on TFTP + LINUX Image + FDT tegra210-p3450-0000.dtb + APPEND \${cbootargs} $BM_CMDLINE +EOF # Create the rootfs in the NFS directory mkdir -p /nfs/results @@ -123,7 +125,7 @@ echo "$BM_CMDLINE" > /tftp/cmdline.txt printf "$BM_BOOTCONFIG" >> /tftp/config.txt set +e -ATTEMPTS=2 +ATTEMPTS=10 while [ $((ATTEMPTS--)) -gt 0 ]; do python3 $BM/poe_run.py \ --dev="$BM_SERIAL" \ diff --git a/lib/mesa/.gitlab-ci/bare-metal/poe_run.py b/lib/mesa/.gitlab-ci/bare-metal/poe_run.py index f22b90d5e..f53c1478f 100755 --- a/lib/mesa/.gitlab-ci/bare-metal/poe_run.py +++ b/lib/mesa/.gitlab-ci/bare-metal/poe_run.py @@ -66,6 +66,10 @@ class PoERun: self.print_error("Memory overflow in the binner; GPU hang") return 1 + if re.search("nouveau 57000000.gpu: bus: MMIO read of 00000000 FAULT at 137000", line): + self.print_error("nouveau jetson boot bug, retrying.") + return 2 + result = re.search("hwci: mesa: (\S*)", line) if result: if result.group(1) == "pass": diff --git a/lib/mesa/.gitlab-ci/bare-metal/rootfs-setup.sh b/lib/mesa/.gitlab-ci/bare-metal/rootfs-setup.sh index 0b017454c..7a706d0a0 100644 --- a/lib/mesa/.gitlab-ci/bare-metal/rootfs-setup.sh +++ b/lib/mesa/.gitlab-ci/bare-metal/rootfs-setup.sh @@ -8,15 +8,21 @@ mkdir -p $rootfs_dst/results cp $BM/bm-init.sh $rootfs_dst/init cp $CI_COMMON/init*.sh $rootfs_dst/ +# Make JWT token available as file in the bare-metal storage to enable access +# to MinIO +cp "${CI_JOB_JWT_FILE}" "${rootfs_dst}${CI_JOB_JWT_FILE}" + cp $CI_COMMON/capture-devcoredump.sh $rootfs_dst/ +cp $CI_COMMON/intel-gpu-freq.sh $rootfs_dst/ set +x + # Pass through relevant env vars from the gitlab job to the baremetal init script "$CI_COMMON"/generate-env.sh > $rootfs_dst/set-job-env-vars.sh chmod +x $rootfs_dst/set-job-env-vars.sh echo "Variables passed through:" cat $rootfs_dst/set-job-env-vars.sh -echo "export CI_JOB_JWT=${CI_JOB_JWT@Q}" >> $rootfs_dst/set-job-env-vars.sh + set -x # Add the Mesa drivers we built, and make a consistent symlink to them. diff --git a/lib/mesa/.gitlab-ci/bare-metal/serial_buffer.py b/lib/mesa/.gitlab-ci/bare-metal/serial_buffer.py index 70f377097..710e78677 100755 --- a/lib/mesa/.gitlab-ci/bare-metal/serial_buffer.py +++ b/lib/mesa/.gitlab-ci/bare-metal/serial_buffer.py @@ -28,7 +28,6 @@ import serial import threading import time - class SerialBuffer: def __init__(self, dev, filename, prefix, timeout = None): self.filename = filename @@ -36,15 +35,17 @@ class SerialBuffer: if dev: self.f = open(filename, "wb+") - self.serial = serial.Serial(dev, 115200, timeout=timeout if timeout else 10) + self.serial = serial.Serial(dev, 115200, timeout=timeout) else: self.f = open(filename, "rb") + self.serial = None self.byte_queue = queue.Queue() self.line_queue = queue.Queue() self.prefix = prefix self.timeout = timeout self.sentinel = object() + self.closing = False if self.dev: self.read_thread = threading.Thread( @@ -58,24 +59,31 @@ class SerialBuffer: target=self.serial_lines_thread_loop, daemon=True) self.lines_thread.start() + def close(self): + self.closing = True + if self.serial: + self.serial.cancel_read() + self.read_thread.join() + self.lines_thread.join() + if self.serial: + self.serial.close() + # Thread that just reads the bytes from the serial device to try to keep from # buffer overflowing it. If nothing is received in 1 minute, it finalizes. def serial_read_thread_loop(self): greet = "Serial thread reading from %s\n" % self.dev self.byte_queue.put(greet.encode()) - while True: + while not self.closing: try: b = self.serial.read() - if len(b) > 0: - self.byte_queue.put(b) - elif self.timeout: - self.byte_queue.put(self.sentinel) + if len(b) == 0: break + self.byte_queue.put(b) except Exception as err: print(self.prefix + str(err)) - self.byte_queue.put(self.sentinel) break + self.byte_queue.put(self.sentinel) # Thread that just reads the bytes from the file of serial output that some # other process is appending to. @@ -83,12 +91,13 @@ class SerialBuffer: greet = "Serial thread reading from %s\n" % self.filename self.byte_queue.put(greet.encode()) - while True: + while not self.closing: line = self.f.readline() if line: self.byte_queue.put(line) else: time.sleep(0.1) + self.byte_queue.put(self.sentinel) # Thread that processes the stream of bytes to 1) log to stdout, 2) log to # file, 3) add to the queue of lines to be read by program logic diff --git a/lib/mesa/.gitlab-ci/build/gitlab-ci.yml b/lib/mesa/.gitlab-ci/build/gitlab-ci.yml new file mode 100644 index 000000000..e49f62e11 --- /dev/null +++ b/lib/mesa/.gitlab-ci/build/gitlab-ci.yml @@ -0,0 +1,525 @@ +# Shared between windows and Linux +.build-common: + extends: .ci-run-policy + # Cancel job if a newer commit is pushed to the same branch + interruptible: true + artifacts: + name: "mesa_${CI_JOB_NAME}" + when: always + paths: + - _build/meson-logs/*.txt + - _build/meson-logs/strace + - shader-db + +# Just Linux +.build-linux: + extends: .build-common + variables: + CCACHE_COMPILERCHECK: "content" + CCACHE_COMPRESS: "true" + CCACHE_DIR: /cache/mesa/ccache + # Use ccache transparently, and print stats before/after + before_script: + - !reference [default, before_script] + - export PATH="/usr/lib/ccache:$PATH" + - export CCACHE_BASEDIR="$PWD" + - echo -e "\e[0Ksection_start:$(date +%s):ccache_before[collapsed=true]\r\e[0Kccache stats before build" + - ccache --show-stats + - echo -e "\e[0Ksection_end:$(date +%s):ccache_before\r\e[0K" + after_script: + - echo -e "\e[0Ksection_start:$(date +%s):ccache_after[collapsed=true]\r\e[0Kccache stats after build" + - ccache --show-stats + - echo -e "\e[0Ksection_end:$(date +%s):ccache_after\r\e[0K" + - !reference [default, after_script] + +.build-windows: + extends: .build-common + tags: + - windows + - docker + - "1809" + - mesa + cache: + key: ${CI_JOB_NAME} + paths: + - subprojects/packagecache + +.meson-build: + extends: + - .build-linux + - .use-debian/x86_build + stage: build-x86_64 + variables: + LLVM_VERSION: 11 + script: + - .gitlab-ci/meson/build.sh + +debian-testing: + extends: + - .meson-build + - .ci-deqp-artifacts + variables: + UNWIND: "enabled" + DRI_LOADERS: > + -D glx=dri + -D gbm=enabled + -D egl=enabled + -D platforms=x11 + GALLIUM_ST: > + -D dri3=enabled + -D gallium-va=enabled + GALLIUM_DRIVERS: "swrast,virgl,radeonsi,zink,crocus,iris,i915" + VULKAN_DRIVERS: "swrast,amd,intel" + BUILDTYPE: "debugoptimized" + EXTRA_OPTION: > + -D valgrind=false + MINIO_ARTIFACT_NAME: mesa-amd64 + script: + - .gitlab-ci/lava/lava-pytest.sh + - .gitlab-ci/meson/build.sh + - .gitlab-ci/prepare-artifacts.sh + artifacts: + reports: + junit: artifacts/ci_scripts_report.xml + +debian-testing-asan: + extends: + - debian-testing + variables: + C_ARGS: > + -Wno-error=stringop-truncation + EXTRA_OPTION: > + -D b_sanitize=address + -D valgrind=false + -D tools=dlclose-skip + MINIO_ARTIFACT_NAME: "" + ARTIFACTS_DEBUG_SYMBOLS: 1 + +debian-testing-msan: + extends: + - debian-clang + variables: + # l_undef is incompatible with msan + EXTRA_OPTION: + -D b_sanitize=memory + -D b_lundef=false + MINIO_ARTIFACT_NAME: "" + ARTIFACTS_DEBUG_SYMBOLS: 1 + # Don't run all the tests yet: + # GLSL has some issues in sexpression reading. + # gtest has issues in its test initialization. + MESON_TEST_ARGS: "--suite glcpp --suite gallium --suite format" + # Freedreno dropped because freedreno tools fail at msan. + GALLIUM_DRIVERS: "iris,nouveau,kmsro,r300,r600,swrast,svga,v3d,vc4,virgl,etnaviv,panfrost,lima,zink,radeonsi,tegra,d3d12,crocus" + VULKAN_DRIVERS: intel,amd,broadcom,virtio-experimental + +debian-clover-testing: + extends: + - .meson-build + - .ci-deqp-artifacts + variables: + UNWIND: "enabled" + DRI_LOADERS: > + -D glx=disabled + -D egl=disabled + -D gbm=disabled + GALLIUM_ST: > + -D gallium-opencl=icd + -D opencl-spirv=true + GALLIUM_DRIVERS: "swrast" + BUILDTYPE: "debugoptimized" + EXTRA_OPTION: > + -D valgrind=false + script: + - .gitlab-ci/meson/build.sh + - .gitlab-ci/prepare-artifacts.sh + +debian-gallium: + extends: .meson-build + variables: + UNWIND: "enabled" + DRI_LOADERS: > + -D glx=dri + -D gbm=enabled + -D egl=enabled + -D platforms=x11,wayland + GALLIUM_ST: > + -D dri3=enabled + -D gallium-extra-hud=true + -D gallium-vdpau=enabled + -D gallium-xvmc=enabled + -D gallium-omx=bellagio + -D gallium-va=enabled + -D gallium-xa=enabled + -D gallium-nine=true + -D gallium-opencl=disabled + GALLIUM_DRIVERS: "iris,nouveau,kmsro,r300,r600,freedreno,swrast,svga,v3d,vc4,virgl,etnaviv,panfrost,lima,zink,d3d12,asahi,crocus" + VULKAN_DRIVERS: swrast + EXTRA_OPTION: > + -D osmesa=true + -D tools=drm-shim,etnaviv,freedreno,glsl,intel,intel-ui,nir,nouveau,xvmc,lima,panfrost,asahi + script: + - .gitlab-ci/meson/build.sh + - .gitlab-ci/run-shader-db.sh + +# Test a release build with -Werror so new warnings don't sneak in. +debian-release: + extends: .meson-build + variables: + UNWIND: "enabled" + DRI_LOADERS: > + -D glx=dri + -D gbm=enabled + -D egl=enabled + -D platforms=x11,wayland + GALLIUM_ST: > + -D dri3=enabled + -D gallium-extra-hud=true + -D gallium-vdpau=enabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=enabled + -D gallium-xa=enabled + -D gallium-nine=false + -D gallium-opencl=disabled + -D llvm=enabled + GALLIUM_DRIVERS: "i915,iris,nouveau,kmsro,freedreno,r300,svga,swrast,v3d,vc4,virgl,etnaviv,panfrost,lima,zink,d3d12,crocus" + VULKAN_DRIVERS: "amd,imagination-experimental" + BUILDTYPE: "release" + EXTRA_OPTION: > + -D osmesa=true + -D tools=all + -D intel-clc=enabled + -D imagination-srv=true + script: + - .gitlab-ci/meson/build.sh + +fedora-release: + extends: + - .meson-build + - .use-fedora/x86_build + variables: + BUILDTYPE: "release" + C_ARGS: > + -Wno-error=array-bounds + -Wno-error=maybe-uninitialized + -Wno-error=stringop-overread + -Wno-error=uninitialized + CPP_ARGS: > + -Wno-error=array-bounds + DRI_LOADERS: > + -D glx=dri + -D gbm=enabled + -D egl=enabled + -D glvnd=true + -D platforms=x11,wayland + EXTRA_OPTION: > + -D osmesa=true + -D selinux=true + -D tools=drm-shim,etnaviv,freedreno,glsl,intel,nir,nouveau,lima,panfrost,imagination + -D intel-clc=enabled + -D imagination-srv=true + GALLIUM_DRIVERS: "crocus,etnaviv,freedreno,iris,kmsro,lima,nouveau,panfrost,r300,r600,radeonsi,svga,swrast,tegra,v3d,vc4,virgl,zink" + GALLIUM_ST: > + -D dri3=enabled + -D gallium-extra-hud=true + -D gallium-vdpau=enabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=enabled + -D gallium-xa=enabled + -D gallium-nine=false + -D gallium-opencl=icd + -D gles1=disabled + -D gles2=enabled + -D llvm=enabled + -D microsoft-clc=disabled + -D shared-llvm=enabled + -D vulkan-device-select-layer=true + LLVM_VERSION: "" + UNWIND: "disabled" + VULKAN_DRIVERS: "amd,broadcom,freedreno,intel,imagination-experimental" + script: + - .gitlab-ci/meson/build.sh + +debian-android: + extends: + - .meson-cross + - .use-debian/android_build + variables: + UNWIND: "disabled" + C_ARGS: > + -Wno-error=asm-operand-widths + -Wno-error=constant-conversion + -Wno-error=enum-conversion + -Wno-error=initializer-overrides + -Wno-error=missing-braces + -Wno-error=sometimes-uninitialized + -Wno-error=unused-function + CPP_ARGS: > + -Wno-error=deprecated-declarations + DRI_LOADERS: > + -D glx=disabled + -D gbm=disabled + -D egl=enabled + -D platforms=android + EXTRA_OPTION: > + -D android-stub=true + -D llvm=disabled + -D platform-sdk-version=29 + -D valgrind=false + GALLIUM_ST: > + -D dri3=disabled + -D gallium-vdpau=disabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=disabled + -D gallium-xa=disabled + -D gallium-nine=false + -D gallium-opencl=disabled + LLVM_VERSION: "" + PKG_CONFIG_LIBDIR: "/disable/non/android/system/pc/files" + script: + - PKG_CONFIG_PATH=/usr/local/lib/aarch64-linux-android/pkgconfig/:/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/sysroot/usr/lib/aarch64-linux-android/pkgconfig/ CROSS=aarch64-linux-android GALLIUM_DRIVERS=etnaviv,freedreno,lima,panfrost,vc4,v3d VULKAN_DRIVERS=freedreno,broadcom,virtio-experimental .gitlab-ci/meson/build.sh + # x86_64 build: + # Can't do Intel because gen_decoder.c currently requires libexpat, which + # is not a dependency that AOSP wants to accept. Can't do Radeon Gallium + # drivers because they requires LLVM, which we don't have an Android build + # of. + - PKG_CONFIG_PATH=/usr/local/lib/x86_64-linux-android/pkgconfig/:/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/sysroot/usr/lib/x86_64-linux-android/pkgconfig/ CROSS=x86_64-linux-android GALLIUM_DRIVERS=iris VULKAN_DRIVERS=amd,intel .gitlab-ci/meson/build.sh + +.meson-cross: + extends: + - .meson-build + stage: build-misc + variables: + UNWIND: "disabled" + DRI_LOADERS: > + -D glx=dri + -D gbm=enabled + -D egl=enabled + -D platforms=x11 + -D osmesa=false + GALLIUM_ST: > + -D dri3=enabled + -D gallium-vdpau=disabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=disabled + -D gallium-xa=disabled + -D gallium-nine=false + +.meson-arm: + extends: + - .meson-cross + - .use-debian/arm_build + needs: + - debian/arm_build + variables: + VULKAN_DRIVERS: freedreno,broadcom + GALLIUM_DRIVERS: "etnaviv,freedreno,kmsro,lima,nouveau,panfrost,swrast,tegra,v3d,vc4" + BUILDTYPE: "debugoptimized" + tags: + - aarch64 + +debian-armhf: + extends: + - .meson-arm + - .ci-deqp-artifacts + variables: + CROSS: armhf + EXTRA_OPTION: > + -D llvm=disabled + -D valgrind=false + MINIO_ARTIFACT_NAME: mesa-armhf + script: + - .gitlab-ci/meson/build.sh + - .gitlab-ci/prepare-artifacts.sh + +debian-arm64: + extends: + - .meson-arm + - .ci-deqp-artifacts + variables: + VULKAN_DRIVERS: "freedreno,broadcom,panfrost,imagination-experimental" + EXTRA_OPTION: > + -D llvm=disabled + -D valgrind=false + -D imagination-srv=true + MINIO_ARTIFACT_NAME: mesa-arm64 + script: + - .gitlab-ci/meson/build.sh + - .gitlab-ci/prepare-artifacts.sh + +debian-arm64-asan: + extends: + - debian-arm64 + variables: + C_ARGS: > + -Wno-error=stringop-truncation + EXTRA_OPTION: > + -D llvm=disabled + -D b_sanitize=address + -D valgrind=false + -D tools=dlclose-skip + ARTIFACTS_DEBUG_SYMBOLS: 1 + MINIO_ARTIFACT_NAME: mesa-arm64-asan + MESON_TEST_ARGS: "--no-suite mesa:compiler" + +debian-arm64-build-test: + extends: + - .meson-arm + - .ci-deqp-artifacts + variables: + VULKAN_DRIVERS: "amd" + EXTRA_OPTION: > + -Dtools=panfrost,imagination + script: + - .gitlab-ci/meson/build.sh + +debian-clang: + extends: .meson-build + variables: + UNWIND: "enabled" + C_ARGS: > + -Wno-error=constant-conversion + -Wno-error=enum-conversion + -Wno-error=implicit-const-int-float-conversion + -Wno-error=initializer-overrides + -Wno-error=sometimes-uninitialized + -Wno-error=unused-function + CPP_ARGS: > + -Wno-error=c99-designator + -Wno-error=deprecated-declarations + -Wno-error=implicit-const-int-float-conversion + -Wno-error=missing-braces + -Wno-error=overloaded-virtual + -Wno-error=tautological-constant-out-of-range-compare + -Wno-error=unused-const-variable + -Wno-error=unused-private-field + DRI_LOADERS: > + -D glvnd=true + GALLIUM_DRIVERS: "iris,nouveau,kmsro,r300,r600,freedreno,swrast,svga,v3d,vc4,virgl,etnaviv,panfrost,lima,zink,radeonsi,tegra,d3d12,crocus,i915,asahi" + VULKAN_DRIVERS: intel,amd,freedreno,broadcom,virtio-experimental,swrast,panfrost,imagination-experimental + EXTRA_OPTIONS: + -D imagination-srv=true + CC: clang + CXX: clang++ + +windows-vs2019: + extends: + - .build-windows + - .use-windows_build_vs2019 + - .windows-build-rules + stage: build-misc + script: + - . .\.gitlab-ci\windows\mesa_build.ps1 + artifacts: + paths: + - _build/meson-logs/*.txt + - _install/ + +debian-clover: + extends: .meson-build + variables: + UNWIND: "enabled" + DRI_LOADERS: > + -D glx=disabled + -D egl=disabled + -D gbm=disabled + GALLIUM_DRIVERS: "r600,radeonsi" + GALLIUM_ST: > + -D dri3=disabled + -D gallium-vdpau=disabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=disabled + -D gallium-xa=disabled + -D gallium-nine=false + -D gallium-opencl=icd + EXTRA_OPTION: > + -D valgrind=false + script: + - LLVM_VERSION=9 GALLIUM_DRIVERS=r600,swrast .gitlab-ci/meson/build.sh + - .gitlab-ci/meson/build.sh + +debian-vulkan: + extends: .meson-build + variables: + UNWIND: "disabled" + DRI_LOADERS: > + -D glx=disabled + -D gbm=disabled + -D egl=disabled + -D platforms=x11,wayland + -D osmesa=false + GALLIUM_ST: > + -D dri3=enabled + -D gallium-vdpau=disabled + -D gallium-xvmc=disabled + -D gallium-omx=disabled + -D gallium-va=disabled + -D gallium-xa=disabled + -D gallium-nine=false + -D gallium-opencl=disabled + -D b_sanitize=undefined + -D c_args=-fno-sanitize-recover=all + -D cpp_args=-fno-sanitize-recover=all + UBSAN_OPTIONS: "print_stacktrace=1" + VULKAN_DRIVERS: intel,amd,freedreno,broadcom,virtio-experimental,imagination-experimental + EXTRA_OPTION: > + -D vulkan-layers=device-select,overlay + -D build-aco-tests=true + -D intel-clc=enabled + -D imagination-srv=true + +debian-i386: + extends: + - .meson-cross + - .use-debian/i386_build + variables: + CROSS: i386 + VULKAN_DRIVERS: intel,amd,swrast,virtio-experimental + GALLIUM_DRIVERS: "iris,nouveau,r300,r600,radeonsi,swrast,virgl,zink,crocus" + EXTRA_OPTION: > + -D vulkan-layers=device-select,overlay + +debian-s390x: + extends: + - debian-ppc64el + - .use-debian/s390x_build + - .s390x-rules + tags: + - kvm + variables: + CROSS: s390x + GALLIUM_DRIVERS: "swrast,zink" + # The lp_test_blend test times out with LLVM 11 + LLVM_VERSION: 9 + VULKAN_DRIVERS: "swrast" + +debian-ppc64el: + extends: + - .meson-cross + - .use-debian/ppc64el_build + - .ppc64el-rules + variables: + CROSS: ppc64el + GALLIUM_DRIVERS: "nouveau,radeonsi,swrast,virgl,zink" + VULKAN_DRIVERS: "amd,swrast" + +debian-mingw32-x86_64: + extends: .meson-build + stage: build-misc + variables: + UNWIND: "disabled" + C_ARGS: > + -Wno-error=format + -Wno-error=format-extra-args + CPP_ARGS: $C_ARGS + GALLIUM_DRIVERS: "swrast" + EXTRA_OPTION: > + -Dllvm=disabled + -Dzlib=disabled + -Dosmesa=true + --cross-file=.gitlab-ci/x86_64-w64-mingw32 diff --git a/lib/mesa/.gitlab-ci/common/generate-env.sh b/lib/mesa/.gitlab-ci/common/generate-env.sh index 05376d4a7..885826b2e 100755 --- a/lib/mesa/.gitlab-ci/common/generate-env.sh +++ b/lib/mesa/.gitlab-ci/common/generate-env.sh @@ -5,8 +5,11 @@ for var in \ BASE_SYSTEM_FORK_HOST_PREFIX \ BASE_SYSTEM_MAINLINE_HOST_PREFIX \ CI_COMMIT_BRANCH \ + CI_COMMIT_REF_NAME \ CI_COMMIT_TITLE \ CI_JOB_ID \ + CI_JOB_JWT_FILE \ + CI_JOB_NAME \ CI_JOB_URL \ CI_MERGE_REQUEST_SOURCE_BRANCH_NAME \ CI_MERGE_REQUEST_TITLE \ @@ -14,12 +17,16 @@ for var in \ CI_NODE_TOTAL \ CI_PAGES_DOMAIN \ CI_PIPELINE_ID \ + CI_PIPELINE_URL \ CI_PROJECT_DIR \ CI_PROJECT_NAME \ CI_PROJECT_PATH \ CI_PROJECT_ROOT_NAMESPACE \ CI_RUNNER_DESCRIPTION \ CI_SERVER_URL \ + CROSVM_GALLIUM_DRIVER \ + CROSVM_GPU_ARGS \ + DEQP_BIN_DIR \ DEQP_CASELIST_FILTER \ DEQP_CASELIST_INV_FILTER \ DEQP_CONFIG \ @@ -29,6 +36,7 @@ for var in \ DEQP_RESULTS_DIR \ DEQP_RUNNER_OPTIONS \ DEQP_SUITE \ + DEQP_TEMP_DIR \ DEQP_VARIANT \ DEQP_VER \ DEQP_WIDTH \ @@ -40,6 +48,9 @@ for var in \ FDO_UPSTREAM_REPO \ FD_MESA_DEBUG \ FLAKES_CHANNEL \ + FREEDRENO_HANGCHECK_MS \ + GALLIUM_DRIVER \ + GALLIVM_PERF \ GPU_VERSION \ GTEST \ GTEST_FAILS \ @@ -49,40 +60,56 @@ for var in \ GTEST_SKIPS \ HWCI_FREQ_MAX \ HWCI_KERNEL_MODULES \ + HWCI_KVM \ HWCI_START_XORG \ HWCI_TEST_SCRIPT \ IR3_SHADER_DEBUG \ JOB_ARTIFACTS_BASE \ JOB_RESULTS_PATH \ JOB_ROOTFS_OVERLAY_PATH \ + KERNEL_IMAGE_BASE_URL \ + KERNEL_IMAGE_NAME \ + LD_LIBRARY_PATH \ + LP_NUM_THREADS \ + MESA_BASE_TAG \ MESA_BUILD_PATH \ - MESA_GL_VERSION_OVERRIDE \ - MESA_GLSL_VERSION_OVERRIDE \ + MESA_DEBUG \ MESA_GLES_VERSION_OVERRIDE \ + MESA_GLSL_VERSION_OVERRIDE \ + MESA_GL_VERSION_OVERRIDE \ + MESA_IMAGE \ + MESA_IMAGE_PATH \ + MESA_IMAGE_TAG \ + MESA_TEMPLATES_COMMIT \ MESA_VK_IGNORE_CONFORMANCE_WARNING \ + MESA_SPIRV_LOG_LEVEL \ MINIO_HOST \ - NIR_VALIDATE \ + MINIO_RESULTS_UPLOAD \ + NIR_DEBUG \ PAN_I_WANT_A_BROKEN_VULKAN_DRIVER \ PAN_MESA_DEBUG \ PIGLIT_FRACTION \ - PIGLIT_JUNIT_RESULTS \ PIGLIT_NO_WINDOW \ PIGLIT_OPTIONS \ PIGLIT_PLATFORM \ PIGLIT_PROFILES \ PIGLIT_REPLAY_ARTIFACTS_BASE_URL \ - PIGLIT_REPLAY_SUBCOMMAND \ PIGLIT_REPLAY_DESCRIPTION_FILE \ PIGLIT_REPLAY_DEVICE_NAME \ PIGLIT_REPLAY_EXTRA_ARGS \ + PIGLIT_REPLAY_LOOP_TIMES \ PIGLIT_REPLAY_REFERENCE_IMAGES_BASE \ - PIGLIT_REPLAY_UPLOAD_TO_MINIO \ + PIGLIT_REPLAY_SUBCOMMAND \ PIGLIT_RESULTS \ PIGLIT_TESTS \ PIPELINE_ARTIFACTS_BASE \ + SKQP_ASSETS_DIR \ + SKQP_BACKENDS \ TU_DEBUG \ + VIRGL_HOST_API \ VK_CPU \ VK_DRIVER \ + VK_ICD_FILENAMES \ ; do if [ -n "${!var+x}" ]; then echo "export $var=${!var@Q}" diff --git a/lib/mesa/.gitlab-ci/common/init-stage1.sh b/lib/mesa/.gitlab-ci/common/init-stage1.sh index 648c37a2f..3b3317a2c 100755 --- a/lib/mesa/.gitlab-ci/common/init-stage1.sh +++ b/lib/mesa/.gitlab-ci/common/init-stage1.sh @@ -9,6 +9,7 @@ cd / mount -t proc none /proc mount -t sysfs none /sys +mount -t debugfs none /sys/kernel/debug mount -t devtmpfs none /dev || echo possibly already mounted mkdir -p /dev/pts mount -t devpts devpts /dev/pts diff --git a/lib/mesa/.gitlab-ci/common/init-stage2.sh b/lib/mesa/.gitlab-ci/common/init-stage2.sh index 53b904156..6aebc2231 100755 --- a/lib/mesa/.gitlab-ci/common/init-stage2.sh +++ b/lib/mesa/.gitlab-ci/common/init-stage2.sh @@ -8,7 +8,31 @@ set -ex # Set up any devices required by the jobs -[ -z "$HWCI_KERNEL_MODULES" ] || (echo -n $HWCI_KERNEL_MODULES | xargs -d, -n1 /usr/sbin/modprobe) +[ -z "$HWCI_KERNEL_MODULES" ] || { + echo -n $HWCI_KERNEL_MODULES | xargs -d, -n1 /usr/sbin/modprobe +} + +# +# Load the KVM module specific to the detected CPU virtualization extensions: +# - vmx for Intel VT +# - svm for AMD-V +# +# Additionally, download the kernel image to boot the VM via HWCI_TEST_SCRIPT. +# +if [ "$HWCI_KVM" = "true" ]; then + unset KVM_KERNEL_MODULE + grep -qs '\bvmx\b' /proc/cpuinfo && KVM_KERNEL_MODULE=kvm_intel || { + grep -qs '\bsvm\b' /proc/cpuinfo && KVM_KERNEL_MODULE=kvm_amd + } + + [ -z "${KVM_KERNEL_MODULE}" ] && \ + echo "WARNING: Failed to detect CPU virtualization extensions" || \ + modprobe ${KVM_KERNEL_MODULE} + + mkdir -p /lava-files + wget -S --progress=dot:giga -O /lava-files/${KERNEL_IMAGE_NAME} \ + "${KERNEL_IMAGE_BASE_URL}/${KERNEL_IMAGE_NAME}" +fi # Fix prefix confusion: the build installs to $CI_PROJECT_DIR, but we expect # it in /install @@ -36,6 +60,16 @@ if [ "$HWCI_FREQ_MAX" = "true" ]; then # Disable GPU runtime power management GPU_AUTOSUSPEND=`find /sys/devices -name autosuspend_delay_ms | grep gpu | head -1` test -z "$GPU_AUTOSUSPEND" || echo -1 > $GPU_AUTOSUSPEND || true + + # Lock Intel GPU frequency to 70% of the maximum allowed by hardware + # and enable throttling detection & reporting. + ./intel-gpu-freq.sh -s 70% -g all -d +fi + +# Increase freedreno hangcheck timer because it's right at the edge of the +# spilling tests timing out (and some traces, too) +if [ -n "$FREEDRENO_HANGCHECK_MS" ]; then + echo $FREEDRENO_HANGCHECK_MS | tee -a /sys/kernel/debug/dri/128/hangcheck_period_ms fi # Start a little daemon to capture the first devcoredump we encounter. (They @@ -61,18 +95,18 @@ if [ -n "$HWCI_START_XORG" ]; then export DISPLAY=:0 fi -RESULT=fail -if sh $HWCI_TEST_SCRIPT; then - RESULT=pass - rm -rf results/trace/$PIGLIT_REPLAY_DEVICE_NAME -fi +sh -c "$HWCI_TEST_SCRIPT" && RESULT=pass || RESULT=fail + +# Let's make sure the results are always stored in current working directory +mv -f ${CI_PROJECT_DIR}/results ./ 2>/dev/null || true + +[ "${RESULT}" = "fail" ] || rm -rf results/trace/$PIGLIT_REPLAY_DEVICE_NAME # upload artifacts -MINIO=$(cat /proc/cmdline | tr ' ' '\n' | grep minio_results | cut -d '=' -f 2 || true) -if [ -n "$MINIO" ]; then +if [ -n "$MINIO_RESULTS_UPLOAD" ]; then tar -czf results.tar.gz results/; - ci-fairy minio login "$CI_JOB_JWT"; - ci-fairy minio cp results.tar.gz minio://"$MINIO"/results.tar.gz; + ci-fairy minio login --token-file "${CI_JOB_JWT_FILE}"; + ci-fairy minio cp results.tar.gz minio://"$MINIO_RESULTS_UPLOAD"/results.tar.gz; fi echo "hwci: mesa: $RESULT" diff --git a/lib/mesa/.gitlab-ci/common/intel-gpu-freq.sh b/lib/mesa/.gitlab-ci/common/intel-gpu-freq.sh new file mode 100755 index 000000000..10a72eea7 --- /dev/null +++ b/lib/mesa/.gitlab-ci/common/intel-gpu-freq.sh @@ -0,0 +1,567 @@ +#!/bin/sh +# +# The Intel i915 GPU driver allows to change the minimum, maximum and boost +# frequencies in steps of 50 MHz via /sys/class/drm/card<n>/<freq_info>, +# where <n> is the DRM card index and <freq_info> one of the following: +# +# - gt_max_freq_mhz (enforced maximum freq) +# - gt_min_freq_mhz (enforced minimum freq) +# - gt_boost_freq_mhz (enforced boost freq) +# +# The hardware capabilities can be accessed via: +# +# - gt_RP0_freq_mhz (supported maximum freq) +# - gt_RPn_freq_mhz (supported minimum freq) +# - gt_RP1_freq_mhz (most efficient freq) +# +# The current frequency can be read from: +# - gt_act_freq_mhz (the actual GPU freq) +# - gt_cur_freq_mhz (the last requested freq) +# +# Copyright (C) 2022 Collabora Ltd. +# Author: Cristian Ciocaltea <cristian.ciocaltea@collabora.com> +# +# SPDX-License-Identifier: MIT +# + +# +# Constants +# +DRM_FREQ_SYSFS_PATTERN="/sys/class/drm/card%d/gt_%s_freq_mhz" +ENF_FREQ_INFO="max min boost" +CAP_FREQ_INFO="RP0 RPn RP1" +ACT_FREQ_INFO="act cur" +THROTT_DETECT_SLEEP_SEC=2 +THROTT_DETECT_PID_FILE_PATH=/tmp/thrott-detect.pid + +# +# Global variables. +# +unset INTEL_DRM_CARD_INDEX +unset GET_ACT_FREQ GET_ENF_FREQ GET_CAP_FREQ +unset SET_MIN_FREQ SET_MAX_FREQ +unset MONITOR_FREQ +unset DETECT_THROTT +unset DRY_RUN + +# +# Simple printf based stderr logger. +# +log() { + local msg_type=$1 + + shift + printf "%s: %s: " "${msg_type}" "${0##*/}" >&2 + printf "$@" >&2 + printf "\n" >&2 +} + +# +# Helper to print sysfs path for the given card index and freq info. +# +# arg1: Frequency info sysfs name, one of *_FREQ_INFO constants above +# arg2: Video card index, defaults to INTEL_DRM_CARD_INDEX +# +print_freq_sysfs_path() { + printf ${DRM_FREQ_SYSFS_PATTERN} "${2:-${INTEL_DRM_CARD_INDEX}}" "$1" +} + +# +# Helper to set INTEL_DRM_CARD_INDEX for the first identified Intel video card. +# +identify_intel_gpu() { + local i=0 vendor path + + while [ ${i} -lt 16 ]; do + [ -c "/dev/dri/card$i" ] || { + i=$((i + 1)) + continue + } + + path=$(print_freq_sysfs_path "" ${i}) + path=${path%/*}/device/vendor + + [ -r "${path}" ] && read vendor < "${path}" && \ + [ "${vendor}" = "0x8086" ] && INTEL_DRM_CARD_INDEX=$i && return 0 + + i=$((i + 1)) + done + + return 1 +} + +# +# Read the specified freq info from sysfs. +# +# arg1: Flag (y/n) to also enable printing the freq info. +# arg2...: Frequency info sysfs name(s), see *_FREQ_INFO constants above +# return: Global variable(s) FREQ_${arg} containing the requested information +# +read_freq_info() { + local var val path print=0 ret=0 + + [ "$1" = "y" ] && print=1 + shift + + while [ $# -gt 0 ]; do + var=FREQ_$1 + path=$(print_freq_sysfs_path "$1") + + [ -r ${path} ] && read ${var} < ${path} || { + log ERROR "Failed to read freq info from: %s" "${path}" + ret=1 + continue + } + + [ -n "${var}" ] || { + log ERROR "Got empty freq info from: %s" "${path}" + ret=1 + continue + } + + [ ${print} -eq 1 ] && { + eval val=\$${var} + printf "%6s: %4s MHz\n" "$1" "${val}" + } + + shift + done + + return ${ret} +} + +# +# Display requested info. +# +print_freq_info() { + local req_freq + + [ -n "${GET_CAP_FREQ}" ] && { + printf "* Hardware capabilities\n" + read_freq_info y ${CAP_FREQ_INFO} + printf "\n" + } + + [ -n "${GET_ENF_FREQ}" ] && { + printf "* Enforcements\n" + read_freq_info y ${ENF_FREQ_INFO} + printf "\n" + } + + [ -n "${GET_ACT_FREQ}" ] && { + printf "* Actual\n" + read_freq_info y ${ACT_FREQ_INFO} + printf "\n" + } +} + +# +# Helper to print frequency value as requested by user via '-s, --set' option. +# arg1: user requested freq value +# +compute_freq_set() { + local val + + case "$1" in + +) + val=${FREQ_RP0} + ;; + -) + val=${FREQ_RPn} + ;; + *%) + val=$((${1%?} * ${FREQ_RP0} / 100)) + # Adjust freq to comply with 50 MHz increments + val=$((val / 50 * 50)) + ;; + *[!0-9]*) + log ERROR "Cannot set freq to invalid value: %s" "$1" + return 1 + ;; + "") + log ERROR "Cannot set freq to unspecified value" + return 1 + ;; + *) + # Adjust freq to comply with 50 MHz increments + val=$(($1 / 50 * 50)) + ;; + esac + + printf "%s" "${val}" +} + +# +# Helper for set_freq(). +# +set_freq_max() { + log INFO "Setting GPU max freq to %s MHz" "${SET_MAX_FREQ}" + + read_freq_info n min || return $? + + [ ${SET_MAX_FREQ} -gt ${FREQ_RP0} ] && { + log ERROR "Cannot set GPU max freq (%s) to be greater than hw max freq (%s)" \ + "${SET_MAX_FREQ}" "${FREQ_RP0}" + return 1 + } + + [ ${SET_MAX_FREQ} -lt ${FREQ_RPn} ] && { + log ERROR "Cannot set GPU max freq (%s) to be less than hw min freq (%s)" \ + "${SET_MIN_FREQ}" "${FREQ_RPn}" + return 1 + } + + [ ${SET_MAX_FREQ} -lt ${FREQ_min} ] && { + log ERROR "Cannot set GPU max freq (%s) to be less than min freq (%s)" \ + "${SET_MAX_FREQ}" "${FREQ_min}" + return 1 + } + + [ -z "${DRY_RUN}" ] || return 0 + + printf "%s" ${SET_MAX_FREQ} | tee $(print_freq_sysfs_path max) \ + $(print_freq_sysfs_path boost) > /dev/null + [ $? -eq 0 ] || { + log ERROR "Failed to set GPU max frequency" + return 1 + } +} + +# +# Helper for set_freq(). +# +set_freq_min() { + log INFO "Setting GPU min freq to %s MHz" "${SET_MIN_FREQ}" + + read_freq_info n max || return $? + + [ ${SET_MIN_FREQ} -gt ${FREQ_max} ] && { + log ERROR "Cannot set GPU min freq (%s) to be greater than max freq (%s)" \ + "${SET_MIN_FREQ}" "${FREQ_max}" + return 1 + } + + [ ${SET_MIN_FREQ} -lt ${FREQ_RPn} ] && { + log ERROR "Cannot set GPU min freq (%s) to be less than hw min freq (%s)" \ + "${SET_MIN_FREQ}" "${FREQ_RPn}" + return 1 + } + + [ -z "${DRY_RUN}" ] || return 0 + + printf "%s" ${SET_MIN_FREQ} > $(print_freq_sysfs_path min) + [ $? -eq 0 ] || { + log ERROR "Failed to set GPU min frequency" + return 1 + } +} + +# +# Set min or max or both GPU frequencies to the user indicated values. +# +set_freq() { + # Get hw max & min frequencies + read_freq_info n RP0 RPn || return $? + + [ -z "${SET_MAX_FREQ}" ] || { + SET_MAX_FREQ=$(compute_freq_set "${SET_MAX_FREQ}") + [ -z "${SET_MAX_FREQ}" ] && return 1 + } + + [ -z "${SET_MIN_FREQ}" ] || { + SET_MIN_FREQ=$(compute_freq_set "${SET_MIN_FREQ}") + [ -z "${SET_MIN_FREQ}" ] && return 1 + } + + # + # Ensure correct operation order, to avoid setting min freq + # to a value which is larger than max freq. + # + # E.g.: + # crt_min=crt_max=600; new_min=new_max=700 + # > operation order: max=700; min=700 + # + # crt_min=crt_max=600; new_min=new_max=500 + # > operation order: min=500; max=500 + # + if [ -n "${SET_MAX_FREQ}" ] && [ -n "${SET_MIN_FREQ}" ]; then + [ ${SET_MAX_FREQ} -lt ${SET_MIN_FREQ} ] && { + log ERROR "Cannot set GPU max freq to be less than min freq" + return 1 + } + + read_freq_info n min || return $? + + if [ ${SET_MAX_FREQ} -lt ${FREQ_min} ]; then + set_freq_min || return $? + set_freq_max + else + set_freq_max || return $? + set_freq_min + fi + elif [ -n "${SET_MAX_FREQ}" ]; then + set_freq_max + elif [ -n "${SET_MIN_FREQ}" ]; then + set_freq_min + else + log "Unexpected call to set_freq()" + return 1 + fi +} + +# +# Helper for detect_throttling(). +# +get_thrott_detect_pid() { + [ -e ${THROTT_DETECT_PID_FILE_PATH} ] || return 0 + + local pid + read pid < ${THROTT_DETECT_PID_FILE_PATH} || { + log ERROR "Failed to read pid from: %s" "${THROTT_DETECT_PID_FILE_PATH}" + return 1 + } + + local proc_path=/proc/${pid:-invalid}/cmdline + [ -r ${proc_path} ] && grep -qs "${0##*/}" ${proc_path} && { + printf "%s" "${pid}" + return 0 + } + + # Remove orphaned PID file + rm -rf ${THROTT_DETECT_PID_FILE_PATH} + return 1 +} + +# +# Control detection and reporting of GPU throttling events. +# arg1: start - run throttle detector in background +# stop - stop throttle detector process, if any +# status - verify if throttle detector is running +# +detect_throttling() { + local pid + pid=$(get_thrott_detect_pid) + + case "$1" in + status) + printf "Throttling detector is " + [ -z "${pid}" ] && printf "not running\n" && return 0 + printf "running (pid=%s)\n" ${pid} + ;; + + stop) + [ -z "${pid}" ] && return 0 + + log INFO "Stopping throttling detector (pid=%s)" "${pid}" + kill ${pid}; sleep 1; kill -0 ${pid} 2>/dev/null && kill -9 ${pid} + rm -rf ${THROTT_DETECT_PID_FILE_PATH} + ;; + + start) + [ -n "${pid}" ] && { + log WARN "Throttling detector is already running (pid=%s)" ${pid} + return 0 + } + + ( + read_freq_info n RPn || exit $? + + while true; do + sleep ${THROTT_DETECT_SLEEP_SEC} + read_freq_info n act min cur || exit $? + + # + # The throttling seems to occur when act freq goes below min. + # However, it's necessary to exclude the idle states, where + # act freq normally reaches RPn and cur goes below min. + # + [ ${FREQ_act} -lt ${FREQ_min} ] && \ + [ ${FREQ_act} -gt ${FREQ_RPn} ] && \ + [ ${FREQ_cur} -ge ${FREQ_min} ] && \ + printf "GPU throttling detected: act=%s min=%s cur=%s RPn=%s\n" \ + ${FREQ_act} ${FREQ_min} ${FREQ_cur} ${FREQ_RPn} + done + ) & + + pid=$! + log INFO "Started GPU throttling detector (pid=%s)" ${pid} + + printf "%s\n" ${pid} > ${THROTT_DETECT_PID_FILE_PATH} || \ + log WARN "Failed to write throttle detector PID file" + ;; + esac +} + +# +# Show help message. +# +print_usage() { + cat <<EOF +Usage: ${0##*/} [OPTION]... + +A script to manage Intel GPU frequencies. Can be used for debugging performance +problems or trying to obtain a stable frequency while benchmarking. + +Note Intel GPUs only accept specific frequencies, usually multiples of 50 MHz. + +Options: + -g, --get [act|enf|cap|all] + Get frequency information: active (default), enforced, + hardware capabilities or all of them. + + -s, --set [{min|max}=]{FREQUENCY[%]|+|-} + Set min or max frequency to the given value (MHz). + Append '%' to interpret FREQUENCY as % of hw max. + Use '+' or '-' to set frequency to hardware max or min. + Omit min/max prefix to set both frequencies. + + -r, --reset Reset frequencies to hardware defaults. + + -m, --monitor [act|enf|cap|all] + Monitor the indicated frequencies via 'watch' utility. + See '-g, --get' option for more details. + + -d|--detect-thrott [start|stop|status] + Start (default operation) the throttling detector + as a background process. Use 'stop' or 'status' to + terminate the detector process or verify its status. + + --dry-run See what the script will do without applying any + frequency changes. + + -h, --help Display this help text and exit. +EOF +} + +# +# Parse user input for '-g, --get' option. +# Returns 0 if a value has been provided, otherwise 1. +# +parse_option_get() { + local ret=0 + + case "$1" in + act) GET_ACT_FREQ=1;; + enf) GET_ENF_FREQ=1;; + cap) GET_CAP_FREQ=1;; + all) GET_ACT_FREQ=1; GET_ENF_FREQ=1; GET_CAP_FREQ=1;; + -*|"") + # No value provided, using default. + GET_ACT_FREQ=1 + ret=1 + ;; + *) + print_usage + exit 1 + ;; + esac + + return ${ret} +} + +# +# Validate user input for '-s, --set' option. +# +validate_option_set() { + case "$1" in + +|-|[0-9]%|[0-9][0-9]%) + return 0 + ;; + *[!0-9]*|"") + print_usage + exit 1 + ;; + esac +} + +# +# Parse script arguments. +# +[ $# -eq 0 ] && { print_usage; exit 1; } + +while [ $# -gt 0 ]; do + case "$1" in + -g|--get) + parse_option_get "$2" && shift + ;; + + -s|--set) + shift + case "$1" in + min=*) + SET_MIN_FREQ=${1#min=} + validate_option_set "${SET_MIN_FREQ}" + ;; + max=*) + SET_MAX_FREQ=${1#max=} + validate_option_set "${SET_MAX_FREQ}" + ;; + *) + SET_MIN_FREQ=$1 + validate_option_set "${SET_MIN_FREQ}" + SET_MAX_FREQ=${SET_MIN_FREQ} + ;; + esac + ;; + + -r|--reset) + RESET_FREQ=1 + SET_MIN_FREQ="-" + SET_MAX_FREQ="+" + ;; + + -m|--monitor) + MONITOR_FREQ=act + parse_option_get "$2" && MONITOR_FREQ=$2 && shift + ;; + + -d|--detect-thrott) + DETECT_THROTT=start + case "$2" in + start|stop|status) + DETECT_THROTT=$2 + shift + ;; + esac + ;; + + --dry-run) + DRY_RUN=1 + ;; + + -h|--help) + print_usage + exit 0 + ;; + + *) + print_usage + exit 1 + ;; + esac + + shift +done + +# +# Main +# +RET=0 + +identify_intel_gpu || { + log INFO "No Intel GPU detected" + exit 0 +} + +[ -n "${SET_MIN_FREQ}${SET_MAX_FREQ}" ] && { set_freq || RET=$?; } +print_freq_info + +[ -n "${DETECT_THROTT}" ] && detect_throttling ${DETECT_THROTT} + +[ -n "${MONITOR_FREQ}" ] && { + log INFO "Entering frequency monitoring mode" + sleep 2 + exec watch -d -n 1 "$0" -g "${MONITOR_FREQ}" +} + +exit ${RET} diff --git a/lib/mesa/.gitlab-ci/container/arm64.config b/lib/mesa/.gitlab-ci/container/arm64.config index 623084bb8..5ce3715ae 100644 --- a/lib/mesa/.gitlab-ci/container/arm64.config +++ b/lib/mesa/.gitlab-ci/container/arm64.config @@ -14,6 +14,7 @@ CONFIG_DRM_ROCKCHIP=y CONFIG_DRM_PANFROST=y CONFIG_DRM_LIMA=y CONFIG_DRM_PANEL_SIMPLE=y +CONFIG_DRM_PANEL_EDP=y CONFIG_DRM_MSM=y CONFIG_DRM_I2C_ADV7511=y CONFIG_PWM_CROS_EC=y @@ -35,6 +36,7 @@ CONFIG_TYPEC_TCPM=y # For CONFIG_QCOM_LMH CONFIG_OF=y +CONFIG_QCOM_COMMAND_DB=y CONFIG_QCOM_RPMHPD=y CONFIG_QCOM_RPMPD=y CONFIG_SDM_GPUCC_845=y @@ -155,3 +157,16 @@ CONFIG_HW_RANDOM_MTK=y CONFIG_MTK_DEVAPC=y CONFIG_PWM_MTK_DISP=y CONFIG_MTK_CMDQ=y + +# For nouveau. Note that DRM must be a module so that it's loaded after NFS is up to provide the firmware. +CONFIG_ARCH_TEGRA=y +CONFIG_DRM_NOUVEAU=m +CONFIG_DRM_TEGRA=m +CONFIG_R8169=y +CONFIG_STAGING=y +CONFIG_DRM_TEGRA_STAGING=y +CONFIG_TEGRA_HOST1X=y +CONFIG_ARM_TEGRA_DEVFREQ=y +CONFIG_TEGRA_SOCTHERM=y +CONFIG_DRM_TEGRA_DEBUG=y +CONFIG_PWM_TEGRA=y diff --git a/lib/mesa/.gitlab-ci/container/baremetal_build.sh b/lib/mesa/.gitlab-ci/container/baremetal_build.sh index 5752287a8..cd11d6342 100644 --- a/lib/mesa/.gitlab-ci/container/baremetal_build.sh +++ b/lib/mesa/.gitlab-ci/container/baremetal_build.sh @@ -25,7 +25,10 @@ if [[ $arch == "arm64" ]]; then wget ${ARTIFACTS_URL}/Image.gz wget ${ARTIFACTS_URL}/cheza-kernel - DEVICE_TREES="apq8016-sbc.dtb apq8096-db820c.dtb" + DEVICE_TREES="" + DEVICE_TREES="$DEVICE_TREES apq8016-sbc.dtb" + DEVICE_TREES="$DEVICE_TREES apq8096-db820c.dtb" + DEVICE_TREES="$DEVICE_TREES tegra210-p3450-0000.dtb" for DTB in $DEVICE_TREES; do wget ${ARTIFACTS_URL}/$DTB diff --git a/lib/mesa/.gitlab-ci/container/build-crosvm.sh b/lib/mesa/.gitlab-ci/container/build-crosvm.sh index 2fd582075..05172fa45 100644 --- a/lib/mesa/.gitlab-ci/container/build-crosvm.sh +++ b/lib/mesa/.gitlab-ci/container/build-crosvm.sh @@ -2,47 +2,25 @@ set -ex -# Pull down repositories that crosvm depends on to cros checkout-like locations. -CROS_ROOT=/ -THIRD_PARTY_ROOT=$CROS_ROOT/third_party -mkdir -p $THIRD_PARTY_ROOT -AOSP_EXTERNAL_ROOT=$CROS_ROOT/aosp/external -mkdir -p $AOSP_EXTERNAL_ROOT -PLATFORM2_ROOT=/platform2 - -PLATFORM2_COMMIT=72e56e66ccf3d2ea48f5686bd1f772379c43628b -git clone --single-branch --no-checkout https://chromium.googlesource.com/chromiumos/platform2 $PLATFORM2_ROOT -pushd $PLATFORM2_ROOT -git checkout $PLATFORM2_COMMIT -popd - -# minijail does not exist in upstream linux distros. -MINIJAIL_COMMIT=debdf5de5a0ae3b667bee2f8fb1f755b0b3f5a6c -git clone --single-branch --no-checkout https://android.googlesource.com/platform/external/minijail $AOSP_EXTERNAL_ROOT/minijail -pushd $AOSP_EXTERNAL_ROOT/minijail -git checkout $MINIJAIL_COMMIT -make -cp libminijail.so /usr/lib/x86_64-linux-gnu/ -popd - -# Pull the cras library for audio access. -ADHD_COMMIT=a1e0869b95c845c4fe6234a7b92fdfa6acc1e809 -git clone --single-branch --no-checkout https://chromium.googlesource.com/chromiumos/third_party/adhd $THIRD_PARTY_ROOT/adhd -pushd $THIRD_PARTY_ROOT/adhd -git checkout $ADHD_COMMIT -popd - -# Pull vHost (dataplane for virtio backend drivers) -VHOST_COMMIT=3091854e27242d09453004b011f701fa29c0b8e8 -git clone --single-branch --no-checkout https://chromium.googlesource.com/chromiumos/third_party/rust-vmm/vhost $THIRD_PARTY_ROOT/rust-vmm/vhost -pushd $THIRD_PARTY_ROOT/rust-vmm/vhost -git checkout $VHOST_COMMIT -popd +SCRIPT_DIR="$(pwd)" -CROSVM_VERSION=e42a43d880b0364b55559dbeade3af174f929001 -git clone --single-branch --no-checkout https://chromium.googlesource.com/chromiumos/platform/crosvm /platform/crosvm +CROSVM_VERSION=c7cd0e0114c8363b884ba56d8e12adee718dcc93 +git clone --single-branch -b main --no-checkout https://chromium.googlesource.com/chromiumos/platform/crosvm /platform/crosvm pushd /platform/crosvm git checkout "$CROSVM_VERSION" +git submodule update --init +# Apply all crosvm patches for Mesa CI +cat "$SCRIPT_DIR"/.gitlab-ci/container/build-crosvm_*.patch | + patch -p1 + +VIRGLRENDERER_VERSION=0564c9a0c2f584e004a7d4864aee3b8ec9692105 +rm -rf third_party/virglrenderer +git clone --single-branch -b master --no-checkout https://gitlab.freedesktop.org/virgl/virglrenderer.git third_party/virglrenderer +pushd third_party/virglrenderer +git checkout "$VIRGLRENDERER_VERSION" +meson build/ $EXTRA_MESON_ARGS +ninja -C build install +popd RUSTFLAGS='-L native=/usr/local/lib' cargo install \ bindgen \ @@ -60,4 +38,4 @@ RUSTFLAGS='-L native=/usr/local/lib' cargo install \ popd -rm -rf $PLATFORM2_ROOT $AOSP_EXTERNAL_ROOT/minijail $THIRD_PARTY_ROOT/adhd $THIRD_PARTY_ROOT/rust-vmm /platform/crosvm +rm -rf /platform/crosvm diff --git a/lib/mesa/.gitlab-ci/container/build-crosvm_no-syslog.patch b/lib/mesa/.gitlab-ci/container/build-crosvm_no-syslog.patch new file mode 100644 index 000000000..804e90bb7 --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-crosvm_no-syslog.patch @@ -0,0 +1,43 @@ +From 3c57ec558bccc67fd53363c23deea20646be5c47 Mon Sep 17 00:00:00 2001 +From: Tomeu Vizoso <tomeu.vizoso@collabora.com> +Date: Wed, 17 Nov 2021 10:18:04 +0100 +Subject: [PATCH] Hack syslog out + +It's causing stability problems when running several Crosvm instances in +parallel. + +Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com> +--- + base/src/unix/linux/syslog.rs | 2 +- + common/sys_util/src/linux/syslog.rs | 2 +- + 2 files changed, 2 insertions(+), 2 deletions(-) + +diff --git a/base/src/unix/linux/syslog.rs b/base/src/unix/linux/syslog.rs +index 05972a3a..f0db3781 100644 +--- a/base/src/unix/linux/syslog.rs ++++ b/base/src/unix/linux/syslog.rs +@@ -35,7 +35,7 @@ pub struct PlatformSyslog { + impl Syslog for PlatformSyslog { + fn new() -> Result<Self, Error> { + Ok(Self { +- socket: Some(openlog_and_get_socket()?), ++ socket: None, + }) + } + +diff --git a/common/sys_util/src/linux/syslog.rs b/common/sys_util/src/linux/syslog.rs +index 05972a3a..f0db3781 100644 +--- a/common/sys_util/src/linux/syslog.rs ++++ b/common/sys_util/src/linux/syslog.rs +@@ -35,7 +35,7 @@ pub struct PlatformSyslog { + impl Syslog for PlatformSyslog { + fn new() -> Result<Self, Error> { + Ok(Self { +- socket: Some(openlog_and_get_socket()?), ++ socket: None, + }) + } + +-- +2.25.1 + diff --git a/lib/mesa/.gitlab-ci/container/build-deqp-runner.sh b/lib/mesa/.gitlab-ci/container/build-deqp-runner.sh index ae989be82..9ae0d9932 100644 --- a/lib/mesa/.gitlab-ci/container/build-deqp-runner.sh +++ b/lib/mesa/.gitlab-ci/container/build-deqp-runner.sh @@ -1,9 +1,24 @@ -#!/bin/bash +#!/bin/sh set -ex -cargo install --locked deqp-runner \ - -j ${FDO_CI_CONCURRENT:-4} \ - --version 0.10.0 \ - --root /usr/local \ - $EXTRA_CARGO_ARGS +if [ -n "${DEQP_RUNNER_GIT_TAG}${DEQP_RUNNER_GIT_REV}" ]; then + # Build and install from source + DEQP_RUNNER_CARGO_ARGS="--git ${DEQP_RUNNER_GIT_URL:-https://gitlab.freedesktop.org/anholt/deqp-runner.git}" + + if [ -n "${DEQP_RUNNER_GIT_TAG}" ]; then + DEQP_RUNNER_CARGO_ARGS="--tag ${DEQP_RUNNER_GIT_TAG} ${DEQP_RUNNER_CARGO_ARGS}" + else + DEQP_RUNNER_CARGO_ARGS="--rev ${DEQP_RUNNER_GIT_REV} ${DEQP_RUNNER_CARGO_ARGS}" + fi + + DEQP_RUNNER_CARGO_ARGS="${DEQP_RUNNER_CARGO_ARGS} ${EXTRA_CARGO_ARGS}" +else + # Install from package registry + DEQP_RUNNER_CARGO_ARGS="--version 0.13.1 ${EXTRA_CARGO_ARGS} -- deqp-runner" +fi + +cargo install --locked \ + -j ${FDO_CI_CONCURRENT:-4} \ + --root /usr/local \ + ${DEQP_RUNNER_CARGO_ARGS} diff --git a/lib/mesa/.gitlab-ci/container/build-deqp.sh b/lib/mesa/.gitlab-ci/container/build-deqp.sh index 616d504a3..f239fef2a 100644 --- a/lib/mesa/.gitlab-ci/container/build-deqp.sh +++ b/lib/mesa/.gitlab-ci/container/build-deqp.sh @@ -6,11 +6,15 @@ git config --global user.email "mesa@example.com" git config --global user.name "Mesa CI" git clone \ https://github.com/KhronosGroup/VK-GL-CTS.git \ - -b vulkan-cts-1.2.7.1 \ + -b vulkan-cts-1.3.1.1 \ --depth 1 \ /VK-GL-CTS pushd /VK-GL-CTS +# Cherry-pick fix for zlib dependency +git fetch origin main +git cherry-pick -x ec1804831b654ac55bd2a7a5dd27a556afe05030 + # --insecure is due to SSL cert failures hitting sourceforge for zlib and # libpng (sigh). The archives get their checksums checked anyway, and git # always goes through ssh or https. @@ -68,7 +72,11 @@ cp /deqp/executor/testlog-to-* /deqp/executor.save rm -rf /deqp/executor mv /deqp/executor.save /deqp/executor +# Remove other mustpass files, since we saved off the ones we wanted to conventient locations above. rm -rf /deqp/external/openglcts/modules/gl_cts/data/mustpass +rm -rf /deqp/external/vulkancts/modules/vulkan/vk-master* +rm -rf /deqp/external/vulkancts/modules/vulkan/vk-default + rm -rf /deqp/external/openglcts/modules/cts-runner rm -rf /deqp/modules/internal rm -rf /deqp/execserver diff --git a/lib/mesa/.gitlab-ci/container/build-fossilize.sh b/lib/mesa/.gitlab-ci/container/build-fossilize.sh index 2195c4bf5..a8abbb938 100644 --- a/lib/mesa/.gitlab-ci/container/build-fossilize.sh +++ b/lib/mesa/.gitlab-ci/container/build-fossilize.sh @@ -4,7 +4,7 @@ set -ex git clone https://github.com/ValveSoftware/Fossilize.git cd Fossilize -git checkout 72088685d90bc814d14aad5505354ffa8a642789 +git checkout 16fba1b8b5d9310126bb02323d7bae3227338461 git submodule update --init mkdir build cd build diff --git a/lib/mesa/.gitlab-ci/container/build-kernel.sh b/lib/mesa/.gitlab-ci/container/build-kernel.sh index 7367924c7..426ecb780 100644 --- a/lib/mesa/.gitlab-ci/container/build-kernel.sh +++ b/lib/mesa/.gitlab-ci/container/build-kernel.sh @@ -28,7 +28,7 @@ if [[ -n ${DEVICE_TREES} ]]; then cp ${DEVICE_TREES} /lava-files/. fi -if [[ ${DEBIAN_ARCH} = "amd64" ]]; then +if [[ ${DEBIAN_ARCH} = "amd64" || ${DEBIAN_ARCH} = "arm64" ]]; then make modules INSTALL_MOD_PATH=/lava-files/rootfs-${DEBIAN_ARCH}/ make modules_install fi diff --git a/lib/mesa/.gitlab-ci/container/build-libdrm.sh b/lib/mesa/.gitlab-ci/container/build-libdrm.sh index e765f9322..65bd7768a 100644 --- a/lib/mesa/.gitlab-ci/container/build-libdrm.sh +++ b/lib/mesa/.gitlab-ci/container/build-libdrm.sh @@ -2,7 +2,7 @@ set -ex -export LIBDRM_VERSION=libdrm-2.4.107 +export LIBDRM_VERSION=libdrm-2.4.110 wget https://dri.freedesktop.org/libdrm/$LIBDRM_VERSION.tar.xz tar -xvf $LIBDRM_VERSION.tar.xz && rm $LIBDRM_VERSION.tar.xz diff --git a/lib/mesa/.gitlab-ci/container/build-piglit.sh b/lib/mesa/.gitlab-ci/container/build-piglit.sh index 5bc07ed04..b19d7c067 100644 --- a/lib/mesa/.gitlab-ci/container/build-piglit.sh +++ b/lib/mesa/.gitlab-ci/container/build-piglit.sh @@ -4,7 +4,7 @@ set -ex git clone https://gitlab.freedesktop.org/mesa/piglit.git --single-branch --no-checkout /piglit pushd /piglit -git checkout 7d7dd2688c214e1b3c00f37226500cbec4a58efb +git checkout 445711587d461539a4d8f9d35a7fe996a86d3c8d patch -p1 <$OLDPWD/.gitlab-ci/piglit/disable-vs_in.diff cmake -S . -B . -G Ninja -DCMAKE_BUILD_TYPE=Release $PIGLIT_OPTS $EXTRA_CMAKE_ARGS ninja $PIGLIT_BUILD_TARGETS diff --git a/lib/mesa/.gitlab-ci/container/build-skqp.sh b/lib/mesa/.gitlab-ci/container/build-skqp.sh new file mode 100755 index 000000000..af95eba32 --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp.sh @@ -0,0 +1,97 @@ +#!/bin/bash +# +# Copyright (C) 2022 Collabora Limited +# Author: Guilherme Gallo <guilherme.gallo@collabora.com> +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + + +create_gn_args() { + # gn can be configured to cross-compile skia and its tools + # It is important to set the target_cpu to guarantee the intended target + # machine + cp "${BASE_ARGS_GN_FILE}" "${SKQP_OUT_DIR}"/args.gn + echo "target_cpu = \"${SKQP_ARCH}\"" >> "${SKQP_OUT_DIR}"/args.gn +} + + +download_skia_source() { + if [ -z ${SKIA_DIR+x} ] + then + return 1 + fi + + # Skia cloned from https://android.googlesource.com/platform/external/skqp + # has all needed assets tracked on git-fs + SKQP_REPO=https://android.googlesource.com/platform/external/skqp + SKQP_BRANCH=android-cts-10.0_r11 + + git clone --branch "${SKQP_BRANCH}" --depth 1 "${SKQP_REPO}" "${SKIA_DIR}" +} + +set -ex + +SCRIPT_DIR=$(realpath "$(dirname "$0")") +SKQP_PATCH_DIR="${SCRIPT_DIR}" +BASE_ARGS_GN_FILE="${SCRIPT_DIR}/build-skqp_base.gn" + +SKQP_ARCH=${SKQP_ARCH:-x64} +SKIA_DIR=${SKIA_DIR:-$(mktemp -d)} +SKQP_OUT_DIR=${SKIA_DIR}/out/${SKQP_ARCH} +SKQP_INSTALL_DIR=/skqp +SKQP_ASSETS_DIR="${SKQP_INSTALL_DIR}/assets" +SKQP_BINARIES=(skqp) + +download_skia_source + +pushd "${SKIA_DIR}" + +# Apply all skqp patches for Mesa CI +cat "${SKQP_PATCH_DIR}"/build-skqp_*.patch | + patch -p1 + +# Fetch some needed build tools needed to build skia/skqp. +# Basically, it clones repositories with commits SHAs from ${SKIA_DIR}/DEPS +# directory. +python tools/git-sync-deps + +mkdir -p "${SKQP_OUT_DIR}" +mkdir -p "${SKQP_INSTALL_DIR}" + +create_gn_args + +# Build and install skqp binaries +bin/gn gen "${SKQP_OUT_DIR}" + +for BINARY in "${SKQP_BINARIES[@]}" +do + /usr/bin/ninja -C "${SKQP_OUT_DIR}" "${BINARY}" + # Strip binary, since gn is not stripping it even when `is_debug == false` + ${STRIP_CMD:-strip} "${SKQP_OUT_DIR}/${BINARY}" + install -m 0755 "${SKQP_OUT_DIR}/${BINARY}" "${SKQP_INSTALL_DIR}" +done + +# Move assets to the target directory, which will reside in rootfs. +mv platform_tools/android/apps/skqp/src/main/assets/ "${SKQP_ASSETS_DIR}" + +popd +rm -Rf "${SKIA_DIR}" + +set +ex diff --git a/lib/mesa/.gitlab-ci/container/build-skqp_BUILD.gn.patch b/lib/mesa/.gitlab-ci/container/build-skqp_BUILD.gn.patch new file mode 100644 index 000000000..a1e82af6b --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp_BUILD.gn.patch @@ -0,0 +1,13 @@ +diff --git a/BUILD.gn b/BUILD.gn +index d2b1407..7b60c90 100644 +--- a/BUILD.gn ++++ b/BUILD.gn +@@ -144,7 +144,7 @@ config("skia_public") { + + # Skia internal APIs, used by Skia itself and a few test tools. + config("skia_private") { +- visibility = [ ":*" ] ++ visibility = [ "*" ] + + include_dirs = [ + "include/private", diff --git a/lib/mesa/.gitlab-ci/container/build-skqp_base.gn b/lib/mesa/.gitlab-ci/container/build-skqp_base.gn new file mode 100644 index 000000000..3df11647a --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp_base.gn @@ -0,0 +1,47 @@ +cc = "clang" +cxx = "clang++" + +extra_cflags = [ "-DSK_ENABLE_DUMP_GPU", "-DSK_BUILD_FOR_SKQP" ] +extra_cflags_cc = [ + "-Wno-error", + + # skqp build process produces a lot of compilation warnings, silencing + # most of them to remove clutter and avoid the CI job log to exceed the + # maximum size + + # GCC flags + "-Wno-redundant-move", + "-Wno-suggest-override", + "-Wno-class-memaccess", + "-Wno-deprecated-copy", + "-Wno-uninitialized", + + # Clang flags + "-Wno-macro-redefined", + "-Wno-anon-enum-enum-conversion", + "-Wno-suggest-destructor-override", + "-Wno-return-std-move-in-c++11", + "-Wno-extra-semi-stmt", + ] + +cc_wrapper = "ccache" + +is_debug = false + +skia_enable_fontmgr_android = false +skia_enable_fontmgr_empty = true +skia_enable_pdf = false +skia_enable_skottie = false + +skia_skqp_global_error_tolerance = 8 +skia_tools_require_resources = true + +skia_use_dng_sdk = false +skia_use_expat = true +skia_use_icu = false +skia_use_libheif = false +skia_use_lua = false +skia_use_piex = false +skia_use_vulkan = true + +target_os = "linux" diff --git a/lib/mesa/.gitlab-ci/container/build-skqp_fetch_gn.patch b/lib/mesa/.gitlab-ci/container/build-skqp_fetch_gn.patch new file mode 100644 index 000000000..545cf2af7 --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp_fetch_gn.patch @@ -0,0 +1,68 @@ +diff --git a/bin/fetch-gn b/bin/fetch-gn +index d5e94a2..59c4591 100755 +--- a/bin/fetch-gn ++++ b/bin/fetch-gn +@@ -5,39 +5,44 @@ + # Use of this source code is governed by a BSD-style license that can be + # found in the LICENSE file. + +-import hashlib + import os ++import platform + import shutil + import stat + import sys +-import urllib2 ++import tempfile ++import zipfile ++ ++if sys.version_info[0] < 3: ++ from urllib2 import urlopen ++else: ++ from urllib.request import urlopen + + os.chdir(os.path.join(os.path.dirname(__file__), os.pardir)) + +-dst = 'bin/gn.exe' if 'win32' in sys.platform else 'bin/gn' ++gnzip = os.path.join(tempfile.mkdtemp(), 'gn.zip') ++with open(gnzip, 'wb') as f: ++ OS = {'darwin': 'mac', 'linux': 'linux', 'linux2': 'linux', 'win32': 'windows'}[sys.platform] ++ cpu = {'amd64': 'amd64', 'arm64': 'arm64', 'x86_64': 'amd64', 'aarch64': 'arm64'}[platform.machine().lower()] + +-sha1 = '2f27ff0b6118e5886df976da5effa6003d19d1ce' if 'linux' in sys.platform else \ +- '9be792dd9010ce303a9c3a497a67bcc5ac8c7666' if 'darwin' in sys.platform else \ +- 'eb69be2d984b4df60a8c21f598135991f0ad1742' # Windows ++ rev = 'd62642c920e6a0d1756316d225a90fd6faa9e21e' ++ url = 'https://chrome-infra-packages.appspot.com/dl/gn/gn/{}-{}/+/git_revision:{}'.format( ++ OS,cpu,rev) ++ f.write(urlopen(url).read()) + +-def sha1_of_file(path): +- h = hashlib.sha1() +- if os.path.isfile(path): +- with open(path, 'rb') as f: +- h.update(f.read()) +- return h.hexdigest() ++gn = 'gn.exe' if 'win32' in sys.platform else 'gn' ++with zipfile.ZipFile(gnzip, 'r') as f: ++ f.extract(gn, 'bin') + +-if sha1_of_file(dst) != sha1: +- with open(dst, 'wb') as f: +- f.write(urllib2.urlopen('https://chromium-gn.storage-download.googleapis.com/' + sha1).read()) ++gn = os.path.join('bin', gn) + +- os.chmod(dst, stat.S_IRUSR | stat.S_IWUSR | stat.S_IXUSR | +- stat.S_IRGRP | stat.S_IXGRP | +- stat.S_IROTH | stat.S_IXOTH ) ++os.chmod(gn, stat.S_IRUSR | stat.S_IWUSR | stat.S_IXUSR | ++ stat.S_IRGRP | stat.S_IXGRP | ++ stat.S_IROTH | stat.S_IXOTH ) + + # We'll also copy to a path that depot_tools' GN wrapper will expect to find the binary. + copy_path = 'buildtools/linux64/gn' if 'linux' in sys.platform else \ + 'buildtools/mac/gn' if 'darwin' in sys.platform else \ + 'buildtools/win/gn.exe' + if os.path.isdir(os.path.dirname(copy_path)): +- shutil.copy(dst, copy_path) ++ shutil.copy(gn, copy_path) diff --git a/lib/mesa/.gitlab-ci/container/build-skqp_git-sync-deps.patch b/lib/mesa/.gitlab-ci/container/build-skqp_git-sync-deps.patch new file mode 100644 index 000000000..d088349ad --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp_git-sync-deps.patch @@ -0,0 +1,142 @@ +Patch based from diff with skia repository from commit +013397884c73959dc07cb0a26ee742b1cdfbda8a + +Adds support for Python3, but removes the constraint of only SHA based refs in +DEPS +diff --git a/tools/git-sync-deps b/tools/git-sync-deps +index c7379c0b5c..f63d4d9ccf 100755 +--- a/tools/git-sync-deps ++++ b/tools/git-sync-deps +@@ -43,7 +43,7 @@ def git_executable(): + A string suitable for passing to subprocess functions, or None. + """ + envgit = os.environ.get('GIT_EXECUTABLE') +- searchlist = ['git'] ++ searchlist = ['git', 'git.bat'] + if envgit: + searchlist.insert(0, envgit) + with open(os.devnull, 'w') as devnull: +@@ -94,21 +94,25 @@ def is_git_toplevel(git, directory): + try: + toplevel = subprocess.check_output( + [git, 'rev-parse', '--show-toplevel'], cwd=directory).strip() +- return os.path.realpath(directory) == os.path.realpath(toplevel) ++ return os.path.realpath(directory) == os.path.realpath(toplevel.decode()) + except subprocess.CalledProcessError: + return False + + +-def status(directory, checkoutable): +- def truncate(s, length): ++def status(directory, commithash, change): ++ def truncate_beginning(s, length): ++ return s if len(s) <= length else '...' + s[-(length-3):] ++ def truncate_end(s, length): + return s if len(s) <= length else s[:(length - 3)] + '...' ++ + dlen = 36 +- directory = truncate(directory, dlen) +- checkoutable = truncate(checkoutable, 40) +- sys.stdout.write('%-*s @ %s\n' % (dlen, directory, checkoutable)) ++ directory = truncate_beginning(directory, dlen) ++ commithash = truncate_end(commithash, 40) ++ symbol = '>' if change else '@' ++ sys.stdout.write('%-*s %s %s\n' % (dlen, directory, symbol, commithash)) + + +-def git_checkout_to_directory(git, repo, checkoutable, directory, verbose): ++def git_checkout_to_directory(git, repo, commithash, directory, verbose): + """Checkout (and clone if needed) a Git repository. + + Args: +@@ -117,8 +121,7 @@ def git_checkout_to_directory(git, repo, checkoutable, directory, verbose): + repo (string) the location of the repository, suitable + for passing to `git clone`. + +- checkoutable (string) a tag, branch, or commit, suitable for +- passing to `git checkout` ++ commithash (string) a commit, suitable for passing to `git checkout` + + directory (string) the path into which the repository + should be checked out. +@@ -129,7 +132,12 @@ def git_checkout_to_directory(git, repo, checkoutable, directory, verbose): + """ + if not os.path.isdir(directory): + subprocess.check_call( +- [git, 'clone', '--quiet', repo, directory]) ++ [git, 'clone', '--quiet', '--no-checkout', repo, directory]) ++ subprocess.check_call([git, 'checkout', '--quiet', commithash], ++ cwd=directory) ++ if verbose: ++ status(directory, commithash, True) ++ return + + if not is_git_toplevel(git, directory): + # if the directory exists, but isn't a git repo, you will modify +@@ -145,11 +153,11 @@ def git_checkout_to_directory(git, repo, checkoutable, directory, verbose): + with open(os.devnull, 'w') as devnull: + # If this fails, we will fetch before trying again. Don't spam user + # with error infomation. +- if 0 == subprocess.call([git, 'checkout', '--quiet', checkoutable], ++ if 0 == subprocess.call([git, 'checkout', '--quiet', commithash], + cwd=directory, stderr=devnull): + # if this succeeds, skip slow `git fetch`. + if verbose: +- status(directory, checkoutable) # Success. ++ status(directory, commithash, False) # Success. + return + + # If the repo has changed, always force use of the correct repo. +@@ -159,18 +167,24 @@ def git_checkout_to_directory(git, repo, checkoutable, directory, verbose): + + subprocess.check_call([git, 'fetch', '--quiet'], cwd=directory) + +- subprocess.check_call([git, 'checkout', '--quiet', checkoutable], cwd=directory) ++ subprocess.check_call([git, 'checkout', '--quiet', commithash], cwd=directory) + + if verbose: +- status(directory, checkoutable) # Success. ++ status(directory, commithash, True) # Success. + + + def parse_file_to_dict(path): + dictionary = {} +- execfile(path, dictionary) ++ with open(path) as f: ++ exec('def Var(x): return vars[x]\n' + f.read(), dictionary) + return dictionary + + ++def is_sha1_sum(s): ++ """SHA1 sums are 160 bits, encoded as lowercase hexadecimal.""" ++ return len(s) == 40 and all(c in '0123456789abcdef' for c in s) ++ ++ + def git_sync_deps(deps_file_path, command_line_os_requests, verbose): + """Grab dependencies, with optional platform support. + +@@ -204,19 +218,19 @@ def git_sync_deps(deps_file_path, command_line_os_requests, verbose): + raise Exception('%r is parent of %r' % (other_dir, directory)) + list_of_arg_lists = [] + for directory in sorted(dependencies): +- if not isinstance(dependencies[directory], basestring): ++ if not isinstance(dependencies[directory], str): + if verbose: +- print 'Skipping "%s".' % directory ++ sys.stdout.write( 'Skipping "%s".\n' % directory) + continue + if '@' in dependencies[directory]: +- repo, checkoutable = dependencies[directory].split('@', 1) ++ repo, commithash = dependencies[directory].split('@', 1) + else: +- raise Exception("please specify commit or tag") ++ raise Exception("please specify commit") + + relative_directory = os.path.join(deps_file_directory, directory) + + list_of_arg_lists.append( +- (git, repo, checkoutable, relative_directory, verbose)) ++ (git, repo, commithash, relative_directory, verbose)) + + multithread(git_checkout_to_directory, list_of_arg_lists) + diff --git a/lib/mesa/.gitlab-ci/container/build-skqp_is_clang.py.patch b/lib/mesa/.gitlab-ci/container/build-skqp_is_clang.py.patch new file mode 100644 index 000000000..af6f6cff3 --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-skqp_is_clang.py.patch @@ -0,0 +1,13 @@ +diff --git a/gn/BUILDCONFIG.gn b/gn/BUILDCONFIG.gn +index 454334a..1797594 100644 +--- a/gn/BUILDCONFIG.gn ++++ b/gn/BUILDCONFIG.gn +@@ -80,7 +80,7 @@ if (current_cpu == "") { + is_clang = is_android || is_ios || is_mac || + (cc == "clang" && cxx == "clang++") || clang_win != "" + if (!is_clang && !is_win) { +- is_clang = exec_script("gn/is_clang.py", ++ is_clang = exec_script("//gn/is_clang.py", + [ + cc, + cxx, diff --git a/lib/mesa/.gitlab-ci/container/build-vkd3d-proton.sh b/lib/mesa/.gitlab-ci/container/build-vkd3d-proton.sh index b2898271e..0da94de9d 100644 --- a/lib/mesa/.gitlab-ci/container/build-vkd3d-proton.sh +++ b/lib/mesa/.gitlab-ci/container/build-vkd3d-proton.sh @@ -2,8 +2,8 @@ set -ex -VKD3D_PROTON_VERSION="2.3.1" -VKD3D_PROTON_COMMIT="3ed3526332f53d7d35cf1b685fa8096b01f26ff0" +VKD3D_PROTON_VERSION="2.6" +VKD3D_PROTON_COMMIT="3e5aab6fb3e18f81a71b339be4cb5cdf55140980" VKD3D_PROTON_DST_DIR="/vkd3d-proton-tests" VKD3D_PROTON_SRC_DIR="/vkd3d-proton-src" diff --git a/lib/mesa/.gitlab-ci/container/build-wayland.sh b/lib/mesa/.gitlab-ci/container/build-wayland.sh new file mode 100644 index 000000000..893ee058f --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/build-wayland.sh @@ -0,0 +1,22 @@ +#!/bin/bash + +set -ex + +export LIBWAYLAND_VERSION="1.18.0" +export WAYLAND_PROTOCOLS_VERSION="1.24" + +git clone https://gitlab.freedesktop.org/wayland/wayland +cd wayland +git checkout "$LIBWAYLAND_VERSION" +meson -Ddocumentation=false -Ddtd_validation=false -Dlibraries=true _build +ninja -C _build install +cd .. +rm -rf wayland + +git clone https://gitlab.freedesktop.org/wayland/wayland-protocols +cd wayland-protocols +git checkout "$WAYLAND_PROTOCOLS_VERSION" +meson _build +ninja -C _build install +cd .. +rm -rf wayland-protocols diff --git a/lib/mesa/.gitlab-ci/container/container_pre_build.sh b/lib/mesa/.gitlab-ci/container/container_pre_build.sh index dc36970c8..7bfa5b0c6 100755 --- a/lib/mesa/.gitlab-ci/container/container_pre_build.sh +++ b/lib/mesa/.gitlab-ci/container/container_pre_build.sh @@ -10,7 +10,7 @@ fi export CCACHE_COMPILERCHECK=content export CCACHE_COMPRESS=true -export CCACHE_DIR=/cache/mesa/ccache +export CCACHE_DIR=/cache/$CI_PROJECT_NAME/ccache export PATH=$CCACHE_PATH:$PATH # CMake ignores $PATH, so we have to force CC/GCC to the ccache versions. diff --git a/lib/mesa/.gitlab-ci/container/create-rootfs.sh b/lib/mesa/.gitlab-ci/container/create-rootfs.sh index f8a888cad..5922745f9 100644 --- a/lib/mesa/.gitlab-ci/container/create-rootfs.sh +++ b/lib/mesa/.gitlab-ci/container/create-rootfs.sh @@ -3,13 +3,26 @@ set -ex if [ $DEBIAN_ARCH = arm64 ]; then - ARCH_PACKAGES="firmware-qcom-media" + ARCH_PACKAGES="firmware-qcom-media + firmware-linux-nonfree + libfontconfig1 + libgl1 + libglu1-mesa + libvulkan-dev + " elif [ $DEBIAN_ARCH = amd64 ]; then ARCH_PACKAGES="firmware-amd-graphics + inetutils-syslogd + iptables + libcap2 libelf1 + libfdt1 libllvm11 libva2 libva-drm2 + socat + spirv-tools + sysvinit-core " fi @@ -23,6 +36,8 @@ INSTALL_CI_FAIRY_PACKAGES="git apt-get -y install --no-install-recommends \ $ARCH_PACKAGES \ $INSTALL_CI_FAIRY_PACKAGES \ + $EXTRA_LOCAL_PACKAGES \ + bash \ ca-certificates \ firmware-realtek \ initramfs-tools \ @@ -66,12 +81,11 @@ apt-get -y install --no-install-recommends \ waffle-utils \ wget \ xinit \ - xserver-xorg-core \ - xz-utils + xserver-xorg-core # Needed for ci-fairy, this revision is able to upload files to # MinIO and doesn't depend on git -pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@0f1abc24c043e63894085a6bd12f14263e8b29eb +pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@34f4ade99434043f88e164933f570301fd18b125 apt-get purge -y \ $INSTALL_CI_FAIRY_PACKAGES @@ -90,10 +104,6 @@ chmod +x /init # Strip the image to a small minimal system without removing the debian # toolchain. -# xz compress firmware so it doesn't waste RAM at runtime on ramdisk systems -find /lib/firmware -type f -print0 | \ - xargs -0r -P4 -n4 xz -T1 -C crc32 - # Copy timezone file and remove tzdata package rm -rf /etc/localtime cp /usr/share/zoneinfo/Etc/UTC /etc/localtime @@ -146,6 +156,8 @@ rm -rf usr/sbin/update-usbids rm -rf var/lib/usbutils/usb.ids rm -rf usr/share/misc/usb.ids +rm -rf /root/.pip + ####################################################################### # Crush into a minimal production image to be deployed via some type of image # updating system. @@ -160,9 +172,7 @@ UNNEEDED_PACKAGES="apt libapt-pkg6.0 "\ "insserv "\ "udev "\ "init-system-helpers "\ -"bash "\ "cpio "\ -"xz-utils "\ "passwd "\ "libsemanage1 libsemanage-common "\ "libsepol1 "\ @@ -207,7 +217,7 @@ rm -rf var/* opt srv share # ca-certificates are in /etc drop the source rm -rf usr/share/ca-certificates -# No bash, no need for completions +# No need for completions rm -rf usr/share/bash-completion # No zsh, no need for comletions diff --git a/lib/mesa/.gitlab-ci/container/debian/android_build.sh b/lib/mesa/.gitlab-ci/container/debian/android_build.sh index 88c05af4e..121976f1b 100644 --- a/lib/mesa/.gitlab-ci/container/debian/android_build.sh +++ b/lib/mesa/.gitlab-ci/container/debian/android_build.sh @@ -3,6 +3,7 @@ set -ex EPHEMERAL="\ + autoconf \ rdfind \ unzip \ " @@ -29,7 +30,7 @@ sh .gitlab-ci/container/create-android-cross-file.sh /$ndk arm-linux-androideabi # Not using build-libdrm.sh because we don't want its cleanup after building # each arch. Fetch and extract now. -export LIBDRM_VERSION=libdrm-2.4.102 +export LIBDRM_VERSION=libdrm-2.4.110 wget https://dri.freedesktop.org/libdrm/$LIBDRM_VERSION.tar.xz tar -xf $LIBDRM_VERSION.tar.xz && rm $LIBDRM_VERSION.tar.xz @@ -50,11 +51,56 @@ for arch in \ -Detnaviv=false \ -Dfreedreno=false \ -Dintel=false \ - -Dcairo-tests=false + -Dcairo-tests=false \ + -Dvalgrind=false ninja -C build-$arch install cd .. done rm -rf $LIBDRM_VERSION +export LIBELF_VERSION=libelf-0.8.13 +wget https://fossies.org/linux/misc/old/$LIBELF_VERSION.tar.gz + +# Not 100% sure who runs the mirror above so be extra careful +if ! echo "4136d7b4c04df68b686570afa26988ac ${LIBELF_VERSION}.tar.gz" | md5sum -c -; then + echo "Checksum failed" + exit 1 +fi + +tar -xf ${LIBELF_VERSION}.tar.gz +cd $LIBELF_VERSION + +# Work around a bug in the original configure not enabling __LIBELF64. +autoreconf + +for arch in \ + x86_64-linux-android \ + i686-linux-android \ + aarch64-linux-android \ + arm-linux-androideabi ; do + + ccarch=${arch} + if [ "${arch}" == 'arm-linux-androideabi' ] + then + ccarch=armv7a-linux-androideabi + fi + + export CC=/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/bin/${arch}-ar + export CC=/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/bin/${ccarch}29-clang + export CXX=/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/bin/${ccarch}29-clang++ + export LD=/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/bin/${arch}-ld + export RANLIB=/android-ndk-r21d/toolchains/llvm/prebuilt/linux-x86_64/bin/${arch}-ranlib + + # The configure script doesn't know about android, but doesn't really use the host anyway it + # seems + ./configure --host=x86_64-linux-gnu --disable-nls --disable-shared \ + --libdir=/usr/local/lib/${arch} + make install + make distclean +done + +cd .. +rm -rf $LIBELF_VERSION + apt-get purge -y $EPHEMERAL diff --git a/lib/mesa/.gitlab-ci/container/debian/arm_build.sh b/lib/mesa/.gitlab-ci/container/debian/arm_build.sh index c16e9474d..0f9883721 100644 --- a/lib/mesa/.gitlab-ci/container/debian/arm_build.sh +++ b/lib/mesa/.gitlab-ci/container/debian/arm_build.sh @@ -9,6 +9,7 @@ echo 'deb https://deb.debian.org/debian buster main' >/etc/apt/sources.list.d/bu apt-get update apt-get -y install \ + ${EXTRA_LOCAL_PACKAGES} \ abootimg \ autoconf \ automake \ @@ -57,7 +58,7 @@ apt-get -y install \ apt-get install -y --no-remove -t buster \ android-sdk-ext4-utils -pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@6f5af7e5574509726c79109e3c147cee95e81366 +pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@34f4ade99434043f88e164933f570301fd18b125 arch=armhf . .gitlab-ci/container/cross_build.sh diff --git a/lib/mesa/.gitlab-ci/container/debian/arm_test.sh b/lib/mesa/.gitlab-ci/container/debian/arm_test.sh index eedb88e91..a420dbb47 100644 --- a/lib/mesa/.gitlab-ci/container/debian/arm_test.sh +++ b/lib/mesa/.gitlab-ci/container/debian/arm_test.sh @@ -31,3 +31,9 @@ arch=armhf . .gitlab-ci/container/baremetal_build.sh # This firmware file from Debian bullseye causes hangs wget https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/plain/qcom/a530_pfp.fw?id=d5f9eea5a251d43412b07f5295d03e97b89ac4a5 \ -O /rootfs-arm64/lib/firmware/qcom/a530_pfp.fw + +mkdir -p /baremetal-files/jetson-nano/boot/ +ln -s \ + /baremetal-files/Image \ + /baremetal-files/tegra210-p3450-0000.dtb \ + /baremetal-files/jetson-nano/boot/ diff --git a/lib/mesa/.gitlab-ci/container/debian/x86_build-base.sh b/lib/mesa/.gitlab-ci/container/debian/x86_build-base.sh index 6333fa70e..85a6a6f00 100644 --- a/lib/mesa/.gitlab-ci/container/debian/x86_build-base.sh +++ b/lib/mesa/.gitlab-ci/container/debian/x86_build-base.sh @@ -63,7 +63,6 @@ apt-get install -y --no-remove \ python3-requests \ qemu-user \ valgrind \ - wayland-protocols \ wget \ wine64 \ x11proto-dri2-dev \ @@ -73,7 +72,7 @@ apt-get install -y --no-remove \ zlib1g-dev # Needed for ci-fairy, this revision is able to upload files to MinIO -pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@6f5af7e5574509726c79109e3c147cee95e81366 +pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@34f4ade99434043f88e164933f570301fd18b125 ############### Uninstall ephemeral packages diff --git a/lib/mesa/.gitlab-ci/container/debian/x86_build.sh b/lib/mesa/.gitlab-ci/container/debian/x86_build.sh index 318a0bc49..72e326af1 100644 --- a/lib/mesa/.gitlab-ci/container/debian/x86_build.sh +++ b/lib/mesa/.gitlab-ci/container/debian/x86_build.sh @@ -11,8 +11,6 @@ STABLE_EPHEMERAL=" \ automake \ autotools-dev \ bzip2 \ - cmake \ - libgbm-dev \ libtool \ python3-pip \ " @@ -23,10 +21,13 @@ apt-get update apt-get install -y --no-remove \ $STABLE_EPHEMERAL \ + check \ clang \ + cmake \ libasan6 \ libarchive-dev \ libclang-cpp11-dev \ + libgbm-dev \ libglvnd-dev \ libllvmspirvlib-dev \ liblua5.3-dev \ @@ -43,6 +44,8 @@ apt-get install -y --no-remove \ llvm-11-dev \ llvm-9-dev \ ocl-icd-opencl-dev \ + python3-freezegun \ + python3-pytest \ procps \ spirv-tools \ strace \ @@ -67,10 +70,8 @@ chmod +x /usr/local/bin/x86_64-w64-mingw32-pkg-config # dependencies where we want a specific version export XORG_RELEASES=https://xorg.freedesktop.org/releases/individual -export WAYLAND_RELEASES=https://wayland.freedesktop.org/releases export XORGMACROS_VERSION=util-macros-1.19.0 -export LIBWAYLAND_VERSION=wayland-1.18.0 wget $XORG_RELEASES/util/$XORGMACROS_VERSION.tar.bz2 tar -xvf $XORGMACROS_VERSION.tar.bz2 && rm $XORGMACROS_VERSION.tar.bz2 @@ -79,11 +80,7 @@ rm -rf $XORGMACROS_VERSION . .gitlab-ci/container/build-libdrm.sh -wget $WAYLAND_RELEASES/$LIBWAYLAND_VERSION.tar.xz -tar -xvf $LIBWAYLAND_VERSION.tar.xz && rm $LIBWAYLAND_VERSION.tar.xz -cd $LIBWAYLAND_VERSION; ./configure --enable-libraries --without-host-scanner --disable-documentation --disable-dtd-validation; make install; cd .. -rm -rf $LIBWAYLAND_VERSION - +. .gitlab-ci/container/build-wayland.sh pushd /usr/local git clone https://gitlab.freedesktop.org/mesa/shader-db.git --depth 1 diff --git a/lib/mesa/.gitlab-ci/container/debian/x86_test-base.sh b/lib/mesa/.gitlab-ci/container/debian/x86_test-base.sh index 362cf7e9e..7d56e7825 100644 --- a/lib/mesa/.gitlab-ci/container/debian/x86_test-base.sh +++ b/lib/mesa/.gitlab-ci/container/debian/x86_test-base.sh @@ -59,7 +59,7 @@ apt-get install -y --no-install-recommends \ # Needed for ci-fairy, this revision is able to upload files to MinIO # and doesn't depend on git -pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@0f1abc24c043e63894085a6bd12f14263e8b29eb +pip3 install git+http://gitlab.freedesktop.org/freedesktop/ci-templates@34f4ade99434043f88e164933f570301fd18b125 ############### Build dEQP runner . .gitlab-ci/container/build-deqp-runner.sh diff --git a/lib/mesa/.gitlab-ci/container/debian/x86_test-gl.sh b/lib/mesa/.gitlab-ci/container/debian/x86_test-gl.sh index ce9bec8b9..9dc8b395d 100644 --- a/lib/mesa/.gitlab-ci/container/debian/x86_test-gl.sh +++ b/lib/mesa/.gitlab-ci/container/debian/x86_test-gl.sh @@ -22,6 +22,7 @@ STABLE_EPHEMERAL=" \ libcap-dev \ libclang-cpp11-dev \ libelf-dev \ + libexpat1-dev \ libfdt-dev \ libgbm-dev \ libgles2-mesa-dev \ @@ -31,7 +32,6 @@ STABLE_EPHEMERAL=" \ libudev-dev \ libvulkan-dev \ libwaffle-dev \ - libwayland-dev \ libx11-xcb-dev \ libxcb-dri2-0-dev \ libxext-dev \ @@ -45,20 +45,18 @@ STABLE_EPHEMERAL=" \ patch \ pkg-config \ python3-distutils \ - wayland-protocols \ - wget \ xz-utils \ " apt-get install -y --no-remove \ $STABLE_EPHEMERAL \ clinfo \ - inetutils-syslogd \ iptables \ libclang-common-11-dev \ libclang-cpp11 \ libcap2 \ libegl1 \ + libepoxy-dev \ libfdt1 \ libllvmspirvlib11 \ libxcb-shm0 \ @@ -66,12 +64,29 @@ apt-get install -y --no-remove \ python3-lxml \ python3-renderdoc \ python3-simplejson \ + socat \ spirv-tools \ - sysvinit-core + sysvinit-core \ + wget . .gitlab-ci/container/container_pre_build.sh +############### Build libdrm + +. .gitlab-ci/container/build-libdrm.sh + +############### Build Wayland + +. .gitlab-ci/container/build-wayland.sh + +############### Build Crosvm + +. .gitlab-ci/container/build-rust.sh +. .gitlab-ci/container/build-crosvm.sh +rm -rf /root/.cargo +rm -rf /root/.rustup + ############### Build kernel export DEFCONFIG="arch/x86/configs/x86_64_defconfig" @@ -82,28 +97,14 @@ export DEBIAN_ARCH=amd64 mkdir -p /lava-files/ . .gitlab-ci/container/build-kernel.sh -############### Build libdrm - -. .gitlab-ci/container/build-libdrm.sh - ############### Build libclc . .gitlab-ci/container/build-libclc.sh -############### Build virglrenderer - -. .gitlab-ci/container/build-virglrenderer.sh - ############### Build piglit PIGLIT_OPTS="-DPIGLIT_BUILD_CL_TESTS=ON -DPIGLIT_BUILD_DMA_BUF_TESTS=ON" . .gitlab-ci/container/build-piglit.sh -############### Build Crosvm - -. .gitlab-ci/container/build-rust.sh -. .gitlab-ci/container/build-crosvm.sh -rm -rf /root/.cargo - ############### Build dEQP GL DEQP_TARGET=surfaceless . .gitlab-ci/container/build-deqp.sh diff --git a/lib/mesa/.gitlab-ci/container/debian/x86_test-vk.sh b/lib/mesa/.gitlab-ci/container/debian/x86_test-vk.sh index b10d61162..67389861d 100644 --- a/lib/mesa/.gitlab-ci/container/debian/x86_test-vk.sh +++ b/lib/mesa/.gitlab-ci/container/debian/x86_test-vk.sh @@ -13,6 +13,7 @@ STABLE_EPHEMERAL=" \ g++-mingw-w64-i686-posix \ g++-mingw-w64-x86-64-posix \ glslang-tools \ + libexpat1-dev \ libgbm-dev \ libgles2-mesa-dev \ liblz4-dev \ @@ -20,7 +21,6 @@ STABLE_EPHEMERAL=" \ libudev-dev \ libvulkan-dev \ libwaffle-dev \ - libwayland-dev \ libx11-xcb-dev \ libxcb-ewmh-dev \ libxcb-keysyms1-dev \ @@ -124,6 +124,10 @@ wine \ . .gitlab-ci/container/build-libdrm.sh +############### Build Wayland + +. .gitlab-ci/container/build-wayland.sh + ############### Build parallel-deqp-runner's hang-detection tool . .gitlab-ci/container/build-hang-detection.sh diff --git a/lib/mesa/.gitlab-ci/container/fedora/x86_build.sh b/lib/mesa/.gitlab-ci/container/fedora/x86_build.sh index 718e49e93..e1841cfec 100644 --- a/lib/mesa/.gitlab-ci/container/fedora/x86_build.sh +++ b/lib/mesa/.gitlab-ci/container/fedora/x86_build.sh @@ -27,6 +27,7 @@ dnf install -y --setopt=install_weak_deps=False \ gettext \ kernel-headers \ llvm-devel \ + clang-devel \ meson \ "pkgconfig(dri2proto)" \ "pkgconfig(expat)" \ @@ -40,9 +41,6 @@ dnf install -y --setopt=install_weak_deps=False \ "pkgconfig(pciaccess)" \ "pkgconfig(vdpau)" \ "pkgconfig(vulkan)" \ - "pkgconfig(wayland-egl-backend)" \ - "pkgconfig(wayland-protocols)" \ - "pkgconfig(wayland-scanner)" \ "pkgconfig(x11)" \ "pkgconfig(x11-xcb)" \ "pkgconfig(xcb)" \ @@ -66,6 +64,8 @@ dnf install -y --setopt=install_weak_deps=False \ python3-devel \ python3-mako \ vulkan-headers \ + spirv-tools-devel \ + spirv-llvm-translator-devel \ $EPHEMERAL @@ -74,10 +74,8 @@ dnf install -y --setopt=install_weak_deps=False \ # dependencies where we want a specific version export XORG_RELEASES=https://xorg.freedesktop.org/releases/individual -export WAYLAND_RELEASES=https://wayland.freedesktop.org/releases export XORGMACROS_VERSION=util-macros-1.19.0 -export LIBWAYLAND_VERSION=wayland-1.18.0 wget $XORG_RELEASES/util/$XORGMACROS_VERSION.tar.bz2 tar -xvf $XORGMACROS_VERSION.tar.bz2 && rm $XORGMACROS_VERSION.tar.bz2 @@ -86,11 +84,7 @@ rm -rf $XORGMACROS_VERSION . .gitlab-ci/container/build-libdrm.sh -wget $WAYLAND_RELEASES/$LIBWAYLAND_VERSION.tar.xz -tar -xvf $LIBWAYLAND_VERSION.tar.xz && rm $LIBWAYLAND_VERSION.tar.xz -cd $LIBWAYLAND_VERSION; ./configure --enable-libraries --without-host-scanner --disable-documentation --disable-dtd-validation; make install; cd .. -rm -rf $LIBWAYLAND_VERSION - +. .gitlab-ci/container/build-wayland.sh pushd /usr/local git clone https://gitlab.freedesktop.org/mesa/shader-db.git --depth 1 diff --git a/lib/mesa/.gitlab-ci/container/gitlab-ci.yml b/lib/mesa/.gitlab-ci/container/gitlab-ci.yml new file mode 100644 index 000000000..aa4580bb3 --- /dev/null +++ b/lib/mesa/.gitlab-ci/container/gitlab-ci.yml @@ -0,0 +1,420 @@ +# Docker image tag helper templates + +.incorporate-templates-commit: + variables: + FDO_DISTRIBUTION_TAG: "${MESA_IMAGE_TAG}--${MESA_TEMPLATES_COMMIT}" + +.incorporate-base-tag+templates-commit: + variables: + FDO_BASE_IMAGE: "${CI_REGISTRY_IMAGE}/${MESA_BASE_IMAGE}:${MESA_BASE_TAG}--${MESA_TEMPLATES_COMMIT}" + FDO_DISTRIBUTION_TAG: "${MESA_IMAGE_TAG}--${MESA_BASE_TAG}--${MESA_TEMPLATES_COMMIT}" + +.set-image: + extends: + - .incorporate-templates-commit + variables: + MESA_IMAGE: "$CI_REGISTRY_IMAGE/${MESA_IMAGE_PATH}:${FDO_DISTRIBUTION_TAG}" + image: "$MESA_IMAGE" + +.set-image-base-tag: + extends: + - .set-image + - .incorporate-base-tag+templates-commit + variables: + MESA_IMAGE: "$CI_REGISTRY_IMAGE/${MESA_IMAGE_PATH}:${FDO_DISTRIBUTION_TAG}" + + +# Build the CI docker images. +# +# MESA_IMAGE_TAG is the tag of the docker image used by later stage jobs. If the +# image doesn't exist yet, the container stage job 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 +# recommended except for ephemeral images during development: Replacing +# an image after a significant amount of time might pull in newer +# versions of gcc/clang or other packages, which might break the build +# with older commits using the same tag. +# +# After merging a change resulting in generating a new image to the +# 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. + +.container: + stage: container + extends: + - .container-rules + - .incorporate-templates-commit + variables: + FDO_DISTRIBUTION_VERSION: bullseye-slim + FDO_REPO_SUFFIX: $CI_JOB_NAME + FDO_DISTRIBUTION_EXEC: 'env FDO_CI_CONCURRENT=${FDO_CI_CONCURRENT} bash .gitlab-ci/container/${CI_JOB_NAME}.sh' + # no need to pull the whole repo to build the container image + GIT_STRATEGY: none + +.use-base-image: + extends: + - .container + - .incorporate-base-tag+templates-commit + # Don't want the .container rules + - .ci-run-policy + +# Debian 11 based x86 build image base +debian/x86_build-base: + extends: + - .fdo.container-build@debian + - .container + variables: + MESA_IMAGE_TAG: &debian-x86_build-base ${DEBIAN_BASE_TAG} + +.use-debian/x86_build-base: + extends: + - .fdo.container-build@debian + - .use-base-image + variables: + MESA_BASE_IMAGE: ${DEBIAN_X86_BUILD_BASE_IMAGE} + MESA_BASE_TAG: *debian-x86_build-base + MESA_ARTIFACTS_BASE_TAG: *debian-x86_build-base + needs: + - debian/x86_build-base + +# Debian 11 based x86 main build image +debian/x86_build: + extends: + - .use-debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-x86_build ${DEBIAN_BUILD_TAG} + +.use-debian/x86_build: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_build-base + MESA_IMAGE_PATH: ${DEBIAN_X86_BUILD_IMAGE_PATH} + MESA_IMAGE_TAG: *debian-x86_build + needs: + - debian/x86_build + +# Debian 11 based i386 cross-build image +debian/i386_build: + extends: + - .use-debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-i386_build ${DEBIAN_BUILD_TAG} + +.use-debian/i386_build: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_build-base + MESA_IMAGE_PATH: "debian/i386_build" + MESA_IMAGE_TAG: *debian-i386_build + needs: + - debian/i386_build + +# Debian 11 based ppc64el cross-build image +debian/ppc64el_build: + extends: + - .use-debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-ppc64el_build ${DEBIAN_BUILD_TAG} + +.use-debian/ppc64el_build: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_build-base + MESA_IMAGE_PATH: "debian/ppc64el_build" + MESA_IMAGE_TAG: *debian-ppc64el_build + needs: + - debian/ppc64el_build + +# Debian 11 based s390x cross-build image +debian/s390x_build: + extends: + - .use-debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-s390x_build ${DEBIAN_BUILD_TAG} + +.use-debian/s390x_build: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_build-base + MESA_IMAGE_PATH: "debian/s390x_build" + MESA_IMAGE_TAG: *debian-s390x_build + needs: + - debian/s390x_build + +# Android NDK cross-build image +debian/android_build: + extends: + - .use-debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-android_build ${DEBIAN_BUILD_TAG} + +.use-debian/android_build: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_build-base + MESA_IMAGE_PATH: "debian/android_build" + MESA_IMAGE_TAG: *debian-android_build + needs: + - debian/android_build + +# Debian 11 based x86 test image base +debian/x86_test-base: + extends: debian/x86_build-base + variables: + MESA_IMAGE_TAG: &debian-x86_test-base ${DEBIAN_BASE_TAG} + +.use-debian/x86_test-base: + extends: + - .fdo.container-build@debian + - .use-base-image + variables: + MESA_BASE_IMAGE: ${DEBIAN_X86_TEST_BASE_IMAGE} + MESA_BASE_TAG: *debian-x86_test-base + needs: + - debian/x86_test-base + +# Debian 11 based x86 test image for GL +debian/x86_test-gl: + extends: .use-debian/x86_test-base + variables: + FDO_DISTRIBUTION_EXEC: 'env KERNEL_URL=${KERNEL_URL} FDO_CI_CONCURRENT=${FDO_CI_CONCURRENT} bash .gitlab-ci/container/${CI_JOB_NAME}.sh' + KERNEL_URL: &kernel-rootfs-url "https://gitlab.freedesktop.org/gfx-ci/linux/-/archive/v5.16-for-mesa-ci-991fec6622591/linux-v5.16-for-mesa-ci-991fec6622591.tar.bz2" + MESA_IMAGE_TAG: &debian-x86_test-gl ${DEBIAN_X86_TEST_GL_TAG} + +.use-debian/x86_test-gl: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_test-base + MESA_IMAGE_PATH: ${DEBIAN_X86_TEST_IMAGE_PATH} + MESA_IMAGE_TAG: *debian-x86_test-gl + needs: + - debian/x86_test-gl + +# Debian 11 based x86 test image for VK +debian/x86_test-vk: + extends: .use-debian/x86_test-base + variables: + MESA_IMAGE_TAG: &debian-x86_test-vk ${DEBIAN_X86_TEST_VK_TAG} + +.use-debian/x86_test-vk: + extends: + - .set-image-base-tag + variables: + MESA_BASE_TAG: *debian-x86_test-base + MESA_IMAGE_PATH: "debian/x86_test-vk" + MESA_IMAGE_TAG: *debian-x86_test-vk + needs: + - debian/x86_test-vk + +# Debian 11 based ARM build image +debian/arm_build: + extends: + - .fdo.container-build@debian + - .container + tags: + - aarch64 + variables: + MESA_IMAGE_TAG: &debian-arm_build ${DEBIAN_BASE_TAG} + +.use-debian/arm_build: + extends: + - .set-image + variables: + MESA_IMAGE_PATH: "debian/arm_build" + MESA_IMAGE_TAG: *debian-arm_build + MESA_ARTIFACTS_TAG: *debian-arm_build + needs: + - debian/arm_build + + +# Fedora 34 based x86 build image +fedora/x86_build: + extends: + - .fdo.container-build@fedora + - .container + variables: + FDO_DISTRIBUTION_VERSION: 34 + MESA_IMAGE_TAG: &fedora-x86_build ${FEDORA_X86_BUILD_TAG} + +.use-fedora/x86_build: + extends: + - .set-image + variables: + MESA_IMAGE_PATH: "fedora/x86_build" + MESA_IMAGE_TAG: *fedora-x86_build + needs: + - fedora/x86_build + + +.kernel+rootfs: + extends: + - .ci-run-policy + stage: container + variables: + GIT_STRATEGY: fetch + KERNEL_URL: *kernel-rootfs-url + MESA_ROOTFS_TAG: &kernel-rootfs ${KERNEL_ROOTFS_TAG} + DISTRIBUTION_TAG: &distribution-tag-arm "${MESA_ROOTFS_TAG}--${MESA_ARTIFACTS_TAG}--${MESA_TEMPLATES_COMMIT}" + script: + - .gitlab-ci/container/lava_build.sh + +kernel+rootfs_amd64: + extends: + - .use-debian/x86_build-base + - .kernel+rootfs + image: "$FDO_BASE_IMAGE" + variables: + DEBIAN_ARCH: "amd64" + DISTRIBUTION_TAG: &distribution-tag-amd64 "${MESA_ROOTFS_TAG}--${MESA_ARTIFACTS_BASE_TAG}--${MESA_TEMPLATES_COMMIT}" + +kernel+rootfs_arm64: + extends: + - .use-debian/arm_build + - .kernel+rootfs + tags: + - aarch64 + variables: + DEBIAN_ARCH: "arm64" + +kernel+rootfs_armhf: + extends: + - kernel+rootfs_arm64 + variables: + DEBIAN_ARCH: "armhf" + +# Cannot use anchors defined here from included files, so use extends: instead +.use-kernel+rootfs-arm: + variables: + DISTRIBUTION_TAG: *distribution-tag-arm + MESA_ROOTFS_TAG: *kernel-rootfs + +.use-kernel+rootfs-amd64: + variables: + DISTRIBUTION_TAG: *distribution-tag-amd64 + MESA_ROOTFS_TAG: *kernel-rootfs + +# x86 image with ARM64 & armhf kernel & rootfs for baremetal testing +debian/arm_test: + extends: + - .fdo.container-build@debian + - .container + # Don't want the .container rules + - .ci-run-policy + needs: + - kernel+rootfs_arm64 + - kernel+rootfs_armhf + variables: + FDO_DISTRIBUTION_EXEC: 'env ARTIFACTS_PREFIX=https://${MINIO_HOST}/mesa-lava ARTIFACTS_SUFFIX=${MESA_ROOTFS_TAG}--${MESA_ARM_BUILD_TAG}--${MESA_TEMPLATES_COMMIT} CI_PROJECT_PATH=${CI_PROJECT_PATH} FDO_CI_CONCURRENT=${FDO_CI_CONCURRENT} FDO_UPSTREAM_REPO=${FDO_UPSTREAM_REPO} bash .gitlab-ci/container/${CI_JOB_NAME}.sh' + FDO_DISTRIBUTION_TAG: "${MESA_IMAGE_TAG}--${MESA_ROOTFS_TAG}--${MESA_ARM_BUILD_TAG}--${MESA_TEMPLATES_COMMIT}" + MESA_ARM_BUILD_TAG: *debian-arm_build + MESA_IMAGE_TAG: &debian-arm_test ${DEBIAN_BASE_TAG} + MESA_ROOTFS_TAG: *kernel-rootfs + +.use-debian/arm_test: + image: "$CI_REGISTRY_IMAGE/${MESA_IMAGE_PATH}:${MESA_IMAGE_TAG}--${MESA_ROOTFS_TAG}--${MESA_ARM_BUILD_TAG}--${MESA_TEMPLATES_COMMIT}" + variables: + MESA_ARM_BUILD_TAG: *debian-arm_build + MESA_IMAGE_PATH: "debian/arm_test" + MESA_IMAGE_TAG: *debian-arm_test + MESA_ROOTFS_TAG: *kernel-rootfs + needs: + - debian/arm_test + +# Native Windows docker builds +# +# Unlike the above Linux-based builds - including MinGW builds which +# cross-compile for Windows - which use the freedesktop ci-templates, we +# cannot use the same scheme here. As Windows lacks support for +# Docker-in-Docker, and Podman does not run natively on Windows, we have +# to open-code much of the same ourselves. +# +# This is achieved by first running in a native Windows shell instance +# (host PowerShell) in the container stage to build and push the image, +# then in the build stage by executing inside Docker. + +.windows-docker-vs2019: + variables: + MESA_IMAGE: "$CI_REGISTRY_IMAGE/${MESA_IMAGE_PATH}:${MESA_IMAGE_TAG}" + MESA_UPSTREAM_IMAGE: "$CI_REGISTRY/$FDO_UPSTREAM_REPO/$MESA_IMAGE_PATH:${MESA_IMAGE_TAG}" + +.windows_container_build: + inherit: + default: false + extends: + - .container + - .windows-docker-vs2019 + rules: + - if: '$MICROSOFT_FARM == "offline"' + when: never + - !reference [.container-rules, rules] + variables: + GIT_STRATEGY: fetch # we do actually need the full repository though + MESA_BASE_IMAGE: None + tags: + - windows + - shell + - "1809" + - mesa + script: + - .\.gitlab-ci\windows\mesa_container.ps1 $CI_REGISTRY $CI_REGISTRY_USER $CI_REGISTRY_PASSWORD $MESA_IMAGE $MESA_UPSTREAM_IMAGE ${DOCKERFILE} ${MESA_BASE_IMAGE} + +windows_build_vs2019: + inherit: + default: false + extends: + - .windows_container_build + variables: + MESA_IMAGE_PATH: &windows_build_image_path ${WINDOWS_X64_BUILD_PATH} + MESA_IMAGE_TAG: &windows_build_image_tag ${WINDOWS_X64_BUILD_TAG} + DOCKERFILE: Dockerfile_build + timeout: 2h 30m # LLVM takes ages + +windows_test_vs2019: + inherit: + default: false + extends: + - .windows_container_build + rules: + - if: '$MICROSOFT_FARM == "offline"' + when: never + - !reference [.ci-run-policy, rules] + variables: + MESA_IMAGE_PATH: &windows_test_image_path ${WINDOWS_X64_TEST_PATH} + MESA_IMAGE_TAG: &windows_test_image_tag ${WINDOWS_X64_BUILD_TAG}--${WINDOWS_X64_TEST_TAG} + DOCKERFILE: Dockerfile_test + # Right now this only needs the VS install to get DXIL.dll. Maybe see about decoupling this at some point + MESA_BASE_IMAGE_PATH: *windows_build_image_path + MESA_BASE_IMAGE_TAG: *windows_build_image_tag + MESA_BASE_IMAGE: "$CI_REGISTRY_IMAGE/${MESA_BASE_IMAGE_PATH}:${MESA_BASE_IMAGE_TAG}" + script: + - .\.gitlab-ci\windows\mesa_container.ps1 $CI_REGISTRY $CI_REGISTRY_USER $CI_REGISTRY_PASSWORD $MESA_IMAGE $MESA_UPSTREAM_IMAGE Dockerfile_test ${MESA_BASE_IMAGE} + needs: + - windows_build_vs2019 + +.use-windows_build_vs2019: + inherit: + default: false + extends: .windows-docker-vs2019 + image: "$MESA_IMAGE" + variables: + MESA_IMAGE_PATH: *windows_build_image_path + MESA_IMAGE_TAG: *windows_build_image_tag + needs: + - windows_build_vs2019 + +.use-windows_test_vs2019: + inherit: + default: false + extends: .windows-docker-vs2019 + image: "$MESA_IMAGE" + variables: + MESA_IMAGE_PATH: *windows_test_image_path + MESA_IMAGE_TAG: *windows_test_image_tag diff --git a/lib/mesa/.gitlab-ci/container/lava_build.sh b/lib/mesa/.gitlab-ci/container/lava_build.sh index bd0f04021..3b9216197 100755 --- a/lib/mesa/.gitlab-ci/container/lava_build.sh +++ b/lib/mesa/.gitlab-ci/container/lava_build.sh @@ -34,6 +34,7 @@ if [[ "$DEBIAN_ARCH" = "arm64" ]]; then DEVICE_TREES+=" arch/arm64/boot/dts/qcom/apq8096-db820c.dtb" DEVICE_TREES+=" arch/arm64/boot/dts/amlogic/meson-g12b-a311d-khadas-vim3.dtb" DEVICE_TREES+=" arch/arm64/boot/dts/mediatek/mt8183-kukui-jacuzzi-juniper-sku16.dtb" + DEVICE_TREES+=" arch/arm64/boot/dts/nvidia/tegra210-p3450-0000.dtb" DEVICE_TREES+=" arch/arm64/boot/dts/qcom/sc7180-trogdor-lazor-limozeen-nots.dtb" KERNEL_IMAGE_NAME="Image" elif [[ "$DEBIAN_ARCH" = "armhf" ]]; then @@ -51,7 +52,7 @@ else DEFCONFIG="arch/x86/configs/x86_64_defconfig" DEVICE_TREES="" KERNEL_IMAGE_NAME="bzImage" - ARCH_PACKAGES="libva-dev" + ARCH_PACKAGES="libasound2-dev libcap-dev libfdt-dev libva-dev wayland-protocols" fi # Determine if we're in a cross build. @@ -76,14 +77,20 @@ apt-get install -y --no-remove \ ${ARCH_PACKAGES} \ automake \ bc \ + clang \ cmake \ debootstrap \ git \ glslang-tools \ libdrm-dev \ libegl1-mesa-dev \ + libxext-dev \ + libfontconfig-dev \ libgbm-dev \ + libgl-dev \ libgles2-mesa-dev \ + libglu1-mesa-dev \ + libglx-dev \ libpng-dev \ libssl-dev \ libudev-dev \ @@ -93,11 +100,14 @@ apt-get install -y --no-remove \ libx11-xcb-dev \ libxcb-dri2-0-dev \ libxkbcommon-dev \ + ninja-build \ patch \ + python-is-python3 \ python3-distutils \ python3-mako \ python3-numpy \ python3-serial \ + unzip \ wget @@ -119,7 +129,7 @@ fi ############### Building STRIP_CMD="${GCC_ARCH}-strip" -mkdir -p /lava-files/rootfs-${DEBIAN_ARCH} +mkdir -p /lava-files/rootfs-${DEBIAN_ARCH}/usr/lib/$GCC_ARCH ############### Build apitrace @@ -141,6 +151,13 @@ DEQP_TARGET=surfaceless . .gitlab-ci/container/build-deqp.sh mv /deqp /lava-files/rootfs-${DEBIAN_ARCH}/. +############### Build SKQP +if [[ "$DEBIAN_ARCH" = "arm64" ]]; then + SKQP_ARCH="arm64" . .gitlab-ci/container/build-skqp.sh + mv /skqp /lava-files/rootfs-${DEBIAN_ARCH}/. +fi + + ############### Build piglit PIGLIT_OPTS="-DPIGLIT_BUILD_DMA_BUF_TESTS=ON" . .gitlab-ci/container/build-piglit.sh mv /piglit /lava-files/rootfs-${DEBIAN_ARCH}/. @@ -151,15 +168,32 @@ if [[ "$DEBIAN_ARCH" = "amd64" ]]; then mv /va/bin/* /lava-files/rootfs-${DEBIAN_ARCH}/usr/bin/ fi +############### Build Crosvm +if [[ ${DEBIAN_ARCH} = "amd64" ]]; then + . .gitlab-ci/container/build-crosvm.sh + mv /usr/local/bin/crosvm /lava-files/rootfs-${DEBIAN_ARCH}/usr/bin/ + mv /usr/local/lib/$GCC_ARCH/libvirglrenderer.* /lava-files/rootfs-${DEBIAN_ARCH}/usr/lib/$GCC_ARCH/ +fi + ############### Build libdrm EXTRA_MESON_ARGS+=" -D prefix=/libdrm" . .gitlab-ci/container/build-libdrm.sh + +############### Build local stuff for use by igt and kernel testing, which +############### will reuse most of our container build process from a specific +############### hash of the Mesa tree. +if [[ -e ".gitlab-ci/local/build-rootfs.sh" ]]; then + . .gitlab-ci/local/build-rootfs.sh +fi + + ############### Build kernel . .gitlab-ci/container/build-kernel.sh ############### Delete rust, since the tests won't be compiling anything. rm -rf /root/.cargo +rm -rf /root/.rustup ############### Create rootfs set +e @@ -184,7 +218,6 @@ rm /lava-files/rootfs-${DEBIAN_ARCH}/create-rootfs.sh # Dependencies pulled during the creation of the rootfs may overwrite # the built libdrm. Hence, we add it after the rootfs has been already # created. -mkdir -p /lava-files/rootfs-${DEBIAN_ARCH}/usr/lib/$GCC_ARCH find /libdrm/ -name lib\*\.so\* | xargs cp -t /lava-files/rootfs-${DEBIAN_ARCH}/usr/lib/$GCC_ARCH/. mkdir -p /lava-files/rootfs-${DEBIAN_ARCH}/libdrm/ cp -Rp /libdrm/share /lava-files/rootfs-${DEBIAN_ARCH}/libdrm/share @@ -205,7 +238,7 @@ popd . .gitlab-ci/container/container_post_build.sh ############### Upload the files! -ci-fairy minio login $CI_JOB_JWT +ci-fairy minio login --token-file "${CI_JOB_JWT_FILE}" FILES_TO_UPLOAD="lava-rootfs.tgz \ $KERNEL_IMAGE_NAME" diff --git a/lib/mesa/.gitlab-ci/container/x86_64.config b/lib/mesa/.gitlab-ci/container/x86_64.config index 1859540fb..8f2cec020 100644 --- a/lib/mesa/.gitlab-ci/container/x86_64.config +++ b/lib/mesa/.gitlab-ci/container/x86_64.config @@ -72,9 +72,11 @@ CONFIG_PARPORT_PC=y CONFIG_PARPORT_SERIAL=y CONFIG_SERIAL_8250_DW=y CONFIG_CHROME_PLATFORMS=y +CONFIG_KVM_AMD=m #options for Intel devices CONFIG_MFD_INTEL_LPSS_PCI=y +CONFIG_KVM_INTEL=m #options for KVM guests CONFIG_FUSE_FS=y @@ -98,3 +100,6 @@ CONFIG_CRYPTO_DEV_VIRTIO=y CONFIG_HW_RANDOM_VIRTIO=y CONFIG_BLK_MQ_VIRTIO=y CONFIG_TUN=y +CONFIG_VSOCKETS=y +CONFIG_VIRTIO_VSOCKETS=y +CONFIG_VHOST_VSOCK=m diff --git a/lib/mesa/.gitlab-ci/cross-xfail-s390x b/lib/mesa/.gitlab-ci/cross-xfail-s390x index 2bfef18e6..3c3c8ac0c 100644 --- a/lib/mesa/.gitlab-ci/cross-xfail-s390x +++ b/lib/mesa/.gitlab-ci/cross-xfail-s390x @@ -1,2 +1 @@ -lp_test_arit lp_test_format diff --git a/lib/mesa/.gitlab-ci/crosvm-init.sh b/lib/mesa/.gitlab-ci/crosvm-init.sh index 63124fe0f..15e68f835 100755 --- a/lib/mesa/.gitlab-ci/crosvm-init.sh +++ b/lib/mesa/.gitlab-ci/crosvm-init.sh @@ -1,27 +1,42 @@ #!/bin/sh -set -ex +set -e + +VSOCK_STDOUT=$1 +VSOCK_STDERR=$2 +VSOCK_TEMP_DIR=$3 mount -t proc none /proc mount -t sysfs none /sys -mount -t devtmpfs none /dev || echo possibly already mounted mkdir -p /dev/pts mount -t devpts devpts /dev/pts mount -t tmpfs tmpfs /tmp -. /crosvm-env.sh +. ${VSOCK_TEMP_DIR}/crosvm-env.sh -# / is ro -export PIGLIT_REPLAY_EXTRA_ARGS="$PIGLIT_REPLAY_EXTRA_ARGS --db-path /tmp/replayer-db" +# .gitlab-ci.yml script variable is using relative paths to install directory, +# so change to that dir before running `crosvm-script` +cd "${CI_PROJECT_DIR}" -if sh $CROSVM_TEST_SCRIPT; then - touch /results/success -fi +# The exception is the dEQP binary, as it needs to run from its own directory +[ -z "${DEQP_BIN_DIR}" ] || cd "${DEQP_BIN_DIR}" -sleep 5 # Leave some time to get the last output flushed out +# Use a FIFO to collect relevant error messages +STDERR_FIFO=/tmp/crosvm-stderr.fifo +mkfifo -m 600 ${STDERR_FIFO} -poweroff -d -n -f || true +dmesg --level crit,err,warn -w > ${STDERR_FIFO} & +DMESG_PID=$! + +# Transfer the errors and crosvm-script output via a pair of virtio-vsocks +socat -d -u pipe:${STDERR_FIFO} vsock-listen:${VSOCK_STDERR} & +socat -d -U vsock-listen:${VSOCK_STDOUT} \ + system:"stdbuf -eL sh ${VSOCK_TEMP_DIR}/crosvm-script.sh 2> ${STDERR_FIFO}; echo \$? > ${VSOCK_TEMP_DIR}/exit_code",nofork -sleep 10 # Just in case init would exit before the kernel shuts down the VM +kill ${DMESG_PID} +wait + +sync +poweroff -d -n -f || true -exit 1 +sleep 1 # Just in case init would exit before the kernel shuts down the VM diff --git a/lib/mesa/.gitlab-ci/crosvm-runner.sh b/lib/mesa/.gitlab-ci/crosvm-runner.sh index b3ddfcf16..82cc37fb1 100755 --- a/lib/mesa/.gitlab-ci/crosvm-runner.sh +++ b/lib/mesa/.gitlab-ci/crosvm-runner.sh @@ -1,49 +1,125 @@ #!/bin/sh -set -x +set -e -ln -sf $CI_PROJECT_DIR/install /install +# +# Helper to generate CIDs for virtio-vsock based communication with processes +# running inside crosvm guests. +# +# A CID is a 32-bit Context Identifier to be assigned to a crosvm instance +# and must be unique across the host system. For this purpose, let's take +# the least significant 25 bits from CI_JOB_ID as a base and generate a 7-bit +# prefix number to handle up to 128 concurrent crosvm instances per job runner. +# +# As a result, the following variables are set: +# - VSOCK_CID: the crosvm unique CID to be passed as a run argument +# +# - VSOCK_STDOUT, VSOCK_STDERR: the port numbers the guest should accept +# vsock connections on in order to transfer output messages +# +# - VSOCK_TEMP_DIR: the temporary directory path used to pass additional +# context data towards the guest +# +set_vsock_context() { + [ -n "${CI_JOB_ID}" ] || { + echo "Missing or unset CI_JOB_ID env variable" >&2 + exit 1 + } -export LD_LIBRARY_PATH=$CI_PROJECT_DIR/install/lib/ -export EGL_PLATFORM=surfaceless + local dir_prefix="/tmp-vsock." + local cid_prefix=0 + unset VSOCK_TEMP_DIR -export -p > /crosvm-env.sh -export GALLIUM_DRIVER="$CROSVM_GALLIUM_DRIVER" -export GALLIVM_PERF="nopt" -export LIBGL_ALWAYS_SOFTWARE="true" + while [ ${cid_prefix} -lt 128 ]; do + VSOCK_TEMP_DIR=${dir_prefix}${cid_prefix} + mkdir "${VSOCK_TEMP_DIR}" >/dev/null 2>&1 && break || unset VSOCK_TEMP_DIR + cid_prefix=$((cid_prefix + 1)) + done -CROSVM_KERNEL_ARGS="root=my_root rw rootfstype=virtiofs loglevel=3 init=$CI_PROJECT_DIR/install/crosvm-init.sh ip=192.168.30.2::192.168.30.1:255.255.255.0:crosvm:eth0" + [ -n "${VSOCK_TEMP_DIR}" ] || return 1 -# Temporary results dir because from the guest we cannot write to / -mkdir -p /results -mount -t tmpfs tmpfs /results + VSOCK_CID=$(((CI_JOB_ID & 0x1ffffff) | ((cid_prefix & 0x7f) << 25))) + VSOCK_STDOUT=5001 + VSOCK_STDERR=5002 -mkdir -p /piglit/.gitlab-ci/piglit -mount -t tmpfs tmpfs /piglit/.gitlab-ci/piglit + return 0 +} +# The dEQP binary needs to run from the directory it's in +if [ -n "${1##*.sh}" ] && [ -z "${1##*"deqp"*}" ]; then + DEQP_BIN_DIR=$(dirname "$1") + export DEQP_BIN_DIR +fi + +set_vsock_context || { echo "Could not generate crosvm vsock CID" >&2; exit 1; } + +# Ensure cleanup on script exit +trap 'exit ${exit_code}' INT TERM +trap 'exit_code=$?; [ -z "${CROSVM_PID}${SOCAT_PIDS}" ] || kill ${CROSVM_PID} ${SOCAT_PIDS} >/dev/null 2>&1 || true; rm -rf ${VSOCK_TEMP_DIR}' EXIT + +# Securely pass the current variables to the crosvm environment +echo "Variables passed through:" +SCRIPT_DIR=$(readlink -en "${0%/*}") +${SCRIPT_DIR}/common/generate-env.sh | tee ${VSOCK_TEMP_DIR}/crosvm-env.sh + +# Set the crosvm-script as the arguments of the current script +echo "$@" > ${VSOCK_TEMP_DIR}/crosvm-script.sh + +# Setup networking +/usr/sbin/iptables-legacy -w -t nat -A POSTROUTING -o eth0 -j MASQUERADE +echo 1 > /proc/sys/net/ipv4/ip_forward + +# Start background processes to receive output from guest +socat -u vsock-connect:${VSOCK_CID}:${VSOCK_STDERR},retry=200,interval=0.1 stderr & +SOCAT_PIDS=$! +socat -u vsock-connect:${VSOCK_CID}:${VSOCK_STDOUT},retry=200,interval=0.1 stdout & +SOCAT_PIDS="${SOCAT_PIDS} $!" + +# Prepare to start crosvm unset DISPLAY unset XDG_RUNTIME_DIR -/usr/sbin/iptables-legacy -t nat -A POSTROUTING -o eth0 -j MASQUERADE -echo 1 > /proc/sys/net/ipv4/ip_forward +CROSVM_KERN_ARGS="quiet console=null root=my_root rw rootfstype=virtiofs ip=192.168.30.2::192.168.30.1:255.255.255.0:crosvm:eth0" +CROSVM_KERN_ARGS="${CROSVM_KERN_ARGS} init=${SCRIPT_DIR}/crosvm-init.sh -- ${VSOCK_STDOUT} ${VSOCK_STDERR} ${VSOCK_TEMP_DIR}" -# Crosvm wants this -syslogd > /dev/null +[ "${CROSVM_GALLIUM_DRIVER}" = "llvmpipe" ] && \ + CROSVM_LIBGL_ALWAYS_SOFTWARE=true || CROSVM_LIBGL_ALWAYS_SOFTWARE=false -# We aren't testing LLVMPipe here, so we don't need to validate NIR on the host -export NIR_VALIDATE=0 +set +e -x +# We aren't testing the host driver here, so we don't need to validate NIR on the host +NIR_DEBUG="novalidate" \ +LIBGL_ALWAYS_SOFTWARE=${CROSVM_LIBGL_ALWAYS_SOFTWARE} \ +GALLIUM_DRIVER=${CROSVM_GALLIUM_DRIVER} \ crosvm run \ - --gpu "$CROSVM_GPU_ARGS" \ - -m 4096 \ - -c $((FDO_CI_CONCURRENT > 1 ? FDO_CI_CONCURRENT - 1 : 1)) \ - --disable-sandbox \ - --shared-dir /:my_root:type=fs:writeback=true:timeout=60:cache=always \ - --host_ip=192.168.30.1 --netmask=255.255.255.0 --mac "AA:BB:CC:00:00:12" \ - -p "$CROSVM_KERNEL_ARGS" \ - /lava-files/bzImage - -mkdir -p $CI_PROJECT_DIR/results -mv /results/* $CI_PROJECT_DIR/results/. - -test -f $CI_PROJECT_DIR/results/success + --gpu "${CROSVM_GPU_ARGS}" -m 4096 -c 2 --disable-sandbox \ + --shared-dir /:my_root:type=fs:writeback=true:timeout=60:cache=always \ + --host_ip "192.168.30.1" --netmask "255.255.255.0" --mac "AA:BB:CC:00:00:12" \ + --cid ${VSOCK_CID} -p "${CROSVM_KERN_ARGS}" \ + /lava-files/${KERNEL_IMAGE_NAME:-bzImage} > ${VSOCK_TEMP_DIR}/crosvm 2>&1 & + +# Wait for crosvm process to terminate +CROSVM_PID=$! +wait ${CROSVM_PID} +CROSVM_RET=$? +unset CROSVM_PID + +[ ${CROSVM_RET} -eq 0 ] && { + # socat background processes terminate gracefully on remote peers exit + wait + unset SOCAT_PIDS + # The actual return code is the crosvm guest script's exit code + CROSVM_RET=$(cat ${VSOCK_TEMP_DIR}/exit_code 2>/dev/null) + # Force error when the guest script's exit code is not available + CROSVM_RET=${CROSVM_RET:-1} +} + +# Show crosvm output on error to help with debugging +[ ${CROSVM_RET} -eq 0 ] || { + set +x + echo "Dumping crosvm output.." >&2 + cat ${VSOCK_TEMP_DIR}/crosvm >&2 + set -x +} + +exit ${CROSVM_RET} diff --git a/lib/mesa/.gitlab-ci/deqp-runner.sh b/lib/mesa/.gitlab-ci/deqp-runner.sh index ea1b81564..a04cbc929 100755 --- a/lib/mesa/.gitlab-ci/deqp-runner.sh +++ b/lib/mesa/.gitlab-ci/deqp-runner.sh @@ -1,7 +1,12 @@ #!/bin/sh +echo -e "\e[0Ksection_start:$(date +%s):test_setup[collapsed=true]\r\e[0Kpreparing test setup" + set -ex +# Needed so configuration files can contain paths to files in /install +ln -sf $CI_PROJECT_DIR/install /install + if [ -z "$GPU_VERSION" ]; then echo 'GPU_VERSION must be set to something like "llvmpipe" or "freedreno-a630" (the name used in .gitlab-ci/gpu-version-*.txt)' exit 1 @@ -17,6 +22,15 @@ export VK_ICD_FILENAMES=`pwd`/install/share/vulkan/icd.d/"$VK_DRIVER"_icd.${VK_C RESULTS=`pwd`/${DEQP_RESULTS_DIR:-results} mkdir -p $RESULTS +# Ensure Mesa Shader Cache resides on tmpfs. +SHADER_CACHE_HOME=${XDG_CACHE_HOME:-${HOME}/.cache} +SHADER_CACHE_DIR=${MESA_SHADER_CACHE_DIR:-${SHADER_CACHE_HOME}/mesa_shader_cache} + +findmnt -n tmpfs ${SHADER_CACHE_HOME} || findmnt -n tmpfs ${SHADER_CACHE_DIR} || { + mkdir -p ${SHADER_CACHE_DIR} + mount -t tmpfs -o nosuid,nodev,size=2G,mode=1755 tmpfs ${SHADER_CACHE_DIR} +} + HANG_DETECTION_CMD="" if [ -z "$DEQP_SUITE" ]; then @@ -109,8 +123,6 @@ if [ -e "$INSTALL/$GPU_VERSION-skips.txt" ]; then DEQP_SKIPS="$DEQP_SKIPS $INSTALL/$GPU_VERSION-skips.txt" fi -set +e - report_load() { echo "System load: $(cut -d' ' -f1-3 < /proc/loadavg)" echo "# of CPU cores: $(cat /proc/cpuinfo | grep processor | wc -l)" @@ -133,7 +145,6 @@ if [ "$GALLIUM_DRIVER" = "virpipe" ]; then fi GALLIUM_DRIVER=llvmpipe \ - GALLIVM_PERF="nopt" \ virgl_test_server $VTEST_ARGS >$RESULTS/vtest-log.txt 2>&1 & sleep 1 @@ -146,7 +157,16 @@ if [ -z "$DEQP_SUITE" ]; then if [ $DEQP_VER != vk -a $DEQP_VER != egl ]; then export DEQP_RUNNER_OPTIONS="$DEQP_RUNNER_OPTIONS --version-check `cat $INSTALL/VERSION | sed 's/[() ]/./g'`" fi +fi +set +x +echo -e "\e[0Ksection_end:$(date +%s):test_setup\r\e[0K" + +echo -e "\e[0Ksection_start:$(date +%s):deqp[collapsed=false]\r\e[0Kdeqp-runner" +set -x + +set +e +if [ -z "$DEQP_SUITE" ]; then deqp-runner \ run \ --deqp $DEQP \ @@ -168,14 +188,20 @@ else --flakes $INSTALL/$GPU_VERSION-flakes.txt \ --testlog-to-xml /deqp/executor/testlog-to-xml \ --fraction-start $CI_NODE_INDEX \ - --fraction $CI_NODE_TOTAL \ + --fraction `expr $CI_NODE_TOTAL \* ${DEQP_FRACTION:-1}` \ --jobs ${FDO_CI_CONCURRENT:-4} \ $DEQP_RUNNER_OPTIONS fi DEQP_EXITCODE=$? -quiet report_load +set +x +echo -e "\e[0Ksection_end:$(date +%s):deqp\r\e[0K" + +report_load + +echo -e "\e[0Ksection_start:$(date +%s):test_post_process[collapsed=true]\r\e[0Kpost-processing test results" +set -x # Remove all but the first 50 individual XML files uploaded as artifacts, to # save fd.o space when you break everything. @@ -211,4 +237,6 @@ if [ -n "$FLAKES_CHANNEL" ]; then --branch-title "${CI_MERGE_REQUEST_TITLE:-$CI_COMMIT_TITLE}" fi +echo -e "\e[0Ksection_end:$(date +%s):test_post_process\r\e[0K" + exit $DEQP_EXITCODE diff --git a/lib/mesa/.gitlab-ci/download-git-cache.sh b/lib/mesa/.gitlab-ci/download-git-cache.sh index d7c7d72c9..ece216017 100644 --- a/lib/mesa/.gitlab-ci/download-git-cache.sh +++ b/lib/mesa/.gitlab-ci/download-git-cache.sh @@ -5,7 +5,7 @@ set -o xtrace # if we run this script outside of gitlab-ci for testing, ensure # we got meaningful variables -CI_PROJECT_DIR=${CI_PROJECT_DIR:-$(mktemp -d)/mesa} +CI_PROJECT_DIR=${CI_PROJECT_DIR:-$(mktemp -d)/$CI_PROJECT_NAME} if [[ -e $CI_PROJECT_DIR/.git ]] then @@ -16,8 +16,8 @@ fi TMP_DIR=$(mktemp -d) echo "Downloading archived master..." -/usr/bin/wget -O $TMP_DIR/mesa.tar.gz \ - https://${MINIO_HOST}/git-cache/${FDO_UPSTREAM_REPO}/mesa.tar.gz +/usr/bin/wget -O $TMP_DIR/$CI_PROJECT_NAME.tar.gz \ + https://${MINIO_HOST}/git-cache/${FDO_UPSTREAM_REPO}/$CI_PROJECT_NAME.tar.gz # check wget error code if [[ $? -ne 0 ]] @@ -31,6 +31,6 @@ set -e rm -rf "$CI_PROJECT_DIR" echo "Extracting tarball into '$CI_PROJECT_DIR'..." mkdir -p "$CI_PROJECT_DIR" -tar xzf "$TMP_DIR/mesa.tar.gz" -C "$CI_PROJECT_DIR" +tar xzf "$TMP_DIR/$CI_PROJECT_NAME.tar.gz" -C "$CI_PROJECT_DIR" rm -rf "$TMP_DIR" chmod a+w "$CI_PROJECT_DIR" diff --git a/lib/mesa/.gitlab-ci/image-tags.yml b/lib/mesa/.gitlab-ci/image-tags.yml new file mode 100644 index 000000000..34985f5a3 --- /dev/null +++ b/lib/mesa/.gitlab-ci/image-tags.yml @@ -0,0 +1,21 @@ +variables: + DEBIAN_X86_BUILD_BASE_IMAGE: "debian/x86_build-base" + DEBIAN_BASE_TAG: "2022-02-21-libdrm" + + DEBIAN_X86_BUILD_IMAGE_PATH: "debian/x86_build" + DEBIAN_BUILD_TAG: "2022-02-21-libdrm" + + DEBIAN_X86_TEST_BASE_IMAGE: "debian/x86_test-base" + + DEBIAN_X86_TEST_IMAGE_PATH: "debian/x86_test-gl" + DEBIAN_X86_TEST_GL_TAG: "2022-04-07-virgl-crosvm" + DEBIAN_X86_TEST_VK_TAG: "2022-04-05-deqp-runner" + + FEDORA_X86_BUILD_TAG: "2022-03-18-spirv-tools-5" + KERNEL_ROOTFS_TAG: "2022-04-07-prefix-skqp" + + WINDOWS_X64_BUILD_PATH: "windows/x64_build" + WINDOWS_X64_BUILD_TAG: "2022-20-02-base_split" + + WINDOWS_X64_TEST_PATH: "windows/x64_test" + WINDOWS_X64_TEST_TAG: "2022-04-13-dozen_ci" diff --git a/lib/mesa/.gitlab-ci/lava/lava-gitlab-ci.yml b/lib/mesa/.gitlab-ci/lava/lava-gitlab-ci.yml index 7bd368468..6c9cd5652 100755 --- a/lib/mesa/.gitlab-ci/lava/lava-gitlab-ci.yml +++ b/lib/mesa/.gitlab-ci/lava/lava-gitlab-ci.yml @@ -14,20 +14,23 @@ BASE_SYSTEM_MAINLINE_HOST_PATH: "${BASE_SYSTEM_HOST_PREFIX}/${FDO_UPSTREAM_REPO}/${DISTRIBUTION_TAG}/${ARCH}" BASE_SYSTEM_FORK_HOST_PATH: "${BASE_SYSTEM_HOST_PREFIX}/${CI_PROJECT_PATH}/${DISTRIBUTION_TAG}/${ARCH}" # per-job build artifacts - MESA_BUILD_PATH: "${PIPELINE_ARTIFACTS_BASE}/mesa-${ARCH}.tar.gz" + BUILD_PATH: "${PIPELINE_ARTIFACTS_BASE}/${CI_PROJECT_NAME}-${ARCH}.tar.gz" JOB_ROOTFS_OVERLAY_PATH: "${JOB_ARTIFACTS_BASE}/job-rootfs-overlay.tar.gz" JOB_RESULTS_PATH: "${JOB_ARTIFACTS_BASE}/results.tar.gz" + MINIO_RESULTS_UPLOAD: "${JOB_ARTIFACTS_BASE}" PIGLIT_NO_WINDOW: 1 VISIBILITY_GROUP: "Collabora+fdo" script: - ./artifacts/lava/lava-submit.sh artifacts: - name: "mesa_${CI_JOB_NAME}" + name: "${CI_PROJECT_NAME}_${CI_JOB_NAME}" when: always paths: - results/ exclude: - results/*.shader_cache + tags: + - $RUNNER_TAG after_script: - wget -q "https://${JOB_RESULTS_PATH}" -O- | tar -xz @@ -85,7 +88,7 @@ .lava-traces-base: variables: - HWCI_TEST_SCRIPT: "/install/piglit/run.sh" + HWCI_TEST_SCRIPT: "/install/piglit/piglit-traces.sh" artifacts: reports: junit: results/junit.xml diff --git a/lib/mesa/.gitlab-ci/lava/lava-pytest.sh b/lib/mesa/.gitlab-ci/lava/lava-pytest.sh new file mode 100755 index 000000000..311a2c453 --- /dev/null +++ b/lib/mesa/.gitlab-ci/lava/lava-pytest.sh @@ -0,0 +1,34 @@ +#!/bin/sh +# +# Copyright (C) 2022 Collabora Limited +# Author: Guilherme Gallo <guilherme.gallo@collabora.com> +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +# This script runs unit/integration tests related with LAVA CI tools + +set -ex + +TEST_DIR=${CI_PROJECT_DIR}/.gitlab-ci/tests + +PYTHONPATH="${TEST_DIR}:${PYTHONPATH}" python3 -m \ + pytest "${TEST_DIR}" \ + -W ignore::DeprecationWarning \ + --junitxml=artifacts/ci_scripts_report.xml diff --git a/lib/mesa/.gitlab-ci/lava/lava-submit.sh b/lib/mesa/.gitlab-ci/lava/lava-submit.sh index 1d3a24531..a61665dee 100755 --- a/lib/mesa/.gitlab-ci/lava/lava-submit.sh +++ b/lib/mesa/.gitlab-ci/lava/lava-submit.sh @@ -14,15 +14,16 @@ fi rm -rf results mkdir -p results/job-rootfs-overlay/ -# LAVA always uploads to MinIO when necessary as we don't have direct upload -# from the DUT -export PIGLIT_REPLAY_UPLOAD_TO_MINIO=1 cp artifacts/ci-common/capture-devcoredump.sh results/job-rootfs-overlay/ cp artifacts/ci-common/init-*.sh results/job-rootfs-overlay/ -artifacts/ci-common/generate-env.sh > results/job-rootfs-overlay/set-job-env-vars.sh +cp artifacts/ci-common/intel-gpu-freq.sh results/job-rootfs-overlay/ + +# Prepare env vars for upload. +KERNEL_IMAGE_BASE_URL="https://${BASE_SYSTEM_HOST_PATH}" \ + artifacts/ci-common/generate-env.sh > results/job-rootfs-overlay/set-job-env-vars.sh tar zcf job-rootfs-overlay.tar.gz -C results/job-rootfs-overlay/ . -ci-fairy minio login "${CI_JOB_JWT}" +ci-fairy minio login --token-file "${CI_JOB_JWT_FILE}" ci-fairy minio cp job-rootfs-overlay.tar.gz "minio://${JOB_ROOTFS_OVERLAY_PATH}" touch results/lava.log @@ -30,16 +31,16 @@ tail -f results/lava.log & artifacts/lava/lava_job_submitter.py \ --dump-yaml \ --pipeline-info "$CI_JOB_NAME: $CI_PIPELINE_URL on $CI_COMMIT_REF_NAME ${CI_NODE_INDEX}/${CI_NODE_TOTAL}" \ - --base-system-url-prefix "https://${BASE_SYSTEM_HOST_PATH}" \ - --mesa-build-url "${FDO_HTTP_CACHE_URI:-}https://${MESA_BUILD_PATH}" \ + --rootfs-url-prefix "https://${BASE_SYSTEM_HOST_PATH}" \ + --kernel-url-prefix "https://${BASE_SYSTEM_HOST_PATH}" \ + --build-url "${FDO_HTTP_CACHE_URI:-}https://${BUILD_PATH}" \ --job-rootfs-overlay-url "${FDO_HTTP_CACHE_URI:-}https://${JOB_ROOTFS_OVERLAY_PATH}" \ - --job-artifacts-base ${JOB_ARTIFACTS_BASE} \ --job-timeout ${JOB_TIMEOUT:-30} \ --first-stage-init artifacts/ci-common/init-stage1.sh \ --ci-project-dir ${CI_PROJECT_DIR} \ --device-type ${DEVICE_TYPE} \ --dtb ${DTB} \ - --jwt "${CI_JOB_JWT}" \ + --jwt-file "${CI_JOB_JWT_FILE}" \ --kernel-image-name ${KERNEL_IMAGE_NAME} \ --kernel-image-type "${KERNEL_IMAGE_TYPE}" \ --boot-method ${BOOT_METHOD} \ diff --git a/lib/mesa/.gitlab-ci/lava/lava_job_submitter.py b/lib/mesa/.gitlab-ci/lava/lava_job_submitter.py index bf2032c4f..0975a3a0d 100755 --- a/lib/mesa/.gitlab-ci/lava/lava_job_submitter.py +++ b/lib/mesa/.gitlab-ci/lava/lava_job_submitter.py @@ -25,31 +25,33 @@ """Send a job to LAVA, track it and collect log back""" import argparse -import lavacli -import os +import pathlib import sys import time import traceback import urllib.parse import xmlrpc -import yaml from datetime import datetime, timedelta +from os import getenv + +import lavacli +import yaml from lavacli.utils import loader -# Timeout in minutes to decide if the device from the dispatched LAVA job has +# Timeout in seconds to decide if the device from the dispatched LAVA job has # hung or not due to the lack of new log output. -DEVICE_HANGING_TIMEOUT_MIN = 5 +DEVICE_HANGING_TIMEOUT_SEC = int(getenv("LAVA_DEVICE_HANGING_TIMEOUT_SEC", 5*60)) # How many seconds the script should wait before try a new polling iteration to # check if the dispatched LAVA job is running or waiting in the job queue. -WAIT_FOR_DEVICE_POLLING_TIME_SEC = 10 +WAIT_FOR_DEVICE_POLLING_TIME_SEC = int(getenv("LAVA_WAIT_FOR_DEVICE_POLLING_TIME_SEC", 10)) # How many seconds to wait between log output LAVA RPC calls. -LOG_POLLING_TIME_SEC = 5 +LOG_POLLING_TIME_SEC = int(getenv("LAVA_LOG_POLLING_TIME_SEC", 5)) # How many retries should be made when a timeout happen. -NUMBER_OF_RETRIES_TIMEOUT_DETECTION = 2 +NUMBER_OF_RETRIES_TIMEOUT_DETECTION = int(getenv("LAVA_NUMBER_OF_RETRIES_TIMEOUT_DETECTION", 2)) def print_log(msg): @@ -59,6 +61,11 @@ def fatal_err(msg): print_log(msg) sys.exit(1) + +def hide_sensitive_data(yaml_data, hide_tag="HIDEME"): + return "".join(line for line in yaml_data.splitlines(True) if hide_tag not in line) + + def generate_lava_yaml(args): # General metadata and permissions, plus also inexplicably kernel arguments values = { @@ -67,7 +74,7 @@ def generate_lava_yaml(args): 'visibility': { 'group': [ args.visibility_group ] }, 'priority': 75, 'context': { - 'extra_nfsroot_args': ' init=/init rootwait minio_results={}'.format(args.job_artifacts_base) + 'extra_nfsroot_args': ' init=/init rootwait usbcore.quirks=0bda:8153:k' }, 'timeouts': { 'job': { @@ -86,10 +93,10 @@ def generate_lava_yaml(args): 'to': 'tftp', 'os': 'oe', 'kernel': { - 'url': '{}/{}'.format(args.base_system_url_prefix, args.kernel_image_name), + 'url': '{}/{}'.format(args.kernel_url_prefix, args.kernel_image_name), }, 'nfsrootfs': { - 'url': '{}/lava-rootfs.tgz'.format(args.base_system_url_prefix), + 'url': '{}/lava-rootfs.tgz'.format(args.rootfs_url_prefix), 'compression': 'gz', } } @@ -97,7 +104,7 @@ def generate_lava_yaml(args): deploy['kernel']['type'] = args.kernel_image_type if args.dtb: deploy['dtb'] = { - 'url': '{}/{}.dtb'.format(args.base_system_url_prefix, args.dtb) + 'url': '{}/{}.dtb'.format(args.kernel_url_prefix, args.dtb) } # always boot over NFS @@ -140,15 +147,22 @@ def generate_lava_yaml(args): # - fetch and unpack per-job environment from lava-submit.sh # - exec .gitlab-ci/common/init-stage2.sh init_lines = [] + with open(args.first_stage_init, 'r') as init_sh: init_lines += [ x.rstrip() for x in init_sh if not x.startswith('#') and x.rstrip() ] + + with open(args.jwt_file) as jwt_file: + init_lines += [ + "set +x", + f'echo -n "{jwt_file.read()}" > "{args.jwt_file}" # HIDEME', + "set -x", + ] + init_lines += [ 'mkdir -p {}'.format(args.ci_project_dir), - 'wget -S --progress=dot:giga -O- {} | tar -xz -C {}'.format(args.mesa_build_url, args.ci_project_dir), + 'wget -S --progress=dot:giga -O- {} | tar -xz -C {}'.format(args.build_url, args.ci_project_dir), 'wget -S --progress=dot:giga -O- {} | tar -xz -C /'.format(args.job_rootfs_overlay_url), - 'set +x', - 'export CI_JOB_JWT="{}"'.format(args.jwt), - 'set -x', + f'echo "export CI_JOB_JWT_FILE={args.jwt_file}" >> /set-job-env-vars.sh', 'exec /init-stage2.sh', ] test['definitions'][0]['repository']['run']['steps'] = init_lines @@ -192,7 +206,6 @@ def _call_proxy(fn, *args): fatal_err("A protocol error occurred (Err {} {})".format(err.errcode, err.errmsg)) else: time.sleep(15) - pass except xmlrpc.client.Fault as err: traceback.print_exc() fatal_err("FATAL: Fault: {} (code: {})".format(err.faultString, err.faultCode)) @@ -203,8 +216,8 @@ def get_job_results(proxy, job_id, test_suite, test_case): results_yaml = _call_proxy(proxy.results.get_testjob_results_yaml, job_id) results = yaml.load(results_yaml, Loader=loader(False)) for res in results: - metadata = res['metadata'] - if not 'result' in metadata or metadata['result'] != 'fail': + metadata = res["metadata"] + if "result" not in metadata or metadata["result"] != "fail": continue if 'error_type' in metadata and metadata['error_type'] == "Infrastructure": print_log("LAVA job {} failed with Infrastructure Error. Retry.".format(job_id)) @@ -241,8 +254,7 @@ def follow_job_execution(proxy, job_id): last_time_logs = datetime.now() while not finished: (finished, data) = _call_proxy(proxy.scheduler.jobs.logs, job_id, line_count) - logs = yaml.load(str(data), Loader=loader(False)) - if logs: + if logs := yaml.load(str(data), Loader=loader(False)): # Reset the timeout last_time_logs = datetime.now() for line in logs: @@ -251,7 +263,7 @@ def follow_job_execution(proxy, job_id): line_count += len(logs) else: - time_limit = timedelta(minutes=DEVICE_HANGING_TIMEOUT_MIN) + time_limit = timedelta(seconds=DEVICE_HANGING_TIMEOUT_SEC) if datetime.now() - last_time_logs > time_limit: print_log("LAVA job {} doesn't advance (machine got hung?). Retry.".format(job_id)) return False @@ -279,23 +291,7 @@ def submit_job(proxy, job_file): return _call_proxy(proxy.scheduler.jobs.submit, job_file) -def main(args): - proxy = setup_lava_proxy() - - yaml_file = generate_lava_yaml(args) - - if args.dump_yaml: - censored_args = args - censored_args.jwt = "jwt-hidden" - print(generate_lava_yaml(censored_args)) - - if args.validate_only: - ret = validate_job(proxy, yaml_file) - if not ret: - fatal_err("Error in LAVA job definition") - print("LAVA job definition validated successfully") - return - +def retriable_follow_job(proxy, yaml_file): retry_count = NUMBER_OF_RETRIES_TIMEOUT_DETECTION while retry_count >= 0: @@ -315,23 +311,45 @@ def main(args): show_job_data(proxy, job_id) - if get_job_results(proxy, job_id, "0_mesa", "mesa") == True: - break + if get_job_results(proxy, job_id, "0_mesa", "mesa") == True: + break + else: + # The script attempted all the retries. The job seemed to fail. + return False + return True -if __name__ == '__main__': - # given that we proxy from DUT -> LAVA dispatcher -> LAVA primary -> us -> - # GitLab runner -> GitLab primary -> user, safe to say we don't need any - # more buffering - sys.stdout.reconfigure(line_buffering=True) - sys.stderr.reconfigure(line_buffering=True) + +def main(args): + proxy = setup_lava_proxy() + + yaml_file = generate_lava_yaml(args) + + if args.dump_yaml: + print(hide_sensitive_data(generate_lava_yaml(args))) + + if args.validate_only: + ret = validate_job(proxy, yaml_file) + if not ret: + fatal_err("Error in LAVA job definition") + print("LAVA job definition validated successfully") + return + + if not retriable_follow_job(proxy, yaml_file): + fatal_err( + "Job failed after it exceeded the number of" + f"{NUMBER_OF_RETRIES_TIMEOUT_DETECTION} retries." + ) + + +def create_parser(): parser = argparse.ArgumentParser("LAVA job submitter") parser.add_argument("--pipeline-info") - parser.add_argument("--base-system-url-prefix") - parser.add_argument("--mesa-build-url") + parser.add_argument("--rootfs-url-prefix") + parser.add_argument("--kernel-url-prefix") + parser.add_argument("--build-url") parser.add_argument("--job-rootfs-overlay-url") - parser.add_argument("--job-artifacts-base") parser.add_argument("--job-timeout", type=int) parser.add_argument("--first-stage-init") parser.add_argument("--ci-project-dir") @@ -341,11 +359,22 @@ if __name__ == '__main__': parser.add_argument("--kernel-image-type", nargs='?', default="") parser.add_argument("--boot-method") parser.add_argument("--lava-tags", nargs='?', default="") - parser.add_argument("--jwt") + parser.add_argument("--jwt-file", type=pathlib.Path) parser.add_argument("--validate-only", action='store_true') parser.add_argument("--dump-yaml", action='store_true') parser.add_argument("--visibility-group") + return parser + +if __name__ == "__main__": + # given that we proxy from DUT -> LAVA dispatcher -> LAVA primary -> us -> + # GitLab runner -> GitLab primary -> user, safe to say we don't need any + # more buffering + sys.stdout.reconfigure(line_buffering=True) + sys.stderr.reconfigure(line_buffering=True) + + parser = create_parser() + parser.set_defaults(func=main) args = parser.parse_args() args.func(args) diff --git a/lib/mesa/.gitlab-ci/meson/build.sh b/lib/mesa/.gitlab-ci/meson/build.sh index 56391e51c..d052397cf 100755 --- a/lib/mesa/.gitlab-ci/meson/build.sh +++ b/lib/mesa/.gitlab-ci/meson/build.sh @@ -68,7 +68,6 @@ meson _build --native-file=native.file \ -D cpp_args="$(echo -n $CPP_ARGS)" \ -D libunwind=${UNWIND} \ ${DRI_LOADERS} \ - -D dri-drivers=${DRI_DRIVERS:-[]} \ ${GALLIUM_ST} \ -D gallium-drivers=${GALLIUM_DRIVERS:-[]} \ -D vulkan-drivers=${VULKAN_DRIVERS:-[]} \ diff --git a/lib/mesa/.gitlab-ci/piglit/piglit-runner.sh b/lib/mesa/.gitlab-ci/piglit/piglit-runner.sh index d228f6cea..ad5445c64 100755 --- a/lib/mesa/.gitlab-ci/piglit/piglit-runner.sh +++ b/lib/mesa/.gitlab-ci/piglit/piglit-runner.sh @@ -17,6 +17,31 @@ export VK_ICD_FILENAMES=`pwd`/install/share/vulkan/icd.d/"$VK_DRIVER"_icd.${VK_C RESULTS=`pwd`/${PIGLIT_RESULTS_DIR:-results} mkdir -p $RESULTS +# Ensure Mesa Shader Cache resides on tmpfs. +SHADER_CACHE_HOME=${XDG_CACHE_HOME:-${HOME}/.cache} +SHADER_CACHE_DIR=${MESA_SHADER_CACHE_DIR:-${SHADER_CACHE_HOME}/mesa_shader_cache} + +findmnt -n tmpfs ${SHADER_CACHE_HOME} || findmnt -n tmpfs ${SHADER_CACHE_DIR} || { + mkdir -p ${SHADER_CACHE_DIR} + mount -t tmpfs -o nosuid,nodev,size=2G,mode=1755 tmpfs ${SHADER_CACHE_DIR} +} + +if [ "$GALLIUM_DRIVER" = "virpipe" ]; then + # deqp is to use virpipe, and virgl_test_server llvmpipe + export GALLIUM_DRIVER="$GALLIUM_DRIVER" + + VTEST_ARGS="--use-egl-surfaceless" + if [ "$VIRGL_HOST_API" = "GLES" ]; then + VTEST_ARGS="$VTEST_ARGS --use-gles" + fi + + GALLIUM_DRIVER=llvmpipe \ + GALLIVM_PERF="nopt" \ + virgl_test_server $VTEST_ARGS >$RESULTS/vtest-log.txt 2>&1 & + + sleep 1 +fi + if [ -n "$PIGLIT_FRACTION" -o -n "$CI_NODE_INDEX" ]; then FRACTION=`expr ${PIGLIT_FRACTION:-1} \* ${CI_NODE_TOTAL:-1}` PIGLIT_RUNNER_OPTIONS="$PIGLIT_RUNNER_OPTIONS --fraction $FRACTION" diff --git a/lib/mesa/.gitlab-ci/piglit/piglit-traces.sh b/lib/mesa/.gitlab-ci/piglit/piglit-traces.sh new file mode 100755 index 000000000..8a913b37b --- /dev/null +++ b/lib/mesa/.gitlab-ci/piglit/piglit-traces.sh @@ -0,0 +1,241 @@ +#!/bin/sh + +set -ex + +INSTALL=$(realpath -s "$PWD"/install) +MINIO_ARGS="--credentials=/tmp/.minio_credentials" + +RESULTS=$(realpath -s "$PWD"/results) +mkdir -p "$RESULTS" + +# Set up the driver environment. +# Modifiying here directly LD_LIBRARY_PATH may cause problems when +# using a command wrapper. Hence, we will just set it when running the +# command. +export __LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$INSTALL/lib/" + +# Sanity check to ensure that our environment is sufficient to make our tests +# run against the Mesa built by CI, rather than any installed distro version. +MESA_VERSION=$(head -1 "$INSTALL/VERSION" | sed 's/\./\\./g') + +print_red() { + RED='\033[0;31m' + NC='\033[0m' # No Color + printf "${RED}" + "$@" + printf "${NC}" +} + +# wrapper to supress +x to avoid spamming the log +quiet() { + set +x + "$@" + set -x +} + +if [ "$VK_DRIVER" ]; then + + ### VULKAN ### + + # Set the Vulkan driver to use. + export VK_ICD_FILENAMES="$INSTALL/share/vulkan/icd.d/${VK_DRIVER}_icd.x86_64.json" + + # Set environment for Wine. + export WINEDEBUG="-all" + export WINEPREFIX="/dxvk-wine64" + export WINEESYNC=1 + + # Set environment for DXVK. + export DXVK_LOG_LEVEL="none" + export DXVK_STATE_CACHE=0 + + # Set environment for gfxreconstruct executables. + export PATH="/gfxreconstruct/build/bin:$PATH" + + SANITY_MESA_VERSION_CMD="vulkaninfo" + + HANG_DETECTION_CMD="/parallel-deqp-runner/build/bin/hang-detection" + + + # Set up the Window System Interface (WSI) + + if [ ${TEST_START_XORG:-0} -eq 1 ]; then + "$INSTALL"/common/start-x.sh "$INSTALL" + export DISPLAY=:0 + else + # Run vulkan against the host's running X server (xvfb doesn't + # have DRI3 support). + # Set the DISPLAY env variable in each gitlab-runner's + # configuration file: + # https://docs.gitlab.com/runner/configuration/advanced-configuration.html#the-runners-section + quiet printf "%s%s\n" "Running against the hosts' X server. " \ + "DISPLAY is \"$DISPLAY\"." + fi +else + + ### GL/ES ### + + # Set environment for apitrace executable. + export PATH="/apitrace/build:$PATH" + + # Our rootfs may not have "less", which apitrace uses during + # apitrace dump + export PAGER=cat + + SANITY_MESA_VERSION_CMD="wflinfo" + + HANG_DETECTION_CMD="" + + + # Set up the platform windowing system. + + if [ "x$EGL_PLATFORM" = "xsurfaceless" ]; then + + # Use the surfaceless EGL platform. + export DISPLAY= + export WAFFLE_PLATFORM="surfaceless_egl" + + SANITY_MESA_VERSION_CMD="$SANITY_MESA_VERSION_CMD --platform surfaceless_egl --api gles2" + + if [ "x$GALLIUM_DRIVER" = "xvirpipe" ]; then + # piglit is to use virpipe, and virgl_test_server llvmpipe + export GALLIUM_DRIVER="$GALLIUM_DRIVER" + + LD_LIBRARY_PATH="$__LD_LIBRARY_PATH" \ + GALLIUM_DRIVER=llvmpipe \ + VTEST_USE_EGL_SURFACELESS=1 \ + VTEST_USE_GLES=1 \ + virgl_test_server >"$RESULTS"/vtest-log.txt 2>&1 & + + sleep 1 + fi + elif [ "x$PIGLIT_PLATFORM" = "xgbm" ]; then + SANITY_MESA_VERSION_CMD="$SANITY_MESA_VERSION_CMD --platform gbm --api gl" + elif [ "x$PIGLIT_PLATFORM" = "xmixed_glx_egl" ]; then + # It is assumed that you have already brought up your X server before + # calling this script. + SANITY_MESA_VERSION_CMD="$SANITY_MESA_VERSION_CMD --platform glx --api gl" + else + SANITY_MESA_VERSION_CMD="$SANITY_MESA_VERSION_CMD --platform glx --api gl --profile core" + RUN_CMD_WRAPPER="xvfb-run --server-args=\"-noreset\" sh -c" + fi +fi + +if [ "$ZINK_USE_LAVAPIPE" ]; then + export VK_ICD_FILENAMES="$INSTALL/share/vulkan/icd.d/lvp_icd.x86_64.json" +fi + +# If the job is parallel at the gitlab job level, will take the corresponding +# fraction of the caselist. +if [ -n "$CI_NODE_INDEX" ]; then + USE_CASELIST=1 +fi + +replay_minio_upload_images() { + find "$RESULTS/$__PREFIX" -type f -name "*.png" -printf "%P\n" \ + | while read -r line; do + + __TRACE="${line%-*-*}" + if grep -q "^$__PREFIX/$__TRACE: pass$" ".gitlab-ci/piglit/$PIGLIT_RESULTS.txt.orig"; then + if [ "x$CI_PROJECT_PATH" != "x$FDO_UPSTREAM_REPO" ]; then + continue + fi + __MINIO_PATH="$PIGLIT_REPLAY_REFERENCE_IMAGES_BASE" + __DESTINATION_FILE_PATH="${line##*-}" + if wget -q --method=HEAD "https://${__MINIO_PATH}/${__DESTINATION_FILE_PATH}" 2>/dev/null; then + continue + fi + else + __MINIO_PATH="$JOB_ARTIFACTS_BASE" + __DESTINATION_FILE_PATH="$__MINIO_TRACES_PREFIX/${line##*-}" + fi + + ci-fairy minio cp $MINIO_ARGS "$RESULTS/$__PREFIX/$line" \ + "minio://${__MINIO_PATH}/${__DESTINATION_FILE_PATH}" + done +} + +SANITY_MESA_VERSION_CMD="$SANITY_MESA_VERSION_CMD | tee /tmp/version.txt | grep \"Mesa $MESA_VERSION\(\s\|$\)\"" + +if [ -d results ]; then + cd results && rm -rf ..?* .[!.]* * +fi +cd /piglit + +if [ -n "$USE_CASELIST" ]; then + PIGLIT_TESTS=$(printf "%s" "$PIGLIT_TESTS") + PIGLIT_GENTESTS="./piglit print-cmd $PIGLIT_TESTS replay --format \"{name}\" > /tmp/case-list.txt" + RUN_GENTESTS="export LD_LIBRARY_PATH=$__LD_LIBRARY_PATH; $PIGLIT_GENTESTS" + + eval $RUN_GENTESTS + + sed -ni $CI_NODE_INDEX~$CI_NODE_TOTAL"p" /tmp/case-list.txt + + PIGLIT_TESTS="--test-list /tmp/case-list.txt" +fi + +PIGLIT_OPTIONS=$(printf "%s" "$PIGLIT_OPTIONS") + +PIGLIT_TESTS=$(printf "%s" "$PIGLIT_TESTS") + +PIGLIT_CMD="./piglit run --timeout 300 -j${FDO_CI_CONCURRENT:-4} $PIGLIT_OPTIONS $PIGLIT_TESTS replay "$(/usr/bin/printf "%q" "$RESULTS") + +RUN_CMD="export LD_LIBRARY_PATH=$__LD_LIBRARY_PATH; $SANITY_MESA_VERSION_CMD && $HANG_DETECTION_CMD $PIGLIT_CMD" + +if [ "$RUN_CMD_WRAPPER" ]; then + RUN_CMD="set +e; $RUN_CMD_WRAPPER "$(/usr/bin/printf "%q" "$RUN_CMD")"; set -e" +fi + +ci-fairy minio login $MINIO_ARGS --token-file "${CI_JOB_JWT_FILE}" + +# The replayer doesn't do any size or checksum verification for the traces in +# the replayer db, so if we had to restart the system due to intermittent device +# errors (or tried to cache replayer-db between runs, which would be nice to +# have), you could get a corrupted local trace that would spuriously fail the +# run. +rm -rf replayer-db + +eval $RUN_CMD + +if [ $? -ne 0 ]; then + printf "%s\n" "Found $(cat /tmp/version.txt), expected $MESA_VERSION" +fi + +ARTIFACTS_BASE_URL="https://${CI_PROJECT_ROOT_NAMESPACE}.${CI_PAGES_DOMAIN}/-/${CI_PROJECT_NAME}/-/jobs/${CI_JOB_ID}/artifacts" + +./piglit summary aggregate "$RESULTS" -o junit.xml + +PIGLIT_RESULTS="${PIGLIT_RESULTS:-replay}" +RESULTSFILE="$RESULTS/$PIGLIT_RESULTS.txt" +mkdir -p .gitlab-ci/piglit +./piglit summary console "$RESULTS"/results.json.bz2 \ + | tee ".gitlab-ci/piglit/$PIGLIT_RESULTS.txt.orig" \ + | head -n -1 | grep -v ": pass" \ + | sed '/^summary:/Q' \ + > $RESULTSFILE + +__PREFIX="trace/$PIGLIT_REPLAY_DEVICE_NAME" +__MINIO_PATH="$PIGLIT_REPLAY_ARTIFACTS_BASE_URL" +__MINIO_TRACES_PREFIX="traces" + +if [ "x$PIGLIT_REPLAY_SUBCOMMAND" != "xprofile" ]; then + quiet replay_minio_upload_images +fi + + +if [ ! -s $RESULTSFILE ]; then + exit 0 +fi + +./piglit summary html --exclude-details=pass \ +"$RESULTS"/summary "$RESULTS"/results.json.bz2 + +find "$RESULTS"/summary -type f -name "*.html" -print0 \ + | xargs -0 sed -i 's%<img src="file://'"${RESULTS}"'.*-\([0-9a-f]*\)\.png%<img src="https://'"${JOB_ARTIFACTS_BASE}"'/traces/\1.png%g' +find "$RESULTS"/summary -type f -name "*.html" -print0 \ + | xargs -0 sed -i 's%<img src="file://%<img src="https://'"${PIGLIT_REPLAY_REFERENCE_IMAGES_BASE}"'/%g' + +quiet print_red echo "Failures in traces:" +cat $RESULTSFILE +quiet print_red echo "Review the image changes and get the new checksums at: ${ARTIFACTS_BASE_URL}/results/summary/problems.html" +exit 1 diff --git a/lib/mesa/.gitlab-ci/prepare-artifacts.sh b/lib/mesa/.gitlab-ci/prepare-artifacts.sh index cbbe0a318..bb96de36a 100755 --- a/lib/mesa/.gitlab-ci/prepare-artifacts.sh +++ b/lib/mesa/.gitlab-ci/prepare-artifacts.sh @@ -47,11 +47,12 @@ mkdir -p artifacts/ tar -cf artifacts/install.tar install cp -Rp .gitlab-ci/common artifacts/ci-common cp -Rp .gitlab-ci/lava artifacts/ +cp -Rp .gitlab-ci/valve artifacts/ if [ -n "$MINIO_ARTIFACT_NAME" ]; then # Pass needed files to the test stage MINIO_ARTIFACT_NAME="$MINIO_ARTIFACT_NAME.tar.gz" gzip -c artifacts/install.tar > ${MINIO_ARTIFACT_NAME} - ci-fairy minio login $CI_JOB_JWT + ci-fairy minio login --token-file "${CI_JOB_JWT_FILE}" ci-fairy minio cp ${MINIO_ARTIFACT_NAME} minio://${PIPELINE_ARTIFACTS_BASE}/${MINIO_ARTIFACT_NAME} fi diff --git a/lib/mesa/.gitlab-ci/skqp-runner.sh b/lib/mesa/.gitlab-ci/skqp-runner.sh new file mode 100755 index 000000000..68aca2d33 --- /dev/null +++ b/lib/mesa/.gitlab-ci/skqp-runner.sh @@ -0,0 +1,153 @@ +#!/bin/sh +# +# Copyright (C) 2022 Collabora Limited +# Author: Guilherme Gallo <guilherme.gallo@collabora.com> +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + + +copy_tests_files() ( + # Copy either unit test or render test files from a specific driver given by + # GPU VERSION variable. + # If there is no test file at the expected location, this function will + # return error_code 1 + SKQP_BACKEND="${1}" + SKQP_FILE_PREFIX="${INSTALL}/${GPU_VERSION}-skqp" + + if echo "${SKQP_BACKEND}" | grep -qE 'vk|gl(es)?' + then + SKQP_RENDER_TESTS_FILE="${SKQP_FILE_PREFIX}-${SKQP_BACKEND}_rendertests.txt" + [ -f "${SKQP_RENDER_TESTS_FILE}" ] || return 1 + cp "${SKQP_RENDER_TESTS_FILE}" "${SKQP_ASSETS_DIR}"/skqp/rendertests.txt + return 0 + fi + + # The unittests.txt path is hardcoded inside assets directory, + # that is why it needs to be a special case. + if echo "${SKQP_BACKEND}" | grep -qE "unitTest" + then + SKQP_UNIT_TESTS_FILE="${SKQP_FILE_PREFIX}_unittests.txt" + [ -f "${SKQP_UNIT_TESTS_FILE}" ] || return 1 + cp "${SKQP_UNIT_TESTS_FILE}" "${SKQP_ASSETS_DIR}"/skqp/unittests.txt + fi +) + +test_vk_backend() { + if echo "${SKQP_BACKENDS}" | grep -qE 'vk' + then + if [ -n "$VK_DRIVER" ]; then + return 0 + fi + + echo "VK_DRIVER environment variable is missing." + VK_DRIVERS=$(ls "$INSTALL"/share/vulkan/icd.d/ | cut -f 1 -d '_') + if [ -n "${VK_DRIVERS}" ] + then + echo "Please set VK_DRIVER to the correct driver from the list:" + echo "${VK_DRIVERS}" + fi + echo "No Vulkan tests will be executed, but it was requested in SKQP_BACKENDS variable. Exiting." + exit 2 + fi + + # Vulkan environment is not configured, but it was not requested by the job + return 1 +} + +setup_backends() { + if test_vk_backend + then + export VK_ICD_FILENAMES="$INSTALL"/share/vulkan/icd.d/"$VK_DRIVER"_icd."${VK_CPU:-$(uname -m)}".json + fi +} + +set -ex + +# Needed so configuration files can contain paths to files in /install +ln -sf "$CI_PROJECT_DIR"/install /install +INSTALL=${PWD}/install + +if [ -z "$GPU_VERSION" ]; then + echo 'GPU_VERSION must be set to something like "llvmpipe" or +"freedreno-a630" (it will serve as a component to find the path for files +residing in src/**/ci/*.txt)' + exit 1 +fi + +LD_LIBRARY_PATH=$INSTALL:$LD_LIBRARY_PATH +setup_backends + +SKQP_ASSETS_DIR=/skqp/assets +SKQP_RESULTS_DIR="${SKQP_RESULTS_DIR:-$PWD/results}" + +mkdir -p "${SKQP_ASSETS_DIR}"/skqp + +SKQP_EXITCODE=0 +for SKQP_BACKEND in ${SKQP_BACKENDS} +do + set -e + if ! copy_tests_files "${SKQP_BACKEND}" + then + echo "No override test file found for ${SKQP_BACKEND}. Using the default one." + fi + + set +e + SKQP_BACKEND_RESULTS_DIR="${SKQP_RESULTS_DIR}"/"${SKQP_BACKEND}" + mkdir -p "${SKQP_BACKEND_RESULTS_DIR}" + /skqp/skqp "${SKQP_ASSETS_DIR}" "${SKQP_BACKEND_RESULTS_DIR}" "${SKQP_BACKEND}_" + BACKEND_EXITCODE=$? + + if [ ! $BACKEND_EXITCODE -eq 0 ] + then + echo "skqp failed on ${SKQP_BACKEND} tests with ${BACKEND_EXITCODE} exit code." + fi + + # Propagate error codes to leverage the final job result + SKQP_EXITCODE=$(( SKQP_EXITCODE | BACKEND_EXITCODE )) +done + +set +x + +# Unit tests produce empty HTML reports, guide the user to check the TXT file. +if echo "${SKQP_BACKENDS}" | grep -qE "unitTest" +then + # Remove the empty HTML report to avoid confusion + rm -f "${SKQP_RESULTS_DIR}"/unitTest/report.html + + echo "See skqp unit test results at:" + echo "https://$CI_PROJECT_ROOT_NAMESPACE.pages.freedesktop.org/-/$CI_PROJECT_NAME/-/jobs/$CI_JOB_ID/artifacts/${SKQP_RESULTS_DIR}/unitTest/unit_tests.txt" +fi + +REPORT_FILES=$(mktemp) +find "${SKQP_RESULTS_DIR}"/**/report.html -type f > "${REPORT_FILES}" +while read -r REPORT +do + BACKEND_NAME=$(echo "${REPORT}" | sed 's@.*/\([^/]*\)/report.html@\1@') + echo "See skqp ${BACKEND_NAME} render tests report at:" + echo "https://$CI_PROJECT_ROOT_NAMESPACE.pages.freedesktop.org/-/$CI_PROJECT_NAME/-/jobs/$CI_JOB_ID/artifacts/${REPORT}" +done < "${REPORT_FILES}" + +# If there is no report available, tell the user that something is wrong. +if [ ! -s "${REPORT_FILES}" ] +then + echo "No skqp report available. Probably some fatal error has occured during the skqp execution." +fi + +exit $SKQP_EXITCODE diff --git a/lib/mesa/.gitlab-ci/test-source-dep.yml b/lib/mesa/.gitlab-ci/test-source-dep.yml index d654b928b..e19bb216e 100644 --- a/lib/mesa/.gitlab-ci/test-source-dep.yml +++ b/lib/mesa/.gitlab-ci/test-source-dep.yml @@ -18,6 +18,7 @@ - .gitlab-ci/**/* - include/**/* - meson.build + - .gitattributes - src/* - src/compiler/**/* - src/drm-shim/**/* @@ -30,10 +31,6 @@ - src/loader/**/* - src/mapi/**/* - src/mesa/* - - src/mesa/drivers/* - - src/mesa/drivers/common/**/* - - src/mesa/drivers/dri/* - - src/mesa/drivers/dri/common/**/* - src/mesa/main/**/* - src/mesa/math/**/* - src/mesa/program/**/* @@ -41,11 +38,10 @@ - src/mesa/state_tracker/**/* - src/mesa/swrast/**/* - src/mesa/swrast_setup/**/* - - src/mesa/tnl/**/* - - src/mesa/tnl_dd/**/* - src/mesa/vbo/**/* - src/mesa/x86/**/* - src/mesa/x86-64/**/* + - src/tool/**/* - src/util/**/* .vulkan-rules: @@ -132,6 +128,7 @@ - .gitlab-ci.yml - .gitlab-ci/**/* - meson.build + - .gitattributes - include/**/* - src/compiler/**/* - src/include/**/* @@ -153,6 +150,8 @@ rules: - if: '$FD_FARM == "offline"' when: never + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - *ignore_scheduled_pipelines - changes: *mesa_core_file_list @@ -180,9 +179,11 @@ rules: - if: '$FD_FARM == "offline"' when: never + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never # If the triggerer has access to the restricted traces and if it is pre-merge - if: '($GITLAB_USER_LOGIN !~ "/^(robclark|anholt|flto|cwabbott0|Danil|tomeu)$/") && - ($GITLAB_USER_LOGIN != "marge-bot" || $CI_MERGE_REQUEST_SOURCE_BRANCH_NAME != $CI_COMMIT_REF_NAME)' + ($GITLAB_USER_LOGIN != "marge-bot" || $CI_COMMIT_BRANCH)' when: never - *ignore_scheduled_pipelines - changes: @@ -206,9 +207,11 @@ rules: - if: '$FD_FARM == "offline"' when: never + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - *ignore_scheduled_pipelines # Run only on pre-merge pipelines from Marge - - if: '$GITLAB_USER_LOGIN != "marge-bot" || $CI_MERGE_REQUEST_SOURCE_BRANCH_NAME != $CI_COMMIT_REF_NAME' + - if: '$GITLAB_USER_LOGIN != "marge-bot" || $CI_COMMIT_BRANCH' when: never - changes: *mesa_core_file_list @@ -224,10 +227,30 @@ when: manual - when: never +.nouveau-rules: + stage: nouveau + rules: + - *ignore_scheduled_pipelines + - changes: + *mesa_core_file_list + when: on_success + - changes: + *gallium_core_file_list + when: on_success + - changes: + - src/nouveau/**/* + - src/gallium/drivers/nouveau/**/* + - src/gallium/winsys/kmsro/**/* + - src/gallium/winsys/nouveau/**/* + when: on_success + - when: never + .panfrost-midgard-rules: stage: arm rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -254,6 +277,8 @@ stage: arm rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -349,6 +374,8 @@ stage: amd rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -377,10 +404,37 @@ when: on_success - when: never +# Unfortunately YAML doesn't let us concatenate arrays, so we have to do the +# rules duplication manually +.virgl-lava-rules-performance: + stage: layered-backends + rules: + - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never + # Run only on pre-merge pipelines from Marge + - if: '$GITLAB_USER_LOGIN != "marge-bot" || $CI_COMMIT_BRANCH' + when: never + - changes: + *mesa_core_file_list + when: manual + - changes: + *gallium_core_file_list + when: manual + - changes: + *llvmpipe_file_list + when: manual + - changes: + *virgl_file_list + when: manual + - when: never + .radeonsi-rules: stage: amd rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -402,6 +456,8 @@ stage: amd rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -434,10 +490,29 @@ when: on_success - when: never +.crocus-rules: + stage: intel + rules: + - *ignore_scheduled_pipelines + - changes: + *mesa_core_file_list + when: on_success + - changes: + *gallium_core_file_list + when: on_success + - changes: + - src/gallium/drivers/crocus/**/* + - src/gallium/winsys/crocus/**/* + - src/intel/**/* + when: on_success + - when: never + .iris-rules: stage: intel rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -457,8 +532,10 @@ stage: intel rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never # Run only on pre-merge pipelines from Marge - - if: '$GITLAB_USER_LOGIN != "marge-bot" || $CI_MERGE_REQUEST_SOURCE_BRANCH_NAME != $CI_COMMIT_REF_NAME' + - if: '$GITLAB_USER_LOGIN != "marge-bot" || $CI_COMMIT_BRANCH' when: never - changes: *mesa_core_file_list @@ -475,6 +552,8 @@ stage: intel rules: - *ignore_scheduled_pipelines + - if: '$COLLABORA_FARM == "offline" && $RUNNER_TAG =~ /^mesa-ci-x86-64-lava-/' + when: never - changes: *mesa_core_file_list when: on_success @@ -508,6 +587,8 @@ # rules duplication manually .windows-build-rules: rules: + - if: '$MICROSOFT_FARM == "offline"' + when: never - *ignore_scheduled_pipelines - changes: *mesa_core_file_list @@ -516,6 +597,9 @@ *gallium_core_file_list when: on_success - changes: + *softpipe_file_list + when: on_success + - changes: *lavapipe_file_list when: on_success - changes: @@ -539,6 +623,8 @@ .windows-test-rules: rules: + - if: '$MICROSOFT_FARM == "offline"' + when: never - *ignore_scheduled_pipelines - changes: *mesa_core_file_list diff --git a/lib/mesa/.gitlab-ci/test/gitlab-ci.yml b/lib/mesa/.gitlab-ci/test/gitlab-ci.yml new file mode 100644 index 000000000..888d73863 --- /dev/null +++ b/lib/mesa/.gitlab-ci/test/gitlab-ci.yml @@ -0,0 +1,314 @@ +.test: + extends: + - .ci-run-policy + # Cancel job if a newer commit is pushed to the same branch + interruptible: true + variables: + GIT_STRATEGY: none # testing doesn't build anything from source + before_script: + - !reference [default, before_script] + # Note: Build dir (and thus install) may be dirty due to GIT_STRATEGY + - rm -rf install + - tar -xf artifacts/install.tar + - echo -e "\e[0Ksection_start:$(date +%s):ldd_section[collapsed=true]\r\e[0KChecking ldd on driver build" + - LD_LIBRARY_PATH=install/lib find install/lib -name "*.so" -print -exec ldd {} \; + - echo -e "\e[0Ksection_end:$(date +%s):ldd_section\r\e[0K" + artifacts: + when: always + name: "mesa_${CI_JOB_NAME}" + paths: + - results/ + +.test-gl: + extends: + - .test + - .use-debian/x86_test-gl + needs: + - debian/x86_test-gl + - debian-testing + +.test-vk: + extends: + - .test + - .use-debian/x86_test-vk + needs: + - debian-testing + - debian/x86_test-vk + +.test-cl: + extends: + - .test + - .use-debian/x86_test-gl + needs: + - debian/x86_test-gl + - debian-clover-testing + +.vkd3d-proton-test: + artifacts: + when: on_failure + name: "mesa_${CI_JOB_NAME}" + paths: + - results/vkd3d-proton.log + script: + - ./install/vkd3d-proton/run.sh + +.piglit-test: + artifacts: + name: "mesa_${CI_JOB_NAME}" + paths: + - results + reports: + junit: results/junit.xml + variables: + PIGLIT_NO_WINDOW: 1 + HWCI_TEST_SCRIPT: "/install/piglit/piglit-runner.sh" + script: + - install/piglit/piglit-runner.sh + +.piglit-traces-test: + extends: + - .piglit-test + cache: + key: ${CI_JOB_NAME} + paths: + - replayer-db/ + artifacts: + when: on_failure + name: "mesa_${CI_JOB_NAME}" + reports: + junit: results/junit.xml + paths: + - results/summary/ + - results/*.txt + variables: + PIGLIT_REPLAY_EXTRA_ARGS: --keep-image --db-path ${CI_PROJECT_DIR}/replayer-db/ --minio_host=minio-packet.freedesktop.org --minio_bucket=mesa-tracie-public --role-session-name=${CI_PROJECT_PATH}:${CI_JOB_ID} --jwt-file=${CI_JOB_JWT_FILE} + script: + - install/piglit/piglit-traces.sh + +.deqp-test: + script: + - ./install/deqp-runner.sh + artifacts: + exclude: + - results/*.shader_cache + reports: + junit: results/junit.xml + +.deqp-test-vk: + extends: + - .deqp-test + variables: + DEQP_VER: vk + +.fossilize-test: + script: + - ./install/fossilize-runner.sh + artifacts: + when: on_failure + name: "mesa_${CI_JOB_NAME}" + paths: + - results/ + +.baremetal-test: + extends: + - .ci-run-policy + - .test + # Cancel job if a newer commit is pushed to the same branch + interruptible: true + stage: test + before_script: + - !reference [default, before_script] + # Use this instead of gitlab's artifacts download because it hits packet.net + # instead of fd.o. Set FDO_HTTP_CACHE_URI to an http cache for your test lab to + # improve it even more (see https://docs.mesa3d.org/ci/bare-metal.html for + # setup). + - wget ${FDO_HTTP_CACHE_URI:-}https://${PIPELINE_ARTIFACTS_BASE}/${MINIO_ARTIFACT_NAME}.tar.gz -S --progress=dot:giga -O- | tar -xz + artifacts: + when: always + name: "mesa_${CI_JOB_NAME}" + paths: + - results/ + - serial*.txt + exclude: + - results/*.shader_cache + reports: + junit: results/junit.xml + +.baremetal-test-armhf: + extends: + - .baremetal-test + variables: + BM_ROOTFS: /rootfs-armhf + MINIO_ARTIFACT_NAME: mesa-armhf + +.baremetal-test-arm64: + extends: + - .baremetal-test + variables: + BM_ROOTFS: /rootfs-arm64 + MINIO_ARTIFACT_NAME: mesa-arm64 + +.baremetal-arm64-asan-test: + variables: + DEQP_RUNNER_OPTIONS: "--env LD_PRELOAD=libasan.so.6:/install/lib/libdlclose-skip.so" + MINIO_ARTIFACT_NAME: mesa-arm64-asan + needs: + - debian/arm_test + - job: debian-arm64-asan + artifacts: false + +.baremetal-deqp-test: + variables: + HWCI_TEST_SCRIPT: "/install/deqp-runner.sh" + FDO_CI_CONCURRENT: 0 # Default to number of CPUs + +.baremetal-skqp-test: + variables: + HWCI_START_XORG: 1 + HWCI_TEST_SCRIPT: "/install/skqp-runner.sh" + +# For Valve's bare-metal testing farm jobs. +.b2c-test: + # It would be nice to use ci-templates within Mesa CI for this job's + # image:, but the integration is not possible for the current + # use-case. Within this job, two containers are managed. 1) the + # gitlab runner container from which the job is submitted to the + # DUT, and 2) the test container (e.g. debian/x86_test-vk) within + # which the test cases will run on the DUT. Since ci-templates and + # the associated image setting macros in this file rely on variables + # like FDO_DISTRIBUTION_TAG for *the* image, there is no way to + # depend on more than one image per job. So, the job container is + # built as part of the CI in the boot2container project. + image: registry.freedesktop.org/mupuf/valve-infra/mesa-trigger:2022-03-03.2 + extends: + - .use-debian/x86_test-vk + variables: + # No need by default to pull the whole repo + GIT_STRATEGY: none + # boot2container initrd configuration parameters. + B2C_KERNEL_URL: 'https://gitlab.freedesktop.org/mupuf/valve-infra/-/package_files/117/download' # 5.16-for-mesa-ci + B2C_INITRAMFS_URL: 'https://gitlab.freedesktop.org/mupuf/boot2container/-/releases/v0.9.4/downloads/initramfs.linux_amd64.cpio.xz' + B2C_JOB_SUCCESS_REGEX: '\[.*\]: Execution is over, pipeline status: 0\r$' + B2C_JOB_WARN_REGEX: 'null' + B2C_LOG_LEVEL: 6 + B2C_POWEROFF_DELAY: 15 + B2C_SESSION_END_REGEX: '^.*It''s now safe to turn off your computer\r$' + B2C_SESSION_REBOOT_REGEX: 'GPU hang detected!' + B2C_TIMEOUT_BOOT_MINUTES: 240 + B2C_TIMEOUT_BOOT_RETRIES: 2 + B2C_TIMEOUT_FIRST_MINUTES: 5 + B2C_TIMEOUT_FIRST_RETRIES: 3 + B2C_TIMEOUT_MINUTES: 2 + B2C_TIMEOUT_OVERALL_MINUTES: 240 + B2C_TIMEOUT_RETRIES: 0 + + # As noted in the top description, we make a distinction between the + # container used by gitlab-runner to queue the work, and the container + # used by the DUTs/test machines. To make this distinction quite clear, + # we rename the MESA_IMAGE variable into IMAGE_UNDER_TEST. + IMAGE_UNDER_TEST: "$MESA_IMAGE" + + INSTALL_TARBALL: "./artifacts/install.tar" + CI_VALVE_ARTIFACTS: "./artifacts/valve" + CI_COMMON_SCRIPTS: "./artifacts/ci-common" + GENERATE_ENV_SCRIPT: "${CI_COMMON_SCRIPTS}/generate-env.sh" + B2C_JOB_TEMPLATE: "${CI_VALVE_ARTIFACTS}/b2c.yml.jinja2.jinja2" + JOB_FOLDER: "job_folder" + before_script: + # We don't want the tarball unpacking of .test, but will take the JWT bits. + - !reference [default, before_script] + - | + set -x + + # Useful as a hook point for runner admins. You may edit the + # config.toml for the Gitlab runner and use a bind-mount to + # populate the hook script with some executable commands. This + # allows quicker feedback than resubmitting pipelines and + # potentially having to wait for a debug build of Mesa to + # complete. + if [ -x /runner-before-script.sh ]; then + echo "Executing runner before-script hook..." + sh /runner-before-script.sh + if [ $? -ne 0 ]; then + echo "Runner hook failed, goodbye" + exit $? + fi + fi + + [ -s "$INSTALL_TARBALL" ] || exit 1 + [ -d "$CI_VALVE_ARTIFACTS" ] || exit 1 + [ -d "$CI_COMMON_SCRIPTS" ] || exit 1 + + + B2C_TEST_SCRIPT="bash -c 'source ./set-job-env-vars.sh ; ${B2C_TEST_SCRIPT}'" + + # The Valve CI gateway receives jobs in a YAML format. Create a + # job description from the CI environment. + python3 "$CI_VALVE_ARTIFACTS"/generate_b2c.py \ + --ci-job-id "${CI_JOB_ID}" \ + --container-cmd "${B2C_TEST_SCRIPT}" \ + --initramfs-url "${B2C_INITRAMFS_URL}" \ + --job-success-regex "${B2C_JOB_SUCCESS_REGEX}" \ + --job-warn-regex "${B2C_JOB_WARN_REGEX}" \ + --kernel-url "${B2C_KERNEL_URL}" \ + --log-level "${B2C_LOG_LEVEL}" \ + --poweroff-delay "${B2C_POWEROFF_DELAY}" \ + --session-end-regex "${B2C_SESSION_END_REGEX}" \ + --session-reboot-regex "${B2C_SESSION_REBOOT_REGEX}" \ + --tags "${CI_RUNNER_TAGS}" \ + --template "${B2C_JOB_TEMPLATE}" \ + --timeout-boot-minutes "${B2C_TIMEOUT_BOOT_MINUTES}" \ + --timeout-boot-retries "${B2C_TIMEOUT_BOOT_RETRIES}" \ + --timeout-first-minutes "${B2C_TIMEOUT_FIRST_MINUTES}" \ + --timeout-first-retries "${B2C_TIMEOUT_FIRST_RETRIES}" \ + --timeout-minutes "${B2C_TIMEOUT_MINUTES}" \ + --timeout-overall-minutes "${B2C_TIMEOUT_OVERALL_MINUTES}" \ + --timeout-retries "${B2C_TIMEOUT_RETRIES}" \ + --job-volume-exclusions "${B2C_JOB_VOLUME_EXCLUSIONS}" \ + --local-container "${IMAGE_UNDER_TEST}" \ + ${B2C_EXTRA_VOLUME_ARGS} \ + --working-dir "$CI_PROJECT_DIR" + + cat b2c.yml.jinja2 + + rm -rf ${JOB_FOLDER} || true + mkdir -v ${JOB_FOLDER} + # Create a script to regenerate the CI environment when this job + # begins running on the remote DUT. + set +x + "$CI_COMMON_SCRIPTS"/generate-env.sh > ${JOB_FOLDER}/set-job-env-vars.sh + chmod +x ${JOB_FOLDER}/set-job-env-vars.sh + echo "Variables passed through:" + cat ${JOB_FOLDER}/set-job-env-vars.sh + echo "export CI_JOB_JWT=${CI_JOB_JWT}" >> ${JOB_FOLDER}/set-job-env-vars.sh + set -x + + # Extract the Mesa distribution into the location expected by + # the Mesa CI deqp-runner scripts. + tar x -C ${JOB_FOLDER} -f $INSTALL_TARBALL + + script: | + slugify () { + echo "$1" | sed -r s/[~\^]+//g | sed -r s/[^a-zA-Z0-9]+/-/g | sed -r s/^-+\|-+$//g | tr A-Z a-z + } + + # Submit the job to Valve's CI gateway service with the CI + # provisioned job_folder. + env PYTHONUNBUFFERED=1 executorctl \ + run -w b2c.yml.jinja2 -j $(slugify "$CI_JOB_NAME") -s ${JOB_FOLDER} + + ls -l + # Anything our job places in results/ will be collected by the + # Gitlab coordinator for status presentation. results/junit.xml + # will be parsed by the UI for more detailed explanations of + # test execution. + needs: + - debian/x86_test-vk + - debian-testing + artifacts: + when: always + name: "mesa_${CI_JOB_NAME}" + paths: + - ${JOB_FOLDER}/results + reports: + junit: ${JOB_FOLDER}/results/junit.xml diff --git a/lib/mesa/.gitlab-ci/tests/__init__.py b/lib/mesa/.gitlab-ci/tests/__init__.py new file mode 100644 index 000000000..e69de29bb --- /dev/null +++ b/lib/mesa/.gitlab-ci/tests/__init__.py diff --git a/lib/mesa/.gitlab-ci/tests/test_lava_job_submitter.py b/lib/mesa/.gitlab-ci/tests/test_lava_job_submitter.py new file mode 100644 index 000000000..0ed19efee --- /dev/null +++ b/lib/mesa/.gitlab-ci/tests/test_lava_job_submitter.py @@ -0,0 +1,250 @@ +#!/usr/bin/env python3 +# +# Copyright (C) 2022 Collabora Limited +# Author: Guilherme Gallo <guilherme.gallo@collabora.com> +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +# SOFTWARE. + +import xmlrpc.client +from contextlib import nullcontext as does_not_raise +from datetime import datetime +from itertools import repeat +from typing import Tuple +from unittest.mock import MagicMock, patch + +import pytest +import yaml +from freezegun import freeze_time +from lava.lava_job_submitter import ( + DEVICE_HANGING_TIMEOUT_SEC, + follow_job_execution, + hide_sensitive_data, + retriable_follow_job, +) + + +def jobs_logs_response(finished=False, msg=None) -> Tuple[bool, str]: + timed_msg = {"dt": str(datetime.now()), "msg": "New message"} + logs = [timed_msg] if msg is None else msg + + return finished, yaml.safe_dump(logs) + + +def result_get_testjob_results_response() -> str: + result = {"result": "test"} + results = [{"metadata": result}] + + return yaml.safe_dump(results) + + +def result_get_testcase_results_response() -> str: + result = {"result": "pass"} + test_cases = [result] + + return yaml.safe_dump(test_cases) + + +@pytest.fixture +def mock_proxy(): + def create_proxy_mock(**kwargs): + proxy_mock = MagicMock() + proxy_submit_mock = proxy_mock.scheduler.jobs.submit + proxy_submit_mock.return_value = "1234" + + proxy_results_mock = proxy_mock.results.get_testjob_results_yaml + proxy_results_mock.return_value = result_get_testjob_results_response() + + proxy_test_cases_mock = proxy_mock.results.get_testcase_results_yaml + proxy_test_cases_mock.return_value = result_get_testcase_results_response() + + proxy_logs_mock = proxy_mock.scheduler.jobs.logs + proxy_logs_mock.return_value = jobs_logs_response() + for key, value in kwargs.items(): + setattr(proxy_logs_mock, key, value) + + return proxy_mock + + yield create_proxy_mock + + +@pytest.fixture +def mock_proxy_waiting_time(mock_proxy): + def update_mock_proxy(frozen_time, **kwargs): + wait_time = kwargs.pop("wait_time", 0) + proxy_mock = mock_proxy(**kwargs) + proxy_job_state = proxy_mock.scheduler.job_state + proxy_job_state.return_value = {"job_state": "Running"} + proxy_job_state.side_effect = frozen_time.tick(wait_time) + + return proxy_mock + + return update_mock_proxy + + +@pytest.fixture +def mock_sleep(): + """Mock time.sleep to make test faster""" + with patch("time.sleep", return_value=None): + yield + + +@pytest.fixture +def frozen_time(mock_sleep): + with freeze_time() as frozen_time: + yield frozen_time + + +@pytest.mark.parametrize("exception", [RuntimeError, SystemError, KeyError]) +def test_submit_and_follow_respects_exceptions(mock_sleep, mock_proxy, exception): + with pytest.raises(exception): + follow_job_execution(mock_proxy(side_effect=exception), "") + + +def generate_n_logs(n=1, tick_sec=1): + """Simulate a log partitionated in n components""" + with freeze_time(datetime.now()) as time_travel: + while True: + # Simulate a scenario where the target job is waiting for being started + for _ in range(n - 1): + time_travel.tick(tick_sec) + yield jobs_logs_response(finished=False, msg=[]) + + time_travel.tick(tick_sec) + yield jobs_logs_response(finished=True) + + +NETWORK_EXCEPTION = xmlrpc.client.ProtocolError("", 0, "test", {}) +XMLRPC_FAULT = xmlrpc.client.Fault(0, "test") + +PROXY_SCENARIOS = { + "finish case": (generate_n_logs(1), does_not_raise(), True), + "works at last retry": ( + generate_n_logs(n=3, tick_sec=DEVICE_HANGING_TIMEOUT_SEC + 1), + does_not_raise(), + True, + ), + "timed out more times than retry attempts": ( + generate_n_logs(n=4, tick_sec=DEVICE_HANGING_TIMEOUT_SEC + 1), + does_not_raise(), + False, + ), + "long log case, no silence": ( + generate_n_logs(n=1000, tick_sec=0), + does_not_raise(), + True, + ), + "very long silence": ( + generate_n_logs(n=4, tick_sec=100000), + does_not_raise(), + False, + ), + # If a protocol error happens, _call_proxy will retry without affecting timeouts + "unstable connection, ProtocolError followed by final message": ( + (NETWORK_EXCEPTION, jobs_logs_response(finished=True)), + does_not_raise(), + True, + ), + # After an arbitrary number of retries, _call_proxy should call sys.exit + "unreachable case, subsequent ProtocolErrors": ( + repeat(NETWORK_EXCEPTION), + pytest.raises(SystemExit), + False, + ), + "XMLRPC Fault": ([XMLRPC_FAULT], pytest.raises(SystemExit, match="1"), False), +} + + +@patch("time.sleep", return_value=None) # mock sleep to make test faster +@pytest.mark.parametrize( + "side_effect, expectation, has_finished", + PROXY_SCENARIOS.values(), + ids=PROXY_SCENARIOS.keys(), +) +def test_retriable_follow_job( + mock_sleep, side_effect, expectation, has_finished, mock_proxy +): + with expectation: + result = retriable_follow_job(mock_proxy(side_effect=side_effect), "") + assert has_finished == result + + +WAIT_FOR_JOB_SCENARIOS = { + "one log run taking (sec):": (generate_n_logs(1), True), +} + + +@pytest.mark.parametrize("wait_time", (0, DEVICE_HANGING_TIMEOUT_SEC * 2)) +@pytest.mark.parametrize( + "side_effect, has_finished", + WAIT_FOR_JOB_SCENARIOS.values(), + ids=WAIT_FOR_JOB_SCENARIOS.keys(), +) +def test_simulate_a_long_wait_to_start_a_job( + frozen_time, + wait_time, + side_effect, + has_finished, + mock_proxy_waiting_time, +): + start_time = datetime.now() + result = retriable_follow_job( + mock_proxy_waiting_time( + frozen_time, side_effect=side_effect, wait_time=wait_time + ), + "", + ) + + end_time = datetime.now() + delta_time = end_time - start_time + + assert has_finished == result + assert delta_time.total_seconds() >= wait_time + + +SENSITIVE_DATA_SCENARIOS = { + "no sensitive data tagged": ( + ["bla bla", "mytoken: asdkfjsde1341=="], + ["bla bla", "mytoken: asdkfjsde1341=="], + "HIDEME", + ), + "sensitive data tagged": ( + ["bla bla", "mytoken: asdkfjsde1341== # HIDEME"], + ["bla bla"], + "HIDEME", + ), + "sensitive data tagged with custom word": ( + ["bla bla", "mytoken: asdkfjsde1341== # DELETETHISLINE", "third line"], + ["bla bla", "third line"], + "DELETETHISLINE", + ), +} + + +@pytest.mark.parametrize( + "input, expectation, tag", + SENSITIVE_DATA_SCENARIOS.values(), + ids=SENSITIVE_DATA_SCENARIOS.keys(), +) +def test_hide_sensitive_data(input, expectation, tag): + yaml_data = yaml.safe_dump(input) + yaml_result = hide_sensitive_data(yaml_data, tag) + result = yaml.safe_load(yaml_result) + + assert result == expectation diff --git a/lib/mesa/.gitlab-ci/valve/b2c.yml.jinja2.jinja2 b/lib/mesa/.gitlab-ci/valve/b2c.yml.jinja2.jinja2 new file mode 100644 index 000000000..238fb6e88 --- /dev/null +++ b/lib/mesa/.gitlab-ci/valve/b2c.yml.jinja2.jinja2 @@ -0,0 +1,63 @@ +version: 1 + +# Rules to match for a machine to qualify +target: +{% if tags %} +{% set b2ctags = tags.split(',') %} + tags: +{% for tag in b2ctags %} + - '{{ tag | trim }}' +{% endfor %} +{% endif %} + +timeouts: + first_console_activity: # This limits the time it can take to receive the first console log + minutes: {{ timeout_first_minutes }} + retries: {{ timeout_first_retries }} + console_activity: # Reset every time we receive a message from the logs + minutes: {{ timeout_minutes }} + retries: {{ timeout_retries }} + boot_cycle: + minutes: {{ timeout_boot_minutes }} + retries: {{ timeout_boot_retries }} + overall: # Maximum time the job can take, not overrideable by the "continue" deployment + minutes: {{ timeout_overall_minutes }} + retries: 0 + # no retries possible here + +console_patterns: + session_end: + regex: >- + {{ session_end_regex }} + session_reboot: + regex: >- + {{ session_reboot_regex }} + job_success: + regex: >- + {{ job_success_regex }} + +# Environment to deploy +deployment: + # Initial boot + start: + kernel: + url: '{{ kernel_url }}' + cmdline: > + SALAD.machine_id={{ '{{' }} machine_id }} + console={{ '{{' }} local_tty_device }},115200 earlyprintk=vga,keep + loglevel={{ log_level }} amdgpu.gpu_recovery=0 no_hash_pointers + b2c.container="-ti --tls-verify=false docker://{{ '{{' }} fdo_proxy_registry }}/mupuf/valve-infra/machine_registration:latest check" + b2c.ntp_peer=10.42.0.1 b2c.pipefail b2c.cache_device=auto b2c.poweroff_delay={{ poweroff_delay }} + b2c.minio="gateway,{{ '{{' }} minio_url }},{{ '{{' }} job_bucket_access_key }},{{ '{{' }} job_bucket_secret_key }}" + b2c.volume="{{ '{{' }} job_bucket }}-results,mirror=gateway/{{ '{{' }} job_bucket }},pull_on=pipeline_start,push_on=changes,overwrite{% for excl in job_volume_exclusions %},exclude={{ excl }}{% endfor %},expiration=pipeline_end,preserve" +{% for volume in volumes %} + b2c.volume={{ volume }} +{% endfor %} + b2c.container="-v {{ '{{' }} job_bucket }}-results:{{ working_dir }} -w {{ working_dir }} {% for mount_volume in mount_volumes %} -v {{ mount_volume }}{% endfor %} --tls-verify=false docker://{{ local_container }} {{ container_cmd }}" + {% if cmdline_extras is defined %} + {{ cmdline_extras }} + {% endif %} + + initramfs: + url: '{{ initramfs_url }}' + diff --git a/lib/mesa/.gitlab-ci/valve/generate_b2c.py b/lib/mesa/.gitlab-ci/valve/generate_b2c.py new file mode 100755 index 000000000..a68b34a14 --- /dev/null +++ b/lib/mesa/.gitlab-ci/valve/generate_b2c.py @@ -0,0 +1,101 @@ +#!/usr/bin/env python3 + +# Copyright © 2022 Valve Corporation +# +# Permission is hereby granted, free of charge, to any person obtaining a +# copy of this software and associated documentation files (the "Software"), +# to deal in the Software without restriction, including without limitation +# the rights to use, copy, modify, merge, publish, distribute, sublicense, +# and/or sell copies of the Software, and to permit persons to whom the +# Software is furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice (including the next +# paragraph) shall be included in all copies or substantial portions of the +# Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL +# THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS +# IN THE SOFTWARE. + +from jinja2 import Environment, FileSystemLoader +from argparse import ArgumentParser +from os import environ, path + + +parser = ArgumentParser() +parser.add_argument('--ci-job-id') +parser.add_argument('--container-cmd') +parser.add_argument('--initramfs-url') +parser.add_argument('--job-success-regex') +parser.add_argument('--job-warn-regex') +parser.add_argument('--kernel-url') +parser.add_argument('--log-level', type=int) +parser.add_argument('--poweroff-delay', type=int) +parser.add_argument('--session-end-regex') +parser.add_argument('--session-reboot-regex') +parser.add_argument('--tags', nargs='?', default='') +parser.add_argument('--template', default='b2c.yml.jinja2.jinja2') +parser.add_argument('--timeout-boot-minutes', type=int) +parser.add_argument('--timeout-boot-retries', type=int) +parser.add_argument('--timeout-first-minutes', type=int) +parser.add_argument('--timeout-first-retries', type=int) +parser.add_argument('--timeout-minutes', type=int) +parser.add_argument('--timeout-overall-minutes', type=int) +parser.add_argument('--timeout-retries', type=int) +parser.add_argument('--job-volume-exclusions', nargs='?', default='') +parser.add_argument('--volume', action='append') +parser.add_argument('--mount-volume', action='append') +parser.add_argument('--local-container', default=environ.get('B2C_LOCAL_CONTAINER', 'alpine:latest')) +parser.add_argument('--working-dir') +args = parser.parse_args() + +env = Environment(loader=FileSystemLoader(path.dirname(args.template)), + trim_blocks=True, lstrip_blocks=True) + +template = env.get_template(path.basename(args.template)) + +values = {} +values['ci_job_id'] = args.ci_job_id +values['container_cmd'] = args.container_cmd +values['initramfs_url'] = args.initramfs_url +values['job_success_regex'] = args.job_success_regex +values['job_warn_regex'] = args.job_warn_regex +values['kernel_url'] = args.kernel_url +values['log_level'] = args.log_level +values['poweroff_delay'] = args.poweroff_delay +values['session_end_regex'] = args.session_end_regex +values['session_reboot_regex'] = args.session_reboot_regex +values['tags'] = args.tags +values['template'] = args.template +values['timeout_boot_minutes'] = args.timeout_boot_minutes +values['timeout_boot_retries'] = args.timeout_boot_retries +values['timeout_first_minutes'] = args.timeout_first_minutes +values['timeout_first_retries'] = args.timeout_first_retries +values['timeout_minutes'] = args.timeout_minutes +values['timeout_overall_minutes'] = args.timeout_overall_minutes +values['timeout_retries'] = args.timeout_retries +if len(args.job_volume_exclusions) > 0: + exclusions = args.job_volume_exclusions.split(",") + values['job_volume_exclusions'] = [excl for excl in exclusions if len(excl) > 0] +if args.volume is not None: + values['volumes'] = args.volume +if args.mount_volume is not None: + values['mount_volumes'] = args.mount_volume +values['working_dir'] = args.working_dir + +assert(len(args.local_container) > 0) +values['local_container'] = args.local_container.replace( + # Use the gateway's pull-through registry cache to reduce load on fd.o. + 'registry.freedesktop.org', '{{ fdo_proxy_registry }}' +) + +if 'B2C_KERNEL_CMDLINE_EXTRAS' in environ: + values['cmdline_extras'] = environ['B2C_KERNEL_CMDLINE_EXTRAS'] + +f = open(path.splitext(path.basename(args.template))[0], "w") +f.write(template.render(values)) +f.close() diff --git a/lib/mesa/.gitlab-ci/windows/Dockerfile_build b/lib/mesa/.gitlab-ci/windows/Dockerfile_build new file mode 100644 index 000000000..f94050424 --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/Dockerfile_build @@ -0,0 +1,13 @@ +# escape=` + +FROM mcr.microsoft.com/windows:1809 + +# Make sure any failure in PowerShell scripts is fatal +SHELL ["powershell", "-ExecutionPolicy", "RemoteSigned", "-Command", "$ErrorActionPreference = 'Stop';"] +ENV ErrorActionPreference='Stop' + +COPY mesa_deps_vs2019.ps1 C:\ +RUN C:\mesa_deps_vs2019.ps1 + +COPY mesa_deps_build.ps1 C:\ +RUN C:\mesa_deps_build.ps1 diff --git a/lib/mesa/.gitlab-ci/windows/Dockerfile_test b/lib/mesa/.gitlab-ci/windows/Dockerfile_test new file mode 100644 index 000000000..106e49335 --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/Dockerfile_test @@ -0,0 +1,7 @@ +# escape=` + +ARG base_image +FROM ${base_image} + +COPY mesa_deps_test.ps1 C:\ +RUN C:\mesa_deps_test.ps1 diff --git a/lib/mesa/.gitlab-ci/windows/deqp_runner_run.ps1 b/lib/mesa/.gitlab-ci/windows/deqp_runner_run.ps1 new file mode 100644 index 000000000..571836fa4 --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/deqp_runner_run.ps1 @@ -0,0 +1,31 @@ +$dxil_dll = cmd.exe /C "C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 -no_logo && where dxil.dll" 2>&1 +if ($dxil_dll -notmatch "dxil.dll$") { + Write-Output "Couldn't get path to dxil.dll" + exit 1 +} +$env:Path = "$(Split-Path $dxil_dll);$env:Path" + +# VK_ICD_FILENAMES environment variable is not used when running with +# elevated privileges. Add a key to the registry instead. +$hkey_path = "HKLM:\SOFTWARE\Khronos\Vulkan\Drivers\" +$hkey_name = Join-Path -Path $pwd -ChildPath "_install\share\vulkan\icd.d\dzn_icd.x86_64.json" +New-Item -Path $hkey_path -force +New-ItemProperty -Path $hkey_path -Name $hkey_name -Value 0 -PropertyType DWORD + +$results = New-Item -ItemType Directory results +$deqp_options = @("--deqp-surface-width", 256, "--deqp-surface-height", 256, "--deqp-surface-type", "pbuffer", "--deqp-gl-config-name", "rgba8888d24s8ms0", "--deqp-visibility", "hidden") +$deqp_module = "C:\deqp\external\vulkancts\modules\vulkan\deqp-vk.exe" +$caselist = "C:\deqp\mustpass\vk-master.txt" +$baseline = ".\_install\warp-fails.txt" +$includes = @("-t", "dEQP-VK.api.*", "-t", "dEQP-VK.info.*", "-t", "dEQP-VK.draw.*", "-t", "dEQP-VK.query_pool.*", "-t", "dEQP-VK.memory.*") + +$env:DZN_DEBUG = "warp" +deqp-runner run --deqp $($deqp_module) --output $($results) --caselist $($caselist) --baseline $($baseline) $($includes) --testlog-to-xml C:\deqp\executor\testlog-to-xml.exe --jobs 4 -- $($deqp_options) +$deqpstatus = $? + +$template = "See https://$($env:CI_PROJECT_ROOT_NAMESPACE).pages.freedesktop.org/-/$($env:CI_PROJECT_NAME)/-/jobs/$($env:CI_JOB_ID)/artifacts/results/{{testcase}}.xml" +deqp-runner junit --testsuite dEQP --results "$($results)/failures.csv" --output "$($results)/junit.xml" --limit 50 --template $template + +if (!$deqpstatus) { + Exit 1 +} diff --git a/lib/mesa/.gitlab-ci/windows/mesa_build.ps1 b/lib/mesa/.gitlab-ci/windows/mesa_build.ps1 index 42794c6ec..e4427a7c2 100644 --- a/lib/mesa/.gitlab-ci/windows/mesa_build.ps1 +++ b/lib/mesa/.gitlab-ci/windows/mesa_build.ps1 @@ -6,10 +6,48 @@ $env:PYTHONUTF8=1 Get-Date Write-Host "Compiling Mesa" -$builddir = New-Item -ItemType Directory -Name "_build" -$installdir = New-Item -ItemType Directory -Name "_install" -Push-Location $builddir.FullName -cmd.exe /C "C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && meson --default-library=shared -Dzlib:default_library=static --buildtype=release -Db_ndebug=false -Dc_std=c17 -Dcpp_std=vc++latest -Db_vscrt=mt --cmake-prefix-path=`"C:\llvm-10`" --pkg-config-path=`"C:\llvm-10\lib\pkgconfig;C:\llvm-10\share\pkgconfig;C:\spirv-tools\lib\pkgconfig`" --prefix=`"$installdir`" -Dllvm=enabled -Dshared-llvm=disabled -Dvulkan-drivers=swrast,amd -Dgallium-drivers=swrast,d3d12,zink -Dshared-glapi=enabled -Dgles2=enabled -Dmicrosoft-clc=enabled -Dstatic-libclc=all -Dspirv-to-dxil=true -Dbuild-tests=true -Dwerror=true -Dwarning_level=2 -Dzlib:warning_level=1 -Dlibelf:warning_level=1 && ninja -j32 install && meson test --num-processes 32" +$builddir = New-Item -Force -ItemType Directory -Name "_build" +$installdir = New-Item -Force -ItemType Directory -Name "_install" +$builddir=$builddir.FullName +$installdir=$installdir.FullName +$sourcedir=$PWD + +Remove-Item -Recurse -Force $builddir +Remove-Item -Recurse -Force $installdir +New-Item -ItemType Directory -Path $builddir +New-Item -ItemType Directory -Path $installdir + +Write-Output builddir:$builddir +Write-Output installdir:$installdir +Write-Output sourcedir:$sourcedir + +$installPath=& "C:\Program Files (x86)\Microsoft Visual Studio\Installer\vswhere.exe" -version 16.0 -property installationpath +Write-Output "vswhere.exe installPath: $installPath" +$installPath="C:\BuildTools" +Write-Output "Final installPath: $installPath" +Import-Module (Join-Path $installPath "Common7\Tools\Microsoft.VisualStudio.DevShell.dll") +Enter-VsDevShell -VsInstallPath $installPath -SkipAutomaticLocation -DevCmdArguments '-arch=x64 -no_logo -host_arch=amd64' + +Push-Location $builddir + +meson --default-library=shared -Dzlib:default_library=static --buildtype=release -Db_ndebug=false ` +-Db_vscrt=mt --cmake-prefix-path="C:\llvm-10" ` +--pkg-config-path="C:\llvm-10\lib\pkgconfig;C:\llvm-10\share\pkgconfig;C:\spirv-tools\lib\pkgconfig" ` +--prefix="$installdir" ` +-Dllvm=enabled -Dshared-llvm=disabled ` +"-Dvulkan-drivers=swrast,amd,microsoft-experimental" "-Dgallium-drivers=swrast,d3d12,zink" ` +-Dshared-glapi=enabled -Dgles2=enabled -Dmicrosoft-clc=enabled -Dstatic-libclc=all -Dspirv-to-dxil=true ` +-Dbuild-tests=true -Dwerror=true -Dwarning_level=2 -Dzlib:warning_level=1 -Dlibelf:warning_level=1 ` +$sourcedir + +if ($?) { + ninja install -j32 +} + +if ($?) { + meson test --num-processes 32 +} + $buildstatus = $? Pop-Location @@ -21,4 +59,10 @@ if (!$buildstatus) { } Copy-Item ".\.gitlab-ci\windows\piglit_run.ps1" -Destination $installdir -Copy-Item ".\.gitlab-ci\windows\quick_gl.txt" -Destination $installdir + +Copy-Item ".\.gitlab-ci\windows\spirv2dxil_check.ps1" -Destination $installdir +Copy-Item ".\.gitlab-ci\windows\spirv2dxil_run.ps1" -Destination $installdir + +Copy-Item ".\.gitlab-ci\windows\deqp_runner_run.ps1" -Destination $installdir + +Get-ChildItem -Recurse -Filter "ci" | Get-ChildItem -Filter "*.txt" | Copy-Item -Destination $installdir diff --git a/lib/mesa/.gitlab-ci/windows/mesa_container.ps1 b/lib/mesa/.gitlab-ci/windows/mesa_container.ps1 index 7a2f6c237..cbb9e2235 100644 --- a/lib/mesa/.gitlab-ci/windows/mesa_container.ps1 +++ b/lib/mesa/.gitlab-ci/windows/mesa_container.ps1 @@ -6,6 +6,8 @@ $registry_username = $args[1] $registry_password = $args[2] $registry_user_image = $args[3] $registry_central_image = $args[4] +$build_dockerfile = $args[5] +$registry_base_image = $args[6] Set-Location -Path ".\.gitlab-ci\windows" @@ -39,7 +41,7 @@ if ($?) { } Write-Host "No image found at $registry_user_image or $registry_central_image; rebuilding" -docker --config "windows-docker.conf" build --no-cache -t "$registry_user_image" . +docker --config "windows-docker.conf" build --no-cache -t "$registry_user_image" -f "$build_dockerfile" --build-arg base_image="$registry_base_image" . if (!$?) { Write-Host "Container build failed" docker --config "windows-docker.conf" logout "$registry_uri" diff --git a/lib/mesa/.gitlab-ci/windows/mesa_deps_build.ps1 b/lib/mesa/.gitlab-ci/windows/mesa_deps_build.ps1 new file mode 100644 index 000000000..a771ca254 --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/mesa_deps_build.ps1 @@ -0,0 +1,146 @@ +# Download new TLS certs from Windows Update +Get-Date +Write-Host "Updating TLS certificate store" +$certdir = (New-Item -ItemType Directory -Name "_tlscerts") +certutil -syncwithWU "$certdir" +Foreach ($file in (Get-ChildItem -Path "$certdir\*" -Include "*.crt")) { + Import-Certificate -FilePath $file -CertStoreLocation Cert:\LocalMachine\Root +} +Remove-Item -Recurse -Path $certdir + + +Get-Date +Write-Host "Installing Chocolatey" +Invoke-Expression ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1')) +Import-Module "$env:ProgramData\chocolatey\helpers\chocolateyProfile.psm1" +Update-SessionEnvironment +Write-Host "Installing Chocolatey packages" + +# Chocolatey tries to download winflexbison from SourceForge, which is not super reliable, and has no retry +# loop of its own - so we give it a helping hand here +For ($i = 0; $i -lt 5; $i++) { + choco install -y python3 --params="/InstallDir:C:\python3" + $python_install = $? + choco install --allow-empty-checksums -y cmake git git-lfs ninja pkgconfiglite winflexbison vulkan-sdk --installargs "ADD_CMAKE_TO_PATH=System" + $other_install = $? + $choco_installed = $other_install -and $python_install + if ($choco_installed) { + Break + } +} + +if (!$choco_installed) { + Write-Host "Couldn't install dependencies from Chocolatey" + Exit 1 +} + +# Add Chocolatey's native install path +Update-SessionEnvironment +# Python and CMake add themselves to the system environment path, which doesn't get refreshed +# until we start a new shell +$env:PATH = "C:\python3;C:\python3\scripts;C:\Program Files\CMake\bin;$env:PATH" + +Start-Process -NoNewWindow -Wait git -ArgumentList 'config --global core.autocrlf false' + +Get-Date +Write-Host "Installing Meson, Mako and numpy" +pip3 install meson mako numpy +if (!$?) { + Write-Host "Failed to install dependencies from pip" + Exit 1 +} + +# we want more secure TLS 1.2 for most things, but it breaks SourceForge +# downloads so must be done after Chocolatey use +[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12 -bor [Net.SecurityProtocolType]::Tls13; + +Get-Date +Write-Host "Cloning LLVM release/12.x" +git clone -b release/12.x --depth=1 https://github.com/llvm/llvm-project llvm-project +if (!$?) { + Write-Host "Failed to clone LLVM repository" + Exit 1 +} + +# ideally we want to use a tag here insted of a sha, +# but as of today, SPIRV-LLVM-Translator doesn't have +# a tag matching LLVM 12.0.0 +Get-Date +Write-Host "Cloning SPIRV-LLVM-Translator" +git clone https://github.com/KhronosGroup/SPIRV-LLVM-Translator llvm-project/llvm/projects/SPIRV-LLVM-Translator +if (!$?) { + Write-Host "Failed to clone SPIRV-LLVM-Translator repository" + Exit 1 +} +Push-Location llvm-project/llvm/projects/SPIRV-LLVM-Translator +git checkout 5b641633b3bcc3251a52260eee11db13a79d7258 +Pop-Location + +Get-Date +# slightly convoluted syntax but avoids the CWD being under the PS filesystem meta-path +$llvm_build = New-Item -ItemType Directory -Path ".\llvm-project" -Name "build" +Push-Location -Path $llvm_build.FullName +Write-Host "Compiling LLVM and Clang" +cmd.exe /C 'C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && cmake ../llvm -GNinja -DCMAKE_BUILD_TYPE=Release -DLLVM_USE_CRT_RELEASE=MT -DCMAKE_INSTALL_PREFIX="C:\llvm-10" -DLLVM_ENABLE_PROJECTS="clang;lld" -DLLVM_TARGETS_TO_BUILD=AMDGPU;X86 -DLLVM_OPTIMIZED_TABLEGEN=TRUE -DLLVM_ENABLE_ASSERTIONS=TRUE -DLLVM_INCLUDE_UTILS=OFF -DLLVM_INCLUDE_RUNTIMES=OFF -DLLVM_INCLUDE_TESTS=OFF -DLLVM_INCLUDE_EXAMPLES=OFF -DLLVM_INCLUDE_GO_TESTS=OFF -DLLVM_INCLUDE_BENCHMARKS=OFF -DLLVM_BUILD_LLVM_C_DYLIB=OFF -DLLVM_ENABLE_DIA_SDK=OFF -DCLANG_BUILD_TOOLS=ON -DLLVM_SPIRV_INCLUDE_TESTS=OFF && ninja -j32 install' +$buildstatus = $? +Pop-Location +if (!$buildstatus) { + Write-Host "Failed to compile LLVM" + Exit 1 +} + +Get-Date +$libclc_build = New-Item -ItemType Directory -Path ".\llvm-project" -Name "build-libclc" +Push-Location -Path $libclc_build.FullName +Write-Host "Compiling libclc" +# libclc can only be built with Ninja, because CMake's VS backend doesn't know how to compile new language types +cmd.exe /C 'C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && cmake ../libclc -GNinja -DCMAKE_BUILD_TYPE=Release -DCMAKE_CXX_FLAGS="-m64" -DCMAKE_POLICY_DEFAULT_CMP0091=NEW -DCMAKE_MSVC_RUNTIME_LIBRARY=MultiThreaded -DCMAKE_INSTALL_PREFIX="C:\llvm-10" -DLIBCLC_TARGETS_TO_BUILD="spirv-mesa3d-;spirv64-mesa3d-" && ninja -j32 install' +$buildstatus = $? +Pop-Location +Remove-Item -Recurse -Path $libclc_build +if (!$buildstatus) { + Write-Host "Failed to compile libclc" + Exit 1 +} +Remove-Item -Recurse -Path $llvm_build + +Get-Date +Write-Host "Cloning SPIRV-Tools" +git clone https://github.com/KhronosGroup/SPIRV-Tools +if (!$?) { + Write-Host "Failed to clone SPIRV-Tools repository" + Exit 1 +} +git clone https://github.com/KhronosGroup/SPIRV-Headers SPIRV-Tools/external/SPIRV-Headers +if (!$?) { + Write-Host "Failed to clone SPIRV-Headers repository" + Exit 1 +} +Write-Host "Building SPIRV-Tools" +$spv_build = New-Item -ItemType Directory -Path ".\SPIRV-Tools" -Name "build" +Push-Location -Path $spv_build.FullName +# SPIRV-Tools doesn't use multi-threaded MSVCRT, but we need it to +cmd.exe /C 'C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && cmake .. -GNinja -DCMAKE_BUILD_TYPE=Release -DCMAKE_POLICY_DEFAULT_CMP0091=NEW -DCMAKE_MSVC_RUNTIME_LIBRARY=MultiThreaded -DCMAKE_INSTALL_PREFIX="C:\spirv-tools" && ninja -j32 install' +$buildstatus = $? +Pop-Location +Remove-Item -Recurse -Path $spv_build +if (!$buildstatus) { + Write-Host "Failed to compile SPIRV-Tools" + Exit 1 +} + +# See https://gitlab.freedesktop.org/mesa/mesa/-/issues/3855 +# Until that's resolved, we need the vulkan-runtime as a build dependency to be able to run any unit tests on GL +Get-Date +Write-Host "Downloading Vulkan-Runtime" +Invoke-WebRequest -Uri 'https://sdk.lunarg.com/sdk/download/latest/windows/vulkan-runtime.exe' -OutFile 'C:\vulkan-runtime.exe' | Out-Null +Write-Host "Installing Vulkan-Runtime" +Start-Process -NoNewWindow -Wait C:\vulkan-runtime.exe -ArgumentList '/S' +if (!$?) { + Write-Host "Failed to install Vulkan-Runtime" + Exit 1 +} +Remove-Item C:\vulkan-runtime.exe -Force + +Get-Date +Write-Host "Complete" diff --git a/lib/mesa/.gitlab-ci/windows/mesa_deps_test.ps1 b/lib/mesa/.gitlab-ci/windows/mesa_deps_test.ps1 new file mode 100644 index 000000000..0600be893 --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/mesa_deps_test.ps1 @@ -0,0 +1,124 @@ +Get-Date +Write-Host "Downloading Freeglut" + +$freeglut_zip = 'freeglut-MSVC.zip' +$freeglut_url = "https://www.transmissionzero.co.uk/files/software/development/GLUT/$freeglut_zip" + +For ($i = 0; $i -lt 5; $i++) { + Invoke-WebRequest -Uri $freeglut_url -OutFile $freeglut_zip + $freeglut_downloaded = $? + if ($freeglut_downloaded) { + Break + } +} + +if (!$freeglut_downloaded) { + Write-Host "Failed to download Freeglut" + Exit 1 +} + +Get-Date +Write-Host "Installing Freeglut" +Expand-Archive $freeglut_zip -DestinationPath C:\ +if (!$?) { + Write-Host "Failed to install Freeglut" + Exit 1 +} + +Get-Date +Write-Host "Downloading glext.h" +New-Item -ItemType Directory -Path ".\glext" -Name "GL" +$ProgressPreference = "SilentlyContinue" +Invoke-WebRequest -Uri 'https://www.khronos.org/registry/OpenGL/api/GL/glext.h' -OutFile '.\glext\GL\glext.h' | Out-Null + +Get-Date +Write-Host "Cloning Piglit" +git clone --no-progress --single-branch --no-checkout https://gitlab.freedesktop.org/mesa/piglit.git 'C:\src\piglit' +if (!$?) { + Write-Host "Failed to clone Piglit repository" + Exit 1 +} +Push-Location -Path C:\src\piglit +git checkout f7f2a6c2275cae023a27b6cc81be3dda8c99492d +Pop-Location + +Get-Date +$piglit_build = New-Item -ItemType Directory -Path "C:\src\piglit" -Name "build" +Push-Location -Path $piglit_build.FullName +Write-Host "Compiling Piglit" +cmd.exe /C 'C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && cmake .. -GNinja -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX="C:\Piglit" -DGLUT_INCLUDE_DIR=C:\freeglut\include -DGLUT_glut_LIBRARY_RELEASE=C:\freeglut\lib\x64\freeglut.lib -DGLEXT_INCLUDE_DIR=.\glext && ninja -j32' +$buildstatus = $? +ninja -j32 install | Out-Null +$installstatus = $? +Pop-Location +Remove-Item -Recurse -Path $piglit_build +if (!$buildstatus -Or !$installstatus) { + Write-Host "Failed to compile or install Piglit" + Exit 1 +} + +Copy-Item -Path C:\freeglut\bin\x64\freeglut.dll -Destination C:\Piglit\lib\piglit\bin\freeglut.dll + +Get-Date +Write-Host "Cloning spirv-samples" +git clone --no-progress --single-branch --no-checkout https://github.com/dneto0/spirv-samples.git C:\spirv-samples\ +Push-Location -Path C:\spirv-samples\ +git checkout 7ac0ad5a7fe0ec884faba1dc2916028d0268eeef +Pop-Location + +Get-Date +Write-Host "Cloning Vulkan and GL Conformance Tests" +$deqp_source = "C:\src\VK-GL-CTS\" +git clone --no-progress --single-branch https://github.com/lfrb/VK-GL-CTS.git -b windows-flush $deqp_source +if (!$?) { + Write-Host "Failed to clone deqp repository" + Exit 1 +} + +Push-Location -Path $deqp_source +# --insecure is due to SSL cert failures hitting sourceforge for zlib and +# libpng (sigh). The archives get their checksums checked anyway, and git +# always goes through ssh or https. +py .\external\fetch_sources.py --insecure +Pop-Location + +Get-Date +$deqp_build = New-Item -ItemType Directory -Path "C:\deqp" +Push-Location -Path $deqp_build.FullName +Write-Host "Compiling deqp" +cmd.exe /C "C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 && cmake -S $($deqp_source) -B . -GNinja -DCMAKE_BUILD_TYPE=Release -DDEQP_TARGET=default && ninja -j32" +$buildstatus = $? +Pop-Location +if (!$buildstatus -Or !$installstatus) { + Write-Host "Failed to compile or install deqp" + Exit 1 +} + +# Copy test result templates +Copy-Item -Path "$($deqp_source)\doc\testlog-stylesheet\testlog.css" -Destination $deqp_build +Copy-Item -Path "$($deqp_source)\doc\testlog-stylesheet\testlog.xsl" -Destination $deqp_build + +# Copy Vulkan must-pass list +$deqp_mustpass = New-Item -ItemType Directory -Path $deqp_build -Name "mustpass" +$root_mustpass = Join-Path -Path $deqp_source -ChildPath "external\vulkancts\mustpass\master" +$files = Get-Content "$($root_mustpass)\vk-default.txt" +foreach($file in $files) { + Get-Content "$($root_mustpass)\$($file)" | Add-Content -Path "$($deqp_mustpass)\vk-master.txt" +} +Remove-Item -Force -Recurse $deqp_source + +Get-Date +$url = 'https://static.rust-lang.org/rustup/dist/x86_64-pc-windows-msvc/rustup-init.exe'; +Write-Host ('Downloading {0} ...' -f $url); +Invoke-WebRequest -Uri $url -OutFile 'rustup-init.exe'; +Write-Host "Installing rust toolchain" +C:\rustup-init.exe -y; +Remove-Item C:\rustup-init.exe; + +Get-Date +Write-Host "Installing deqp-runner" +$env:Path += ";$($env:USERPROFILE)\.cargo\bin" +cargo install --git https://gitlab.freedesktop.org/anholt/deqp-runner.git + +Get-Date +Write-Host "Complete" diff --git a/lib/mesa/.gitlab-ci/windows/piglit_run.ps1 b/lib/mesa/.gitlab-ci/windows/piglit_run.ps1 index 3414fc2dc..2205b7ba0 100644 --- a/lib/mesa/.gitlab-ci/windows/piglit_run.ps1 +++ b/lib/mesa/.gitlab-ci/windows/piglit_run.ps1 @@ -9,7 +9,7 @@ cmd.exe /C "C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd6 py -3 C:\Piglit\bin\piglit.py summary console .\results | Select -SkipLast 1 | Select-String -NotMatch -Pattern ': pass' | Set-Content -Path .\result.txt -$reference = Get-Content ".\_install\$env:PIGLIT_PROFILE.txt" +$reference = Get-Content ".\_install\$env:PIGLIT_RESULTS.txt" $result = Get-Content .\result.txt if (-Not ($reference -And $result)) { Exit 1 diff --git a/lib/mesa/.gitlab-ci/windows/spirv2dxil_check.ps1 b/lib/mesa/.gitlab-ci/windows/spirv2dxil_check.ps1 new file mode 100644 index 000000000..bfa9fdc3d --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/spirv2dxil_check.ps1 @@ -0,0 +1,54 @@ +# Ensure that dxil.dll in on the %PATH% +$dxil_dll = cmd.exe /C "C:\BuildTools\Common7\Tools\VsDevCmd.bat -host_arch=amd64 -arch=amd64 -no_logo && where dxil.dll" 2>&1 +if ($dxil_dll -notmatch "dxil.dll$") { + Write-Output "Couldn't get path to dxil.dll" + exit 1 +} +$env:Path = "$(Split-Path $dxil_dll);$env:Path" + +$exec_mode_to_stage = @{ Fragment = "fragment"; Vertex = "vertex"; GLCompute = "compute" } + +$spvasm_files = (Get-ChildItem C:\spirv-samples\spvasm\*.spvasm) | Sort-Object Name +foreach ($spvasm in $spvasm_files) { + $test_name = "Test:$($spvasm.Name):" + $spvfile = ($spvasm -replace '\.spvasm$', '.spv') + $content = Get-Content $spvasm + $spv_version = "1.0" + if ($content | Where-Object { $_ -match 'Version:\s(\d+\.\d+)' }) { + $spv_version = $Matches[1] + } + + $as_output = C:\spirv-tools\bin\spirv-as.exe --target-env spv$spv_version --preserve-numeric-ids -o $spvfile $spvasm 2>&1 | % { if ($_ -is [System.Management.Automation.ErrorRecord]) { $_.Exception.Message } else { $_ } } | Out-String + if ($LASTEXITCODE -ne 0) { + Write-Output "$test_name Skip: Unable to assemble shader" + Write-Output "$as_output`n" + continue + } + + $entry_points = $content | Select-String -Pattern '^OpEntryPoint\s(\w+)[^"]+"(\w+)"' | Select-Object -ExpandProperty Matches -First 1 + if ($entry_points.Count -eq 0) { + Write-Output "$test_name Skip" + Write-Output "No OpEntryPoint not found`n" + continue + } + + foreach ($match in $entry_points) { + $exec_mode, $entry_point = $match.Groups[1].Value, $match.Groups[2].Value + $subtest = "$test_name$entry_point|${exec_mode}:" + $stage = $exec_mode_to_stage[$exec_mode] + if ($stage -eq '') { + Write-Output "$subtest Fail: Unknown shader type ($exec_mode)" + continue + } + + $s2d_output = .\_install\bin\spirv2dxil.exe -v -e "$entry_point" -s "$stage" -o NUL $spvfile 2>&1 | ForEach-Object { if ($_ -is [System.Management.Automation.ErrorRecord]) { $_.Exception.Message } else { $_ } } | Out-String + if ($LASTEXITCODE -eq 0) { + Write-Output "$subtest Pass" + } + else { + Write-Output "$subtest Fail" + $sanitized_output = $s2d_output -replace ', file .+, line \d+' -replace ' In file .+:\d+' + Write-Output "$sanitized_output`n" + } + } +} diff --git a/lib/mesa/.gitlab-ci/windows/spirv2dxil_run.ps1 b/lib/mesa/.gitlab-ci/windows/spirv2dxil_run.ps1 new file mode 100644 index 000000000..ae6c1c2cd --- /dev/null +++ b/lib/mesa/.gitlab-ci/windows/spirv2dxil_run.ps1 @@ -0,0 +1,16 @@ +. .\_install\spirv2dxil_check.ps1 2>&1 | Set-Content -Path .\spirv2dxil_results.txt +$reference = Get-Content .\_install\spirv2dxil_reference.txt +$result = Get-Content .\spirv2dxil_results.txt +if (-Not ($reference -And $result)) { + Exit 1 +} + +$diff = Compare-Object -ReferenceObject $reference -DifferenceObject $result +if (-Not $diff) { + Exit 0 +} + +Write-Host "Unexpected change in results:" +Write-Output $diff | Format-Table -Property SideIndicator, InputObject -Wrap + +Exit 1 |