Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[xsrc-public/xorg]: xsrc-public/external/mit/libdrm/dist initial import of li...
details: https://anonhg.NetBSD.org/xsrc-public/rev/220dd008b2bc
branches: xorg
changeset: 6937:220dd008b2bc
user: mrg <mrg%NetBSD.org@localhost>
date: Sun Jan 09 09:01:58 2022 +0000
description:
initial import of libdrm-2.4.109
diffstat:
external/mit/libdrm/dist/.gitlab-ci.yml | 280 +++++++++++
external/mit/libdrm/dist/.gitlab-ci/debian-install.sh | 66 ++
external/mit/libdrm/dist/amdgpu/amdgpu-symbols.txt | 1 +
external/mit/libdrm/dist/amdgpu/amdgpu.h | 13 +
external/mit/libdrm/dist/amdgpu/amdgpu_bo.c | 24 +-
external/mit/libdrm/dist/amdgpu/amdgpu_device.c | 5 +
external/mit/libdrm/dist/core-symbols.txt | 3 +
external/mit/libdrm/dist/data/amdgpu.ids | 375 +++++++-------
external/mit/libdrm/dist/etnaviv/etnaviv_bo.c | 13 +-
external/mit/libdrm/dist/etnaviv/etnaviv_drm.h | 13 +-
external/mit/libdrm/dist/exynos/exynos_drm.c | 6 +-
external/mit/libdrm/dist/freedreno/freedreno_bo.c | 10 +-
external/mit/libdrm/dist/gen_table_fourcc.py | 2 +-
external/mit/libdrm/dist/include/drm/amdgpu_drm.h | 18 +-
external/mit/libdrm/dist/include/drm/drm.h | 250 +++++++--
external/mit/libdrm/dist/include/drm/drm_fourcc.h | 141 +++++-
external/mit/libdrm/dist/include/drm/drm_mode.h | 170 +++++-
external/mit/libdrm/dist/intel/i915_pciids.h | 8 +-
external/mit/libdrm/dist/intel/intel_bufmgr_gem.c | 190 +-------
external/mit/libdrm/dist/intel/intel_decode.c | 41 +-
external/mit/libdrm/dist/man/drm-memory.7.rst | 17 +-
external/mit/libdrm/dist/meson.build | 43 +-
external/mit/libdrm/dist/nouveau/nouveau.c | 5 +-
external/mit/libdrm/dist/nouveau/pushbuf.c | 6 +-
external/mit/libdrm/dist/omap/omap_drm.c | 10 +-
external/mit/libdrm/dist/radeon/radeon_bo.h | 1 -
external/mit/libdrm/dist/radeon/radeon_bo_gem.c | 7 +-
external/mit/libdrm/dist/tegra/tegra.c | 6 +-
external/mit/libdrm/dist/tests/amdgpu/amdgpu_stress.c | 418 +++++++++++++++++
external/mit/libdrm/dist/tests/amdgpu/meson.build | 11 +
external/mit/libdrm/dist/tests/amdgpu/security_tests.c | 10 +-
external/mit/libdrm/dist/tests/modeprint/modeprint.c | 2 +-
external/mit/libdrm/dist/tests/modetest/modetest.c | 46 +-
external/mit/libdrm/dist/tests/proptest/proptest.c | 2 +-
external/mit/libdrm/dist/xf86drm.c | 217 ++++++--
external/mit/libdrm/dist/xf86drm.h | 4 +
external/mit/libdrm/dist/xf86drmMode.c | 108 ++++
external/mit/libdrm/dist/xf86drmMode.h | 24 +-
38 files changed, 1882 insertions(+), 684 deletions(-)
diffs (truncated from 4021 to 300 lines):
diff -r 22ccc9df09c9 -r 220dd008b2bc external/mit/libdrm/dist/.gitlab-ci.yml
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/external/mit/libdrm/dist/.gitlab-ci.yml Sun Jan 09 09:01:58 2022 +0000
@@ -0,0 +1,280 @@
+# This is the tag of the docker image used for the build jobs. If the
+# image doesn't exist yet, the containers stage 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.
+.templates_sha: &template_sha 567700e483aabed992d0a4fea84994a0472deff6 # see https://docs.gitlab.com/ee/ci/yaml/#includefile
+
+include:
+ - project: 'freedesktop/ci-templates'
+ ref: *template_sha
+ file:
+ - '/templates/debian.yml'
+ - '/templates/freebsd.yml'
+ - '/templates/ci-fairy.yml'
+
+variables:
+ FDO_UPSTREAM_REPO: mesa/drm
+ FDO_REPO_SUFFIX: "$BUILD_OS/$BUILD_ARCH"
+
+stages:
+ - "Base container"
+ - "Build"
+
+.ci-rules:
+ rules:
+ - when: on_success
+
+# CONTAINERS
+
+.os-debian:
+ variables:
+ BUILD_OS: debian
+ FDO_DISTRIBUTION_VERSION: buster
+ FDO_DISTRIBUTION_PACKAGES: 'build-essential docbook-xsl libatomic-ops-dev libcairo2-dev libcunit1-dev libpciaccess-dev meson ninja-build pkg-config python3 python3-pip python3-wheel
python3-setuptools python3-docutils valgrind'
+ FDO_DISTRIBUTION_EXEC: 'pip3 install meson==0.52.1'
+ # bump this tag every time you change something which requires rebuilding the
+ # base image
+ FDO_DISTRIBUTION_TAG: "2021-08-03.0"
+
+.debian-x86_64:
+ extends:
+ - .os-debian
+ variables:
+ BUILD_ARCH: "x86-64"
+
+.debian-aarch64:
+ extends:
+ - .os-debian
+ variables:
+ BUILD_ARCH: "aarch64"
+
+.debian-armv7:
+ extends:
+ - .os-debian
+ variables:
+ BUILD_ARCH: "armv7"
+
+.os-freebsd:
+ variables:
+ BUILD_OS: freebsd
+ FDO_DISTRIBUTION_VERSION: "13.0"
+ FDO_DISTRIBUTION_PACKAGES: 'meson ninja pkgconf libpciaccess libpthread-stubs py38-docutils cairo'
+ # bump this tag every time you change something which requires rebuilding the
+ # base image
+ FDO_DISTRIBUTION_TAG: "2021-11-10.1"
+
+.freebsd-x86_64:
+ extends:
+ - .os-freebsd
+ variables:
+ BUILD_ARCH: "x86_64"
+
+# Build our base container image, which contains the core distribution, the
+# toolchain, and all our build dependencies. This will be reused in the build
+# stage.
+x86_64-debian-container_prep:
+ extends:
+ - .ci-rules
+ - .debian-x86_64
+ - .fdo.container-build@debian
+ stage: "Base container"
+ variables:
+ GIT_STRATEGY: none
+
+aarch64-debian-container_prep:
+ extends:
+ - .ci-rules
+ - .debian-aarch64
+ - .fdo.container-build@debian
+ tags:
+ - aarch64
+ stage: "Base container"
+ variables:
+ GIT_STRATEGY: none
+
+armv7-debian-container_prep:
+ extends:
+ - .ci-rules
+ - .debian-armv7
+ - .fdo.container-build@debian
+ tags:
+ - aarch64
+ stage: "Base container"
+ variables:
+ GIT_STRATEGY: none
+ FDO_BASE_IMAGE: "arm32v7/debian:$FDO_DISTRIBUTION_VERSION"
+
+x86_64-freebsd-container_prep:
+ extends:
+ - .ci-rules
+ - .freebsd-x86_64
+ - .fdo.qemu-build@freebsd@x86_64
+ stage: "Base container"
+ variables:
+ GIT_STRATEGY: none
+
+# Core build environment.
+.build-env:
+ variables:
+ MESON_BUILD_TYPE: "-Dbuildtype=debug -Doptimization=0 -Db_sanitize=address,undefined"
+
+# OS/architecture-specific variants
+.build-env-debian-x86_64:
+ extends:
+ - .fdo.suffixed-image@debian
+ - .debian-x86_64
+ - .build-env
+ needs:
+ - job: x86_64-debian-container_prep
+ artifacts: false
+
+.build-env-debian-aarch64:
+ extends:
+ - .fdo.suffixed-image@debian
+ - .debian-aarch64
+ - .build-env
+ variables:
+ # At least with the versions we have, the LSan runtime makes fork unusably
+ # slow on AArch64, which is bad news since the test suite decides to fork
+ # for every single subtest. For now, in order to get AArch64 builds and
+ # tests into CI, just assume that we're not going to leak any more on
+ # AArch64 than we would on ARMv7 or x86-64.
+ ASAN_OPTIONS: "detect_leaks=0"
+ tags:
+ - aarch64
+ needs:
+ - job: aarch64-debian-container_prep
+ artifacts: false
+
+.build-env-debian-armv7:
+ extends:
+ - .fdo.suffixed-image@debian
+ - .debian-armv7
+ - .build-env
+ tags:
+ - aarch64
+ needs:
+ - job: armv7-debian-container_prep
+ artifacts: false
+
+.build-env-freebsd-x86_64:
+ variables:
+ # Compiling with ASan+UBSan appears to trigger an infinite loop in the
+ # compiler shipped with FreeBSD 13.0, so we only use UBSan here.
+ # Additionally, sanitizers can't be used with b_lundef on FreeBSD.
+ MESON_BUILD_TYPE: "-Dbuildtype=debug -Db_sanitize=undefined -Db_lundef=false"
+ extends:
+ - .fdo.suffixed-image@freebsd
+ - .freebsd-x86_64
+ - .build-env
+ needs:
+ - job: x86_64-freebsd-container_prep
+ artifacts: false
+
+# BUILD
+
+.do-build:
+ extends:
+ - .ci-rules
+ stage: "Build"
+ variables:
+ GIT_DEPTH: 10
+ script:
+ - meson build
+ -D amdgpu=true
+ -D cairo-tests=true
+ -D etnaviv=true
+ -D exynos=true
+ -D freedreno=true
+ -D freedreno-kgsl=true
+ -D intel=true
+ -D libkms=true
+ -D man-pages=true
+ -D nouveau=true
+ -D omap=true
+ -D radeon=true
+ -D tegra=true
+ -D udev=true
+ -D valgrind=auto
+ -D vc4=true
+ -D vmwgfx=true
+ - ninja -C build
+ - ninja -C build test
+ - DESTDIR=$PWD/install ninja -C build install
+ artifacts:
+ when: on_failure
+ paths:
+ - build/meson-logs/*
+
+.do-build-qemu:
+ extends:
+ - .ci-rules
+ stage: "Build"
+ script:
+ # Start the VM and copy our workspace to the VM
+ - /app/vmctl start
+ - scp -r $PWD "vm:"
+ # The `set +e is needed to ensure that we always copy the meson logs back to
+ # the workspace to see details about the failed tests.
+ - |
+ set +e
+ /app/vmctl exec "pkg info; cd $CI_PROJECT_NAME ; meson build -D amdgpu=true -D cairo-tests=true -D intel=true -D libkms=true -D man-pages=true -D nouveau=false -D radeon=true -D valgrind=auto
&& ninja -C build"
+ set -ex
+ scp -r vm:$CI_PROJECT_NAME/build/meson-logs .
+ /app/vmctl exec "ninja -C $CI_PROJECT_NAME/build install"
+ mkdir -p $PREFIX && scp -r vm:$PREFIX/ $PREFIX/
+ # Finally, shut down the VM.
+ - /app/vmctl stop
+ artifacts:
+ when: on_failure
+ paths:
+ - build/meson-logs/*
+
+# Full build and test.
+x86_64-debian-build:
+ extends:
+ - .build-env-debian-x86_64
+ - .do-build
+
+aarch64-debian-build:
+ extends:
+ - .build-env-debian-aarch64
+ - .do-build
+
+armv7-debian-build:
+ extends:
+ - .build-env-debian-armv7
+ - .do-build
+
+# Daily build
+meson-arch-daily:
+ rules:
+ - if: '$SCHEDULE == "arch-daily"'
+ when: on_success
+ - when: never
+ image: archlinux/archlinux:base-devel
+ before_script:
+ - pacman -Syu --noconfirm --needed
+ cairo
+ cunit
+ libatomic_ops
+ libpciaccess
+ meson
+ valgrind
+ python-docutils
+ extends: .do-build
+
+x86_64-freebsd-build:
+ extends:
+ - .build-env-freebsd-x86_64
+ - .do-build-qemu
diff -r 22ccc9df09c9 -r 220dd008b2bc external/mit/libdrm/dist/.gitlab-ci/debian-install.sh
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/external/mit/libdrm/dist/.gitlab-ci/debian-install.sh Sun Jan 09 09:01:58 2022 +0000
@@ -0,0 +1,66 @@
+#!/usr/bin/env bash
+set -o errexit
+set -o xtrace
+
+export DEBIAN_FRONTEND=noninteractive
+
+CROSS_ARCHITECTURES=(i386 armhf arm64 ppc64el)
+for arch in ${CROSS_ARCHITECTURES[@]}; do
+ dpkg --add-architecture $arch
+done
+
+apt-get install -y \
Home |
Main Index |
Thread Index |
Old Index