From 6ec9a1e9e1a418dd8f72cd4f1645849ec2ad10da Mon Sep 17 00:00:00 2001 From: Klaus Ziegler Date: Thu, 30 Dec 2021 17:46:15 +0100 Subject: [PATCH] 12395 Update to libdrm >= 2.4.97 upgrade libdrm-2.4.75 to libdrm-2.4.109 Add back logic to deal with illumos clone-open devices and searching the devices tree in drmGetMinorNameForFD Move gen...table_fourcc.h so clean will not remove it --- ISSUES | 23 + UPDATE_LIB | 40 + myenv.sh | 2 +- tools/bldenv | 0 usr/src/Makefile.master | 4 +- usr/src/cmd/drm-tests/Run_all.sh | 5 +- usr/src/cmd/drm-tests/misc1/Makefile.com | 1 - usr/src/cmd/drm-tests/modeprint/Makefile.com | 4 +- usr/src/common/libdrm/Check-patches | 12 +- usr/src/common/libdrm/Makefile | 8 +- usr/src/common/libdrm/Makefile.drm | 2 +- usr/src/common/libdrm/patches/etnaviv.patch | 8 +- usr/src/common/libdrm/patches/exynos.patch | 25 +- usr/src/common/libdrm/patches/freedreno.patch | 26 +- .../libdrm/patches/incl-drm-drm-h.patch | 10 +- .../libdrm/patches/incl-drm-i915-drm-h.patch | 20 +- usr/src/common/libdrm/patches/intel-drm.patch | 15 +- .../libdrm/patches/libdrm-lists-h.patch | 5 +- usr/src/common/libdrm/patches/omap.patch | 8 +- .../common/libdrm/patches/pkgconfig-in.patch | 57 +- .../libdrm/patches/util-double-list-h.patch | 5 +- .../common/libdrm/patches/util-math-h.patch | 11 - usr/src/common/libdrm/patches/xf86drm-c.patch | 154 ++- usr/src/common/libdrm/patches/xf86drm-h.patch | 27 +- .../common/libdrm/patches/xf86drmMode-c.patch | 15 - usr/src/lib/Makefile | 4 +- usr/src/lib/libdrm/Makefile.com | 3 +- .../common/generated_static_table_fourcc.h | 49 + usr/src/lib/libdrm_amdgpu/Makefile.com | 7 +- usr/src/lib/libdrm_etnaviv/Makefile | 74 ++ usr/src/lib/libdrm_etnaviv/Makefile.com | 59 + usr/src/lib/libdrm_etnaviv/amd64/Makefile | 21 + usr/src/lib/libdrm_etnaviv/i386/Makefile | 20 + usr/src/lib/libdrm_intel/Makefile.com | 2 +- usr/src/lib/libdrm_nouveau/Makefile | 74 ++ usr/src/lib/libdrm_nouveau/Makefile.com | 58 + usr/src/lib/libdrm_nouveau/amd64/Makefile | 21 + usr/src/lib/libdrm_nouveau/i386/Makefile | 20 + usr/src/man/Makefile | 2 - usr/src/pkg/Makefile | 2 +- .../pkg/manifests/driver-graphics-agpgart.mf | 41 +- usr/src/pkg/manifests/driver-graphics-drm.mf | 117 +- .../pkg/manifests/system-header-header-agp.mf | 10 +- .../pkg/manifests/system-header-header-drm.mf | 8 +- usr/src/pkg/manifests/system-test-libdrm.mf | 10 +- usr/src/pkg/manifests/x11-library-libdrm.mf | 82 +- usr/src/tools/cw/cw.c | 11 - usr/src/uts/common/drm/drm.h | 395 +++++- usr/src/uts/common/drm/drm_crtc.h | 2 +- usr/src/uts/common/drm/drm_fourcc.h | 1153 ++++++++++++++++- usr/src/uts/common/drm/drm_mode.h | 542 +++++++- usr/src/uts/common/drm/drm_sarea.h | 8 + usr/src/uts/common/drm/i915_drm.h | 574 +++++++- usr/src/uts/sparc/Makefile.files | 5 - usr/src/uts/sparc/Makefile.sparc | 6 +- usr/src/uts/sparc/drm/Makefile | 101 ++ 56 files changed, 3436 insertions(+), 532 deletions(-) create mode 100644 ISSUES create mode 100644 UPDATE_LIB mode change 100644 => 100755 tools/bldenv delete mode 100644 usr/src/common/libdrm/patches/util-math-h.patch delete mode 100644 usr/src/common/libdrm/patches/xf86drmMode-c.patch create mode 100644 usr/src/lib/libdrm/common/generated_static_table_fourcc.h create mode 100644 usr/src/lib/libdrm_etnaviv/Makefile create mode 100644 usr/src/lib/libdrm_etnaviv/Makefile.com create mode 100644 usr/src/lib/libdrm_etnaviv/amd64/Makefile create mode 100644 usr/src/lib/libdrm_etnaviv/i386/Makefile create mode 100644 usr/src/lib/libdrm_nouveau/Makefile create mode 100644 usr/src/lib/libdrm_nouveau/Makefile.com create mode 100644 usr/src/lib/libdrm_nouveau/amd64/Makefile create mode 100644 usr/src/lib/libdrm_nouveau/i386/Makefile create mode 100644 usr/src/uts/sparc/drm/Makefile diff --git a/ISSUES b/ISSUES new file mode 100644 index 00000000..62d131ff --- /dev/null +++ b/ISSUES @@ -0,0 +1,23 @@ + +Dec-30-2021 - Klaus Ziegler + +Issues left over up from release 2.4.109: + +1. This is just the upgrade from libdrm-2.4.75 to 2.4.109, no new functionality + of libdrm-2.4.109 has been checked or reflected in any manifest file, this + will be done in subsequent #PRs. + +2. Implement dynamic creation of the new header file: + + - generated_static_table_fourcc.h + + into the build process of gfx-drm using Python, the regular build process + of libdrm uses meson to build this header file. For the moment, the supplied + header file was created using a regular meson build of the library on SPARC + and Intel platforms to make sure there are no differences. + +3. The creation of manual pages has been disabled in usr/src/man/Makefile + for subdirectories man3 and man7, because illumos based distributions up to + date don't include rst2man(1) command. + +4. Get rid of 32bit support. diff --git a/UPDATE_LIB b/UPDATE_LIB new file mode 100644 index 00000000..68435ae4 --- /dev/null +++ b/UPDATE_LIB @@ -0,0 +1,40 @@ + +Dec-30-2021 - Klaus Ziegler + +To upgrade libdrm: + +change LIBDRM_VERS in +usr/src/common/libdrm/Makefile +usr/src/common/libdrm/Makefile.drm +LIBDRM_HASH in +usr/src/common/libdrm/Makefile + +If the file extension of the file to be downloaded has changed, it must be +changed in usr/src/pkg/manifests/x11-library-libdrm.mf and LIBDRM_ARCHIVE in +usr/src/common/libdrm/Makefile must be modified accordingly. + +# NOTE: if you want to contribute changes to this graphics/DRM gate, +# please use your own fork of gfx-drm.git and substitute HTTPS/URL below, +# to match your repository. + +After you have setup a build environment as follows: +git clone https://github.com/illumos/gfx-drm.git +cd gfx-drm +export BLDENV=tools/bldenv +chmod 755 tools/bldenv + +edit myenv.sh to suite your needs, and start the first build: +/usr/bin/env -i $BLDENV myenv.sh "cd usr/src; make install" + +most likely this first build will err'out right after unpacking +the new library archive. At this stage the make target: check +is run, which checks differences of gfx-drm headers and the +new library supplied headers, these 5 headers will be checked: + +drm.h drm_fourcc.h drm_mode.h drm_sarea.h i915_drm.h + +To pass check target, generate patch files for these headers: +cd usr/src/common/libdrm/libdrm-2.4./include/drm +gdiff -u drm.h /usr/src/uts/common/drm/drm.h > /tmp/drm.h.patch +and the others as well, then apply these patches to headers +contained in usr/src/uts/common/drm and restart the build. diff --git a/myenv.sh b/myenv.sh index ad052875..1973f4bb 100644 --- a/myenv.sh +++ b/myenv.sh @@ -64,7 +64,7 @@ export PKGARCHIVE="${CODEMGR_WS}/packages/${MACH}/nightly" # export PKGPUBLISHER_REDIST='on-redist' # Package manifest format version. -export PKGFMT_OUTPUT='v1' +export PKGFMT_OUTPUT='v2' # Disable shadow compilation. export CW_NO_SHADOW='1' diff --git a/tools/bldenv b/tools/bldenv old mode 100644 new mode 100755 diff --git a/usr/src/Makefile.master b/usr/src/Makefile.master index 33c7883c..055e74c5 100644 --- a/usr/src/Makefile.master +++ b/usr/src/Makefile.master @@ -179,7 +179,7 @@ ELFEDIT= /usr/bin/elfedit ELFSIGN= /usr/bin/elfsign DTRACE= /usr/sbin/dtrace -xnolibs UNIQ= /usr/bin/uniq -TAR= /usr/bin/tar +TAR= /usr/bin/gtar ASTBINDIR= /usr/ast/bin MSGCC= $(ASTBINDIR)/msgcc MSGFMT= /usr/bin/msgfmt -s @@ -300,7 +300,7 @@ CCABS32= -Wc,-xcode=abs32 # # generate v9 code which tolerates callers using the v7 ABI, for the sake of # system calls. -CC32BITCALLERS= -_gcc=-massume-32bit-callers +CC32BITCALLERS= # GCC, especially, is increasingly beginning to auto-inline functions and # sadly does so separately not under the general -fno-inline-functions diff --git a/usr/src/cmd/drm-tests/Run_all.sh b/usr/src/cmd/drm-tests/Run_all.sh index 52397666..e5bc8ab9 100644 --- a/usr/src/cmd/drm-tests/Run_all.sh +++ b/usr/src/cmd/drm-tests/Run_all.sh @@ -29,9 +29,10 @@ # /opt/drm-tests/Run_all.sh > drm-tests.log # -# Leaving out random (takes a while) +# Leaving out random (takes a while), and in the meantime has been removed. # Also updatedraw (broken at the moment) -TESTS="drmdevice dristat drmstat drmsl hash" +# Deleted dristat drmstat from list below, also gone. +TESTS="drmdevice drmsl hash" run_all() { for f in $TESTS ; do diff --git a/usr/src/cmd/drm-tests/misc1/Makefile.com b/usr/src/cmd/drm-tests/misc1/Makefile.com index 635e1f33..337f0a74 100644 --- a/usr/src/cmd/drm-tests/misc1/Makefile.com +++ b/usr/src/cmd/drm-tests/misc1/Makefile.com @@ -16,7 +16,6 @@ PROG= \ drmsl \ hash \ - random \ drmdevice include ../../Makefile.drm diff --git a/usr/src/cmd/drm-tests/modeprint/Makefile.com b/usr/src/cmd/drm-tests/modeprint/Makefile.com index 8617e63d..b677b6b6 100644 --- a/usr/src/cmd/drm-tests/modeprint/Makefile.com +++ b/usr/src/cmd/drm-tests/modeprint/Makefile.com @@ -20,11 +20,13 @@ include ../../Makefile.drm SRCDIR= $(LIBDRM_CMN_DIR)/tests/modeprint -LDLIBS += -ldrm -lm +LDLIBS += -ldrm -lm -lutil LDLIBS32 += -L$(ROOT)/usr/lib/xorg \ + -L$(SRC)/cmd/drm-tests/util/$(MACH) \ -R/usr/lib/xorg LDLIBS64 += -L$(ROOT)/usr/lib/xorg/$(MACH64) \ + -L$(SRC)/cmd/drm-tests/util/$(MACH64) \ -R/usr/lib/xorg/$(MACH64) all: $(PROG) diff --git a/usr/src/common/libdrm/Check-patches b/usr/src/common/libdrm/Check-patches index 02a212e8..648f20b7 100644 --- a/usr/src/common/libdrm/Check-patches +++ b/usr/src/common/libdrm/Check-patches @@ -52,8 +52,8 @@ # One big patch might be easier than all this... # but for now the patches are split up as shown below. -ref=libdrm-2.4.75-ref -dir=libdrm-2.4.75 +ref=libdrm-2.4.109-ref +dir=libdrm-2.4.109 # You make this directory by hand. Not doing this automatically # because I want to make srue you to know it's being written into. @@ -106,9 +106,6 @@ diff_ref libdrm_lists.h > $chk/libdrm-lists-h.patch echo patches/util-double-list-h.patch diff_ref util_double_list.h > $chk/util-double-list-h.patch -echo patches/util-math-h.patch -diff_ref util_math.h > $chk/util-math-h.patch - echo patches/xf86drm-c.patch diff_ref xf86drm.c > $chk/xf86drm-c.patch @@ -116,8 +113,5 @@ echo patches/xf86drm-h.patch ( head -27 patches/xf86drm-h.patch ; diff_ref xf86drm.h ) > $chk/xf86drm-h.patch -echo patches/xf86drmMode-c.patch -diff_ref xf86drmMode.c > $chk/xf86drmMode-c.patch - -diff -r patches $chk \ No newline at end of file +diff -r patches $chk diff --git a/usr/src/common/libdrm/Makefile b/usr/src/common/libdrm/Makefile index 6746b702..82e49297 100644 --- a/usr/src/common/libdrm/Makefile +++ b/usr/src/common/libdrm/Makefile @@ -23,12 +23,12 @@ FETCH= $(PYTHON) $(SRC)/tools/userland-fetch # See also: ./Makefile.drm LIBDRM_VERS and ./Check-patches # PLEASE RUN Check-patches after updating! -LIBDRM_VERS=2.4.75 +LIBDRM_VERS=2.4.109 LIBDRM_DIR=libdrm-$(LIBDRM_VERS) -LIBDRM_ARCHIVE=$(LIBDRM_DIR).tar.bz2 +LIBDRM_ARCHIVE=$(LIBDRM_DIR).tar.xz LIBDRM_URL=http://dri.freedesktop.org/libdrm/$(LIBDRM_ARCHIVE) -LIBDRM_HASH=sha256:2d5a500eef412cc287d12268eed79d571e262d4957a2ec9258073f305985054f +LIBDRM_HASH=sha256:629352e08c1fe84862ca046598d8a08ce14d26ab25ee1f4704f993d074cb7f26 def all install install_h: .patched check @@ -59,7 +59,7 @@ check: FRC touch $@ .unpacked: $(USERLAND_ARCHIVES)$(LIBDRM_ARCHIVE) - tar xvfjo $(USERLAND_ARCHIVES)$(LIBDRM_ARCHIVE) + gtar xvfJo $(USERLAND_ARCHIVES)$(LIBDRM_ARCHIVE) touch $@ $(USERLAND_ARCHIVES)$(LIBDRM_ARCHIVE) : diff --git a/usr/src/common/libdrm/Makefile.drm b/usr/src/common/libdrm/Makefile.drm index 0afa6ce7..5011653b 100644 --- a/usr/src/common/libdrm/Makefile.drm +++ b/usr/src/common/libdrm/Makefile.drm @@ -16,7 +16,7 @@ # This make include is used in $SRC/lib/libdrm/* # # See also: ./Makefile LIBDRM_VERS, ./Check-patches -LIBDRM_VERS=2.4.75 +LIBDRM_VERS=2.4.109 LIBDRM_CMN_DIR=$(SRC)/common/libdrm/libdrm-$(LIBDRM_VERS) diff --git a/usr/src/common/libdrm/patches/etnaviv.patch b/usr/src/common/libdrm/patches/etnaviv.patch index 397f500a..911c74d9 100644 --- a/usr/src/common/libdrm/patches/etnaviv.patch +++ b/usr/src/common/libdrm/patches/etnaviv.patch @@ -1,7 +1,7 @@ ---- libdrm-2.4.71/etnaviv/etnaviv_device.c.old 2016-10-18 23:11:06.163832408 +0300 -+++ libdrm-2.4.71/etnaviv/etnaviv_device.c 2016-10-18 23:12:18.805796392 +0300 -@@ -29,8 +29,8 @@ - #endif +--- libdrm-2.4.109/etnaviv/etnaviv_device.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/etnaviv/etnaviv_device.c 2021-12-28 12:57:52.347557016 +0000 +@@ -25,8 +25,8 @@ + */ #include -#include diff --git a/usr/src/common/libdrm/patches/exynos.patch b/usr/src/common/libdrm/patches/exynos.patch index cff1c8f0..20fe1090 100644 --- a/usr/src/common/libdrm/patches/exynos.patch +++ b/usr/src/common/libdrm/patches/exynos.patch @@ -1,7 +1,6 @@ -diff ... libdrm-2.4.73/exynos/exynos_drm.c ---- libdrm-2.4.73-ref/exynos/exynos_drm.c Wed Aug 24 12:57:39 2016 -+++ libdrm-2.4.73/exynos/exynos_drm.c Sat Dec 31 12:27:53 2016 -@@ -35,7 +35,7 @@ +--- libdrm-2.4.109/exynos/exynos_drm.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/exynos/exynos_drm.c 2021-12-28 12:57:52.350690170 +0000 +@@ -31,7 +31,7 @@ #include #include @@ -10,10 +9,9 @@ diff ... libdrm-2.4.73/exynos/exynos_drm.c #include -diff ... libdrm-2.4.73/exynos/exynos_fimg2d.c ---- libdrm-2.4.73-ref/exynos/exynos_fimg2d.c Wed Aug 24 12:57:39 2016 -+++ libdrm-2.4.73/exynos/exynos_fimg2d.c Sat Dec 31 17:52:27 2016 -@@ -21,7 +21,7 @@ +--- libdrm-2.4.109/exynos/exynos_fimg2d.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/exynos/exynos_fimg2d.c 2021-12-28 12:57:52.351308656 +0000 +@@ -30,7 +30,7 @@ #include #include @@ -22,7 +20,7 @@ diff ... libdrm-2.4.73/exynos/exynos_fimg2d.c #include -@@ -698,9 +698,10 @@ +@@ -693,9 +693,10 @@ if (negative) negative = 1; @@ -35,7 +33,7 @@ diff ... libdrm-2.4.73/exynos/exynos_fimg2d.c scale = 1; scale_x = g2d_get_scaling(src_w, dst_w); scale_y = g2d_get_scaling(src_h, dst_h); -@@ -920,9 +921,10 @@ +@@ -915,9 +916,10 @@ unsigned int scale, gem_space; unsigned int scale_x, scale_y; @@ -48,10 +46,9 @@ diff ... libdrm-2.4.73/exynos/exynos_fimg2d.c scale = 1; scale_x = g2d_get_scaling(src_w, dst_w); scale_y = g2d_get_scaling(src_h, dst_h); -diff ... libdrm-2.4.73/tests/exynos/exynos_fimg2d_test.c ---- libdrm-2.4.73-ref/tests/exynos/exynos_fimg2d_test.c Wed Aug 24 12:57:39 2016 -+++ libdrm-2.4.73/tests/exynos/exynos_fimg2d_test.c Sat Dec 31 12:27:53 2016 -@@ -22,7 +22,7 @@ +--- libdrm-2.4.109/tests/exynos/exynos_fimg2d_test.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/tests/exynos/exynos_fimg2d_test.c 2021-12-28 12:57:52.351698146 +0000 +@@ -31,7 +31,7 @@ #include #include diff --git a/usr/src/common/libdrm/patches/freedreno.patch b/usr/src/common/libdrm/patches/freedreno.patch index c486697c..ced2a866 100644 --- a/usr/src/common/libdrm/patches/freedreno.patch +++ b/usr/src/common/libdrm/patches/freedreno.patch @@ -1,24 +1,12 @@ -diff ... libdrm-2.4.73/freedreno/kgsl/kgsl_bo.c ---- libdrm-2.4.73-ref/freedreno/kgsl/kgsl_bo.c Wed Aug 24 12:57:41 2016 -+++ libdrm-2.4.73/freedreno/kgsl/kgsl_bo.c Sat Dec 31 12:27:53 2016 -@@ -32,7 +32,5 @@ +--- libdrm-2.4.109/freedreno/kgsl/kgsl_bo.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/freedreno/kgsl/kgsl_bo.c 2021-12-29 08:58:14.846699228 +0000 +@@ -28,7 +28,9 @@ #include "kgsl_priv.h" --#include -- ++#ifndef __sun + #include ++#endif + static int set_memtype(struct fd_device *dev, uint32_t handle, uint32_t flags) { -diff ... libdrm-2.4.73/freedreno/kgsl/kgsl_ringbuffer.c ---- libdrm-2.4.73-ref/freedreno/kgsl/kgsl_ringbuffer.c Mon Nov 14 12:55:20 2016 -+++ libdrm-2.4.73/freedreno/kgsl/kgsl_ringbuffer.c Sat Dec 31 18:02:19 2016 -@@ -146,7 +146,8 @@ - ibdesc.gpuaddr = kgsl_ring->bo->gpuaddr; - ibdesc.hostptr = kgsl_ring->bo->hostptr; - ibdesc.sizedwords = 0x145; -- req.timestamp = (uint32_t)kgsl_ring->bo->hostptr; -+ /* This way to avoid GCC -Wpointer-to-int-cast */ -+ req.timestamp = (unsigned int) (unsigned long) kgsl_ring->bo->hostptr; - } - - do { diff --git a/usr/src/common/libdrm/patches/incl-drm-drm-h.patch b/usr/src/common/libdrm/patches/incl-drm-drm-h.patch index 0c38211f..9d4e8683 100644 --- a/usr/src/common/libdrm/patches/incl-drm-drm-h.patch +++ b/usr/src/common/libdrm/patches/incl-drm-drm-h.patch @@ -25,10 +25,8 @@ # or other dealings in this Software without prior written authorization # of the copyright holder. -diff -u ... libdrm-2.4.73/include/drm/drm.h -index 8adb9d5..f9bedd0 100644 ---- libdrm-2.4.73-ref/include/drm/drm.h Mon Nov 14 14:46:05 2016 -+++ libdrm-2.4.73/include/drm/drm.h Mon Nov 28 14:32:21 2016 +--- libdrm-2.4.109/include/drm/drm.h.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/include/drm/drm.h 2021-12-28 13:56:31.700232551 +0000 @@ -55,14 +55,40 @@ typedef int64_t __s64; typedef uint64_t __u64; @@ -80,7 +78,7 @@ index 8adb9d5..f9bedd0 100644 + _DRM_GEM = 6 /**< GEM object (XXX: Not libdrm?) */ }; - /** + /* @@ -214,12 +241,13 @@ * \sa drmAddMap(). */ @@ -135,4 +133,4 @@ index 8adb9d5..f9bedd0 100644 + int fd; }; - /** + /* diff --git a/usr/src/common/libdrm/patches/incl-drm-i915-drm-h.patch b/usr/src/common/libdrm/patches/incl-drm-i915-drm-h.patch index 8c653533..844b799a 100644 --- a/usr/src/common/libdrm/patches/incl-drm-i915-drm-h.patch +++ b/usr/src/common/libdrm/patches/incl-drm-i915-drm-h.patch @@ -25,10 +25,9 @@ # or other dealings in this Software without prior written authorization # of the copyright holder. -diff ... libdrm-2.4.75/include/drm/i915_drm.h ---- libdrm-2.4.75-ref/include/drm/i915_drm.h Fri Jan 27 20:15:16 2017 -+++ libdrm-2.4.75/include/drm/i915_drm.h Fri Apr 21 21:31:17 2017 -@@ -128,6 +128,7 @@ +--- libdrm-2.4.109/include/drm/i915_drm.h.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/include/drm/i915_drm.h 2021-12-28 13:56:31.703875110 +0000 +@@ -208,6 +208,7 @@ int pf_current_page; /* which buffer is being displayed? */ int perf_boxes; /* performance boxes to be displayed */ int width, height; /* screen size in pixels */ @@ -36,7 +35,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h drm_handle_t front_handle; int front_offset; -@@ -167,6 +168,8 @@ +@@ -247,6 +248,8 @@ int pipeB_w; int pipeB_h; @@ -45,7 +44,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h /* fill out some space for old userspace triple buffer */ drm_handle_t unused_handle; __u32 unused1, unused2, unused3; -@@ -265,11 +268,14 @@ +@@ -349,11 +352,14 @@ #define DRM_IOCTL_I915_FLUSH DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLUSH) #define DRM_IOCTL_I915_FLIP DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLIP) #define DRM_IOCTL_I915_BATCHBUFFER DRM_IOW( DRM_COMMAND_BASE + DRM_I915_BATCHBUFFER, drm_i915_batchbuffer_t) @@ -63,7 +62,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h #define DRM_IOCTL_I915_FREE DRM_IOW( DRM_COMMAND_BASE + DRM_I915_FREE, drm_i915_mem_free_t) #define DRM_IOCTL_I915_INIT_HEAP DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT_HEAP, drm_i915_mem_init_heap_t) #define DRM_IOCTL_I915_CMDBUFFER DRM_IOW( DRM_COMMAND_BASE + DRM_I915_CMDBUFFER, drm_i915_cmdbuffer_t) -@@ -328,6 +334,15 @@ +@@ -416,6 +422,15 @@ struct drm_clip_rect *cliprects; /* pointer to userspace cliprects */ } drm_i915_batchbuffer_t; @@ -79,7 +78,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h /* As above, but pass a pointer to userspace buffer which can be * validated by the kernel prior to sending to hardware. */ -@@ -340,6 +355,15 @@ +@@ -428,12 +443,25 @@ struct drm_clip_rect *cliprects; /* pointer to userspace cliprects */ } drm_i915_cmdbuffer_t; @@ -95,7 +94,6 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h /* Userspace can request & wait on irq's: */ typedef struct drm_i915_irq_emit { -@@ -346,6 +370,10 @@ int *irq_seq; } drm_i915_irq_emit_t; @@ -106,7 +104,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h typedef struct drm_i915_irq_wait { int irq_seq; } drm_i915_irq_wait_t; -@@ -421,6 +449,11 @@ +@@ -597,6 +625,11 @@ int *value; } drm_i915_getparam_t; @@ -118,7 +116,7 @@ diff ... libdrm-2.4.75/include/drm/i915_drm.h /* Ioctl to set kernel params: */ #define I915_SETPARAM_USE_MI_BATCHBUFFER_START 1 -@@ -444,6 +477,13 @@ +@@ -621,6 +654,13 @@ int *region_offset; /* offset from start of fb or agp */ } drm_i915_mem_alloc_t; diff --git a/usr/src/common/libdrm/patches/intel-drm.patch b/usr/src/common/libdrm/patches/intel-drm.patch index 1124cc39..3a4a1813 100644 --- a/usr/src/common/libdrm/patches/intel-drm.patch +++ b/usr/src/common/libdrm/patches/intel-drm.patch @@ -1,7 +1,6 @@ -diff ... libdrm-2.4.75/intel/intel_bufmgr_gem.c ---- libdrm-2.4.75-ref/intel/intel_bufmgr_gem.c Fri Jan 27 20:15:16 2017 -+++ libdrm-2.4.75/intel/intel_bufmgr_gem.c Fri Apr 21 21:31:17 2017 -@@ -3445,6 +3445,16 @@ +--- libdrm-2.4.109/intel/intel_bufmgr_gem.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/intel/intel_bufmgr_gem.c 2021-12-28 14:55:05.655173523 +0000 +@@ -3357,13 +3357,24 @@ static pthread_mutex_t bufmgr_list_mutex = PTHREAD_MUTEX_INITIALIZER; static drmMMListHead bufmgr_list = { &bufmgr_list, &bufmgr_list }; @@ -18,7 +17,6 @@ diff ... libdrm-2.4.75/intel/intel_bufmgr_gem.c static drm_intel_bufmgr_gem * drm_intel_bufmgr_gem_find(int fd) { -@@ -3451,7 +3461,8 @@ drm_intel_bufmgr_gem *bufmgr_gem; DRMLISTFOREACHENTRY(bufmgr_gem, &bufmgr_list, managers) { @@ -28,10 +26,9 @@ diff ... libdrm-2.4.75/intel/intel_bufmgr_gem.c atomic_inc(&bufmgr_gem->refcount); return bufmgr_gem; } -diff ... libdrm-2.4.75/intel/intel_decode.c ---- libdrm-2.4.75-ref/intel/intel_decode.c Mon Dec 12 21:45:20 2016 -+++ libdrm-2.4.75/intel/intel_decode.c Fri Apr 21 21:31:17 2017 -@@ -402,6 +402,7 @@ +--- libdrm-2.4.109/intel/intel_decode.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/intel/intel_decode.c 2021-12-28 14:55:05.656127083 +0000 +@@ -398,6 +398,7 @@ format = "1555"; break; case 3: diff --git a/usr/src/common/libdrm/patches/libdrm-lists-h.patch b/usr/src/common/libdrm/patches/libdrm-lists-h.patch index bd94d4c9..778e682b 100644 --- a/usr/src/common/libdrm/patches/libdrm-lists-h.patch +++ b/usr/src/common/libdrm/patches/libdrm-lists-h.patch @@ -1,6 +1,5 @@ -diff ... libdrm-2.4.67/libdrm_lists.h ---- libdrm-2.4.67/libdrm_lists.h.~1~ Thu Feb 14 10:14:08 2013 -+++ libdrm-2.4.67/libdrm_lists.h Sat Oct 29 18:53:40 2016 +--- libdrm-2.4.109/libdrm_lists.h.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/libdrm_lists.h 2021-12-28 13:56:31.711469288 +0000 @@ -96,18 +96,18 @@ (__item) = (__temp), (__temp) = (__item)->prev) diff --git a/usr/src/common/libdrm/patches/omap.patch b/usr/src/common/libdrm/patches/omap.patch index baa4cdd4..815638aa 100644 --- a/usr/src/common/libdrm/patches/omap.patch +++ b/usr/src/common/libdrm/patches/omap.patch @@ -1,7 +1,7 @@ ---- libdrm-2.4.58/omap/omap_drm.c.backup 2015-01-08 18:32:54.476979307 +0300 -+++ libdrm-2.4.58/omap/omap_drm.c 2015-01-08 18:34:06.884595926 +0300 -@@ -31,8 +31,8 @@ - #endif +--- libdrm-2.4.109/omap/omap_drm.c.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/omap/omap_drm.c 2021-12-28 13:56:31.714330845 +0000 +@@ -27,8 +27,8 @@ + */ #include -#include diff --git a/usr/src/common/libdrm/patches/pkgconfig-in.patch b/usr/src/common/libdrm/patches/pkgconfig-in.patch index d4241917..3fb5a298 100644 --- a/usr/src/common/libdrm/patches/pkgconfig-in.patch +++ b/usr/src/common/libdrm/patches/pkgconfig-in.patch @@ -1,6 +1,5 @@ -diff ... libdrm-2.4.73/amdgpu/libdrm_amdgpu.pc.in ---- libdrm-2.4.73-ref/amdgpu/libdrm_amdgpu.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/amdgpu/libdrm_amdgpu.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/amdgpu/libdrm_amdgpu.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/amdgpu/libdrm_amdgpu.pc.in 2021-12-28 13:56:31.717174443 +0000 @@ -6,6 +6,6 @@ Name: libdrm_amdgpu Description: Userspace interface to kernel DRM services for amdgpu @@ -10,9 +9,8 @@ diff ... libdrm-2.4.73/amdgpu/libdrm_amdgpu.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_amdgpu +Cflags: -I${includedir} -I${includedir}/drm Requires.private: libdrm -diff ... libdrm-2.4.73/etnaviv/libdrm_etnaviv.pc.in ---- libdrm-2.4.73-ref/etnaviv/libdrm_etnaviv.pc.in Mon Nov 14 12:55:20 2016 -+++ libdrm-2.4.73/etnaviv/libdrm_etnaviv.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/etnaviv/libdrm_etnaviv.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/etnaviv/libdrm_etnaviv.pc.in 2021-12-28 13:56:31.717523043 +0000 @@ -7,5 +7,5 @@ Description: Userspace interface to etnaviv kernel DRM services Version: @PACKAGE_VERSION@ @@ -20,9 +18,8 @@ diff ... libdrm-2.4.73/etnaviv/libdrm_etnaviv.pc.in -Cflags: -I${includedir} -I${includedir}/libdrm +Cflags: -I${includedir} -I${includedir}/drm Requires.private: libdrm -diff ... libdrm-2.4.73/exynos/libdrm_exynos.pc.in ---- libdrm-2.4.73-ref/exynos/libdrm_exynos.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/exynos/libdrm_exynos.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/exynos/libdrm_exynos.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/exynos/libdrm_exynos.pc.in 2021-12-28 13:56:31.717782111 +0000 @@ -6,6 +6,6 @@ Name: libdrm_exynos Description: Userspace interface to exynos kernel DRM services @@ -32,9 +29,8 @@ diff ... libdrm-2.4.73/exynos/libdrm_exynos.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_exynos +Cflags: -I${includedir} -I${includedir}/drm -I${includedir}/exynos Requires.private: libdrm -diff ... libdrm-2.4.73/freedreno/libdrm_freedreno.pc.in ---- libdrm-2.4.73-ref/freedreno/libdrm_freedreno.pc.in Mon Jun 29 12:32:59 2015 -+++ libdrm-2.4.73/freedreno/libdrm_freedreno.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/freedreno/libdrm_freedreno.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/freedreno/libdrm_freedreno.pc.in 2021-12-28 13:56:31.718045519 +0000 @@ -6,6 +6,6 @@ Name: libdrm_freedreno Description: Userspace interface to freedreno kernel DRM services @@ -44,9 +40,8 @@ diff ... libdrm-2.4.73/freedreno/libdrm_freedreno.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_freedreno +Cflags: -I${includedir} -I${includedir}/drm -I${includedir}/freedreno Requires.private: libdrm -diff ... libdrm-2.4.73/intel/libdrm_intel.pc.in ---- libdrm-2.4.73-ref/intel/libdrm_intel.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/intel/libdrm_intel.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/intel/libdrm_intel.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/intel/libdrm_intel.pc.in 2021-12-28 13:56:31.718309459 +0000 @@ -7,5 +7,5 @@ Description: Userspace interface to intel kernel DRM services Version: @PACKAGE_VERSION@ @@ -55,9 +50,8 @@ diff ... libdrm-2.4.73/intel/libdrm_intel.pc.in -Cflags: -I${includedir} -I${includedir}/libdrm +Libs: -L${libdir} -R${libdir} -ldrm_intel +Cflags: -I${includedir} -I${includedir}/drm -diff ... libdrm-2.4.73/libdrm.pc.in ---- libdrm-2.4.73-ref/libdrm.pc.in Mon Jun 29 12:32:59 2015 -+++ libdrm-2.4.73/libdrm.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/libdrm.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/libdrm.pc.in 2021-12-28 13:56:31.718562768 +0000 @@ -6,5 +6,5 @@ Name: libdrm Description: Userspace interface to kernel DRM services @@ -66,20 +60,18 @@ diff ... libdrm-2.4.73/libdrm.pc.in -Cflags: -I${includedir} -I${includedir}/libdrm +Libs: -L${libdir} -R${libdir} -ldrm +Cflags: -I${includedir} -I${includedir}/drm -diff ... libdrm-2.4.73/libkms/libkms.pc.in ---- libdrm-2.4.73-ref/libkms/libkms.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/libkms/libkms.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/libkms/libkms.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/libkms/libkms.pc.in 2021-12-28 13:56:31.718872073 +0000 @@ -6,6 +6,6 @@ Name: libkms - Description: Library that abstract aways the different mm interface for kernel drivers + Description: Library that abstracts away the different mm interface for kernel drivers Version: 1.0.0 -Libs: -L${libdir} -lkms +Libs: -L${libdir} -R${libdir} -lkms Cflags: -I${includedir}/libkms Requires.private: libdrm -diff ... libdrm-2.4.73/nouveau/libdrm_nouveau.pc.in ---- libdrm-2.4.73-ref/nouveau/libdrm_nouveau.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/nouveau/libdrm_nouveau.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/nouveau/libdrm_nouveau.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/nouveau/libdrm_nouveau.pc.in 2021-12-28 13:56:31.719138480 +0000 @@ -6,6 +6,6 @@ Name: libdrm_nouveau Description: Userspace interface to nouveau kernel DRM services @@ -89,9 +81,8 @@ diff ... libdrm-2.4.73/nouveau/libdrm_nouveau.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_nouveau +Cflags: -I${includedir} -I${includedir}/drm -I${includedir}/drm/nouveau Requires.private: libdrm -diff ... libdrm-2.4.73/omap/libdrm_omap.pc.in ---- libdrm-2.4.73-ref/omap/libdrm_omap.pc.in Mon Jun 29 12:32:59 2015 -+++ libdrm-2.4.73/omap/libdrm_omap.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/omap/libdrm_omap.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/omap/libdrm_omap.pc.in 2021-12-28 13:56:31.719394584 +0000 @@ -6,6 +6,6 @@ Name: libdrm_omap Description: Userspace interface to omap kernel DRM services @@ -101,9 +92,8 @@ diff ... libdrm-2.4.73/omap/libdrm_omap.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_omap +Cflags: -I${includedir} -I${includedir}/drm -I${includedir}/omap Requires.private: libdrm -diff ... libdrm-2.4.73/radeon/libdrm_radeon.pc.in ---- libdrm-2.4.73-ref/radeon/libdrm_radeon.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/radeon/libdrm_radeon.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/radeon/libdrm_radeon.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/radeon/libdrm_radeon.pc.in 2021-12-28 13:56:31.719662132 +0000 @@ -6,6 +6,6 @@ Name: libdrm_radeon Description: Userspace interface to kernel DRM services for radeon @@ -113,9 +103,8 @@ diff ... libdrm-2.4.73/radeon/libdrm_radeon.pc.in +Libs: -L${libdir} -R${libdir} -ldrm_radeon +Cflags: -I${includedir} -I${includedir}/drm Requires.private: libdrm -diff ... libdrm-2.4.73/tegra/libdrm_tegra.pc.in ---- libdrm-2.4.73-ref/tegra/libdrm_tegra.pc.in Thu Jun 30 10:28:51 2016 -+++ libdrm-2.4.73/tegra/libdrm_tegra.pc.in Sat Dec 31 00:51:51 2016 +--- libdrm-2.4.109/tegra/libdrm_tegra.pc.in.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/tegra/libdrm_tegra.pc.in 2021-12-28 13:56:31.719935522 +0000 @@ -6,6 +6,6 @@ Name: libdrm_tegra Description: Userspace interface to Tegra kernel DRM services diff --git a/usr/src/common/libdrm/patches/util-double-list-h.patch b/usr/src/common/libdrm/patches/util-double-list-h.patch index 91677ad2..cc0bfea8 100644 --- a/usr/src/common/libdrm/patches/util-double-list-h.patch +++ b/usr/src/common/libdrm/patches/util-double-list-h.patch @@ -1,6 +1,5 @@ -diff ... libdrm-2.4.71/util_double_list.h ---- libdrm-2.4.71/util_double_list.h.~1~ Tue Aug 2 16:22:45 2016 -+++ libdrm-2.4.71/util_double_list.h Sat Nov 19 10:37:40 2016 +--- libdrm-2.4.109/util_double_list.h.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/util_double_list.h 2021-12-28 13:56:31.722430676 +0000 @@ -110,7 +110,7 @@ #ifndef container_of #define container_of(ptr, sample, member) \ diff --git a/usr/src/common/libdrm/patches/util-math-h.patch b/usr/src/common/libdrm/patches/util-math-h.patch deleted file mode 100644 index 69f51f2e..00000000 --- a/usr/src/common/libdrm/patches/util-math-h.patch +++ /dev/null @@ -1,11 +0,0 @@ -diff ... libdrm-2.4.67/util_math.h ---- libdrm-2.4.67/util_math.h.~1~ Fri Oct 23 13:58:02 2015 -+++ libdrm-2.4.67/util_math.h Sat Oct 29 20:59:51 2016 -@@ -29,6 +29,6 @@ - #define MAX3( A, B, C ) ((A) > (B) ? MAX2(A, C) : MAX2(B, C)) - - #define __align_mask(value, mask) (((value) + (mask)) & ~(mask)) --#define ALIGN(value, alignment) __align_mask(value, (typeof(value))((alignment) - 1)) -+#define ALIGN(value, alignment) __align_mask(value, (__typeof(value))((alignment) - 1)) - - #endif /*_UTIL_MATH_H_*/ diff --git a/usr/src/common/libdrm/patches/xf86drm-c.patch b/usr/src/common/libdrm/patches/xf86drm-c.patch index 87dffc99..f316e330 100644 --- a/usr/src/common/libdrm/patches/xf86drm-c.patch +++ b/usr/src/common/libdrm/patches/xf86drm-c.patch @@ -1,19 +1,19 @@ -diff ... libdrm-2.4.75/xf86drm.c ---- libdrm-2.4.75-ref/xf86drm.c Fri Jan 27 20:15:16 2017 -+++ libdrm-2.4.75/xf86drm.c Sat Apr 22 13:29:51 2017 -@@ -98,6 +98,11 @@ +diff ... libdrm-2.4.109/xf86drm.c +--- libdrm-2.4.109-ref/xf86drm.c Thu Nov 25 15:33:02 2021 ++++ libdrm-2.4.109/xf86drm.c Mon Jan 3 17:41:28 2022 +@@ -97,6 +97,11 @@ #endif #endif /* __OpenBSD__ */ +#if defined(__sun) +/* Device majors are dynamic. */ -+#define DRM_MAJOR (_sun_drm_get_major()) ++#define DRM_MAJOR (_sun_drm_get_major()) +#endif /* __sun */ + #ifndef DRM_MAJOR #define DRM_MAJOR 226 /* Linux */ #endif -@@ -365,9 +370,14 @@ +@@ -805,9 +810,14 @@ if (stat(DRM_DIR_NAME, &st)) { if (!isroot) return DRM_ERR_NOT_ROOT; @@ -28,7 +28,7 @@ diff ... libdrm-2.4.75/xf86drm.c } /* Check if the device node exists and create it if necessary. */ -@@ -374,8 +384,13 @@ +@@ -814,8 +824,13 @@ if (stat(buf, &st)) { if (!isroot) return DRM_ERR_NOT_ROOT; @@ -42,26 +42,7 @@ diff ... libdrm-2.4.75/xf86drm.c } if (drm_server_info && drm_server_info->get_perms) { -@@ -421,6 +436,10 @@ - if (st.st_rdev != dev) { - if (!isroot) - return DRM_ERR_NOT_ROOT; -+#if defined(__sun) -+ /* Let the system do this. */ -+ return DRM_ERR_NO_DEVICE; -+#else - remove(buf); - mknod(buf, S_IFCHR | devmode, dev); - if (drm_server_info && drm_server_info->get_perms) { -@@ -427,6 +446,7 @@ - chown_check_return(buf, user, group); - chmod(buf, devmode); - } -+#endif - } - fd = open(buf, O_RDWR, 0); - drmMsg("drmOpenDevice: open result is %d, (%s)\n", -@@ -548,6 +568,7 @@ +@@ -997,6 +1012,7 @@ } } @@ -69,7 +50,7 @@ diff ... libdrm-2.4.75/xf86drm.c static const char *drmGetMinorName(int type) { switch (type) { -@@ -561,6 +582,7 @@ +@@ -1010,6 +1026,7 @@ return NULL; } } @@ -77,22 +58,23 @@ diff ... libdrm-2.4.75/xf86drm.c /** * Open the device by bus ID. -@@ -1124,7 +1146,7 @@ +@@ -1573,7 +1590,7 @@ drm_map_t map; memclear(map); - map.handle = (void *)(uintptr_t)handle; -+ map.handle = (drm_handle_t)(uintptr_t)handle; ++ map.handle = (int)(void *)(uintptr_t)handle; if(drmIoctl(fd, DRM_IOCTL_RM_MAP, &map)) return -errno; -@@ -2712,6 +2734,15 @@ +@@ -3244,6 +3261,16 @@ fstat(fd, &sbuf); d = sbuf.st_rdev; +#if defined(__sun) + /* -+ * Get rid of clone-open bits in the minor number. ++ * Get rid of clone-open bits in the minor number, ++ * otherwise it will not match any /dev nodes. + * See: the drm driver drm_sun_open() + * Don't have DRM_CLONEID_NBITS here. + */ @@ -102,10 +84,10 @@ diff ... libdrm-2.4.75/xf86drm.c for (i = 0; i < DRM_MAX_MINOR; i++) { snprintf(name, sizeof name, DRM_DEV_NAME, DRM_DIR_NAME, i); if (stat(name, &sbuf) == 0 && sbuf.st_rdev == d) -@@ -2833,6 +2864,25 @@ +@@ -3431,6 +3458,25 @@ + id + drmGetMinorBase(type)); - out_close_dir: - closedir(sysdir); + return strdup(name); +#elif defined(__sun) /* illumos, OSol */ + struct stat sbuf; + char *path = NULL; @@ -124,13 +106,13 @@ diff ... libdrm-2.4.75/xf86drm.c + err = _sun_drm_find_device(min, &path); + if (err == 0) + return (path); -+ /* else ... (ret NULL at endif) */ ++ return (NULL); #else struct stat sbuf; char buf[PATH_MAX + 1]; -@@ -2962,6 +3012,20 @@ - return -EINVAL; - #elif defined(__OpenBSD__) +@@ -3575,6 +3621,20 @@ + return subsystem_type; + #elif defined(__OpenBSD__) || defined(__DragonFly__) || defined(__FreeBSD__) return DRM_BUS_PCI; +#elif defined(__sun) /* illumos, OSol */ + char *path = NULL; @@ -149,10 +131,10 @@ diff ... libdrm-2.4.75/xf86drm.c #else #warning "Missing implementation of drmParseSubsystemType" return -EINVAL; -@@ -3017,6 +3081,21 @@ - info->func = pinfo.func; - +@@ -3710,6 +3770,21 @@ return 0; + #elif defined(__FreeBSD__) + return get_sysctl_pci_bus_info(maj, min, info); +#elif defined(__sun) /* illumos, OSol */ + char *path = NULL; + int err; @@ -171,8 +153,8 @@ diff ... libdrm-2.4.75/xf86drm.c #else #warning "Missing implementation of drmParsePciBusInfo" return -EINVAL; -@@ -3182,6 +3261,21 @@ - device->subdevice_id = pinfo.subdevice_id; +@@ -3923,6 +3998,21 @@ + device->revision_id = results[0].pc_revid; return 0; +#elif defined(__sun) /* illumos, OSol */ @@ -193,3 +175,87 @@ diff ... libdrm-2.4.75/xf86drm.c #else #warning "Missing implementation of drmParsePciDeviceInfo" return -EINVAL; +@@ -4152,6 +4242,20 @@ + info->dev = dev; + + return 0; ++#elif defined(__sun) /* illumos, OSol */ ++ char *path = NULL; ++ int ret; ++ ++ if (maj != DRM_MAJOR) ++ return -EINVAL; ++ ++ ret = _sun_drm_find_device(min, &path); ++ if (ret != 0) ++ return (ret); ++ ++ ret = _sun_drm_get_subsystem(path); ++ free(path); ++ return (ret); + #else + #warning "Missing implementation of drmParseUsbBusInfo" + return -EINVAL; +@@ -4183,6 +4287,20 @@ + info->product = product; + + return 0; ++#elif defined(__sun) /* illumos, OSol */ ++ char *path = NULL; ++ int ret; ++ ++ if (maj != DRM_MAJOR) ++ return -EINVAL; ++ ++ ret = _sun_drm_find_device(min, &path); ++ if (ret != 0) ++ return (ret); ++ ++ ret = _sun_drm_get_subsystem(path); ++ free(path); ++ return (ret); + #else + #warning "Missing implementation of drmParseUsbDeviceInfo" + return -EINVAL; +@@ -4257,6 +4375,20 @@ + free(name); + + return 0; ++#elif defined(__sun) /* illumos, OSol */ ++ char *path = NULL; ++ int ret; ++ ++ if (maj != DRM_MAJOR) ++ return -EINVAL; ++ ++ ret = _sun_drm_find_device(min, &path); ++ if (ret != 0) ++ return (ret); ++ ++ ret = _sun_drm_get_subsystem(path); ++ free(path); ++ return (ret); + #else + #warning "Missing implementation of drmParseOFBusInfo" + return -EINVAL; +@@ -4317,6 +4449,20 @@ + + free(*compatible); + return err; ++#elif defined(__sun) /* illumos, OSol */ ++ char *path = NULL; ++ int ret; ++ ++ if (maj != DRM_MAJOR) ++ return -EINVAL; ++ ++ ret = _sun_drm_find_device(min, &path); ++ if (ret != 0) ++ return (ret); ++ ++ ret = _sun_drm_get_subsystem(path); ++ free(path); ++ return (ret); + #else + #warning "Missing implementation of drmParseOFDeviceInfo" + return -EINVAL; diff --git a/usr/src/common/libdrm/patches/xf86drm-h.patch b/usr/src/common/libdrm/patches/xf86drm-h.patch index 443439d9..9319299e 100644 --- a/usr/src/common/libdrm/patches/xf86drm-h.patch +++ b/usr/src/common/libdrm/patches/xf86drm-h.patch @@ -25,30 +25,11 @@ # or other dealings in this Software without prior written authorization # of the copyright holder. -diff ... libdrm-2.4.75/xf86drm.h ---- libdrm-2.4.75-ref/xf86drm.h Fri Jan 27 20:15:16 2017 -+++ libdrm-2.4.75/xf86drm.h Sat Apr 22 12:58:07 2017 -@@ -472,6 +472,17 @@ - #endif /* architecture */ - #endif /* __GNUC__ >= 2 */ - -+#if defined(__SUNPRO_C) -+#include -+#define atomic_cmpset_int(p, c, n) ((c == atomic_cas_uint(p, c, n)) ? 1 : 0) -+#define DRM_CAS(lock,old,new,__ret) \ -+ do { \ -+ unsigned int __result, __old = (old);\ -+ __result = !atomic_cmpset_int(lock,__old,new);\ -+ __ret = __result; \ -+ } while(0) -+#endif -+ - #ifndef DRM_CAS - #define DRM_CAS(lock,old,new,ret) do { ret=1; } while (0) /* FAST LOCK FAILS */ +--- libdrm-2.4.109/xf86drm.h.orig 2021-11-25 21:33:02.000000000 +0000 ++++ libdrm-2.4.109/xf86drm.h 2021-12-28 20:04:43.046788925 +0000 +@@ -959,6 +959,14 @@ + (((modifier) >> 56) & 0xff) #endif -@@ -844,6 +855,14 @@ - extern int drmGetDevice2(int fd, uint32_t flags, drmDevicePtr *device); - extern int drmGetDevices2(uint32_t flags, drmDevicePtr devices[], int max_devices); +#ifdef __sun +extern int _sun_drm_get_major(void); diff --git a/usr/src/common/libdrm/patches/xf86drmMode-c.patch b/usr/src/common/libdrm/patches/xf86drmMode-c.patch deleted file mode 100644 index 7d340581..00000000 --- a/usr/src/common/libdrm/patches/xf86drmMode-c.patch +++ /dev/null @@ -1,15 +0,0 @@ -diff --git a/xf86drmMode.c b/xf86drmMode.c -index c809c44..715f23a 100644 ---- libdrm-2.4.64/xf86drmMode.c.~1~ 2015-09-14 10:33:51.340507095 +0300 -+++ libdrm-2.4.64/xf86drmMode.c 2015-09-14 10:36:09.881744836 +0300 -@@ -850,7 +850,9 @@ - drmClose(fd); - return 0; - #endif -- return -ENOSYS; -+ -+/* for now return 0 on solaris */ -+ return 0; - } - - int drmModeCrtcGetGamma(int fd, uint32_t crtc_id, uint32_t size, diff --git a/usr/src/lib/Makefile b/usr/src/lib/Makefile index d765c31e..47094799 100644 --- a/usr/src/lib/Makefile +++ b/usr/src/lib/Makefile @@ -53,10 +53,12 @@ i386_SUBDIRS= \ libdrm_intel \ libdrm_amdgpu \ libdrm_exynos \ + libdrm_etnaviv \ libdrm_freedreno \ libdrm_omap \ libdrm_radeon \ - libdrm_tegra + libdrm_tegra \ + libdrm_nouveau sparc_SUBDIRS= diff --git a/usr/src/lib/libdrm/Makefile.com b/usr/src/lib/libdrm/Makefile.com index 708e32f8..0c8fb1a2 100644 --- a/usr/src/lib/libdrm/Makefile.com +++ b/usr/src/lib/libdrm/Makefile.com @@ -43,7 +43,8 @@ MAPFILES= SRCDIR = $(LIBDRM_CMN_DIR) SRCS = $(OBJECTS:%.o=$(SRCDIR)/%.c) -CPPFLAGS += -I$(LIBDRM_CMN_DIR) +CPPFLAGS += -I$(LIBDRM_CMN_DIR) \ + -I../common # CFLAGS += $(CCVERBOSE) LDLIBS += -lm -ldevinfo -lc diff --git a/usr/src/lib/libdrm/common/generated_static_table_fourcc.h b/usr/src/lib/libdrm/common/generated_static_table_fourcc.h new file mode 100644 index 00000000..a8d014d0 --- /dev/null +++ b/usr/src/lib/libdrm/common/generated_static_table_fourcc.h @@ -0,0 +1,49 @@ +/* AUTOMATICALLY GENERATED by gen_table_fourcc.py. You should modify + that script instead of adding here entries manually! */ +static const struct drmFormatModifierInfo drm_format_modifier_table[] = { + { DRM_MODIFIER_INVALID(NONE, INVALID_MODIFIER) }, + { DRM_MODIFIER_LINEAR(NONE, LINEAR) }, + { DRM_MODIFIER_INTEL(X_TILED, X_TILED) }, + { DRM_MODIFIER_INTEL(Y_TILED, Y_TILED) }, + { DRM_MODIFIER_INTEL(Yf_TILED, Yf_TILED) }, + { DRM_MODIFIER_INTEL(Y_TILED_CCS, Y_TILED_CCS) }, + { DRM_MODIFIER_INTEL(Yf_TILED_CCS, Yf_TILED_CCS) }, + { DRM_MODIFIER_INTEL(Y_TILED_GEN12_RC_CCS, Y_TILED_GEN12_RC_CCS) }, + { DRM_MODIFIER_INTEL(Y_TILED_GEN12_MC_CCS, Y_TILED_GEN12_MC_CCS) }, + { DRM_MODIFIER_INTEL(Y_TILED_GEN12_RC_CCS_CC, Y_TILED_GEN12_RC_CCS_CC) }, + { DRM_MODIFIER(SAMSUNG, 64_32_TILE, 64_32_TILE) }, + { DRM_MODIFIER(SAMSUNG, 16_16_TILE, 16_16_TILE) }, + { DRM_MODIFIER(QCOM, COMPRESSED, COMPRESSED) }, + { DRM_MODIFIER(VIVANTE, TILED, TILED) }, + { DRM_MODIFIER(VIVANTE, SUPER_TILED, SUPER_TILED) }, + { DRM_MODIFIER(VIVANTE, SPLIT_TILED, SPLIT_TILED) }, + { DRM_MODIFIER(VIVANTE, SPLIT_SUPER_TILED, SPLIT_SUPER_TILED) }, + { DRM_MODIFIER(NVIDIA, TEGRA_TILED, TEGRA_TILED) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_ONE_GOB, 16BX2_BLOCK_ONE_GOB) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_TWO_GOB, 16BX2_BLOCK_TWO_GOB) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_FOUR_GOB, 16BX2_BLOCK_FOUR_GOB) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_EIGHT_GOB, 16BX2_BLOCK_EIGHT_GOB) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_SIXTEEN_GOB, 16BX2_BLOCK_SIXTEEN_GOB) }, + { DRM_MODIFIER(NVIDIA, 16BX2_BLOCK_THIRTYTWO_GOB, 16BX2_BLOCK_THIRTYTWO_GOB) }, + { DRM_MODIFIER(BROADCOM, VC4_T_TILED, VC4_T_TILED) }, + { DRM_MODIFIER(BROADCOM, SAND32, SAND32) }, + { DRM_MODIFIER(BROADCOM, SAND64, SAND64) }, + { DRM_MODIFIER(BROADCOM, SAND128, SAND128) }, + { DRM_MODIFIER(BROADCOM, SAND256, SAND256) }, + { DRM_MODIFIER(BROADCOM, UIF, UIF) }, + { DRM_MODIFIER(ARM, 16X16_BLOCK_U_INTERLEAVED, 16X16_BLOCK_U_INTERLEAVED) }, + { DRM_MODIFIER(ALLWINNER, TILED, TILED) }, +}; +static const struct drmFormatModifierVendorInfo drm_format_modifier_vendor_table[] = { + { DRM_FORMAT_MOD_VENDOR_NONE, "NONE" }, + { DRM_FORMAT_MOD_VENDOR_INTEL, "INTEL" }, + { DRM_FORMAT_MOD_VENDOR_AMD, "AMD" }, + { DRM_FORMAT_MOD_VENDOR_NVIDIA, "NVIDIA" }, + { DRM_FORMAT_MOD_VENDOR_SAMSUNG, "SAMSUNG" }, + { DRM_FORMAT_MOD_VENDOR_QCOM, "QCOM" }, + { DRM_FORMAT_MOD_VENDOR_VIVANTE, "VIVANTE" }, + { DRM_FORMAT_MOD_VENDOR_BROADCOM, "BROADCOM" }, + { DRM_FORMAT_MOD_VENDOR_ARM, "ARM" }, + { DRM_FORMAT_MOD_VENDOR_ALLWINNER, "ALLWINNER" }, + { DRM_FORMAT_MOD_VENDOR_AMLOGIC, "AMLOGIC" }, +}; diff --git a/usr/src/lib/libdrm_amdgpu/Makefile.com b/usr/src/lib/libdrm_amdgpu/Makefile.com index 5d6ee0e2..45f7f614 100644 --- a/usr/src/lib/libdrm_amdgpu/Makefile.com +++ b/usr/src/lib/libdrm_amdgpu/Makefile.com @@ -30,9 +30,8 @@ VERS= .1 # See common/libdrm/libdrm-*/amdgpu/Makefile.in am__objects OBJECTS= \ - amdgpu_bo.o amdgpu_cs.o amdgpu_device.o \ - amdgpu_gpu_info.o amdgpu_vamgr.o util_hash.o \ - util_hash_table.o + amdgpu_asic_id.o amdgpu_bo.o amdgpu_cs.o amdgpu_device.o \ + amdgpu_gpu_info.o amdgpu_vamgr.o amdgpu_vm.o handle_table.o include ../../Makefile.lib include $(SRC)/common/libdrm/Makefile.drm @@ -44,7 +43,7 @@ MAPFILES= SRCDIR = $(LIBDRM_CMN_DIR)/amdgpu SRCS = $(OBJECTS:%.o=$(SRCDIR)/%.c) -CPPFLAGS += -I$(LIBDRM_CMN_DIR) +CPPFLAGS += -I$(LIBDRM_CMN_DIR) -DAMDGPU_ASIC_ID_TABLE=\"/usr/share/libdrm/amdgpu.ids\" CPPFLAGS += -I$(LIBDRM_CMN_DIR)/amdgpu LDLIBS32 += -L$(ROOT)/usr/lib/xorg diff --git a/usr/src/lib/libdrm_etnaviv/Makefile b/usr/src/lib/libdrm_etnaviv/Makefile new file mode 100644 index 00000000..8a03d937 --- /dev/null +++ b/usr/src/lib/libdrm_etnaviv/Makefile @@ -0,0 +1,74 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# +# +# Copyright 2006 Sun Microsystems, Inc. All rights reserved. +# Use is subject to license terms. +# +# Copyright 2022 Klaus Ziegler +# + +# include library definitions +include ../Makefile.lib + +include $(SRC)/common/libdrm/Makefile.drm + +SUBDIRS = $(MACH) +$(BUILD64)SUBDIRS += $(MACH64) + +all := TARGET= all +clean := TARGET= clean +clobber := TARGET= clobber +install := TARGET= install +lint := TARGET= lint + +ROOTHDRDIR= $(ROOT)/usr/include/drm + +HDRS= etnaviv_drm.h etnaviv_priv.h etnaviv_drmif.h + +.KEEP_STATE: + +install: all .WAIT $(SUBDIRS) + +all clean clobber lint: $(SUBDIRS) + +install_h: $(ROOTHDRS) + +# need to make ROOTHDRDIR +$(ROOTHDRS) : $(ROOTHDRDIR) +$(ROOTHDRDIR) : + $(INS.dir) $@ + +check: $(CHECKHDRS) + +_msg: # no msgfiles here + +$(POFILE): pofile_MSGFILES + +# install rule for install_h target +$(ROOTHDRDIR)/%: $(LIBDRM_CMN_DIR)/etnaviv/% + $(INS.file) + +$(SUBDIRS): FRC + @cd $@; pwd; $(MAKE) $(TARGET) + +FRC: + +include ../Makefile.targ diff --git a/usr/src/lib/libdrm_etnaviv/Makefile.com b/usr/src/lib/libdrm_etnaviv/Makefile.com new file mode 100644 index 00000000..61e896bf --- /dev/null +++ b/usr/src/lib/libdrm_etnaviv/Makefile.com @@ -0,0 +1,59 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# +# +# Copyright 2008 Sun Microsystems, Inc. All rights reserved. +# Use is subject to license terms. +# +# Copyright 2022 Klaus Ziegler +# + +LIBRARY= libdrm_etnaviv.a +VERS= .1 + +OBJECTS= etnaviv_bo_cache.o etnaviv_bo.o etnaviv_cmd_stream.o \ + etnaviv_device.o etnaviv_gpu.o etnaviv_perfmon.o etnaviv_pipe.o + +include ../../Makefile.lib +include $(SRC)/common/libdrm/Makefile.drm + +LIBS = $(DYNLIB) +PCS = $(LIBRARY:.a=.pc) + +MAPFILES= +SRCDIR = $(LIBDRM_CMN_DIR)/etnaviv +SRCS = $(OBJECTS:%.o=$(SRCDIR)/%.c) + +CPPFLAGS += -I$(LIBDRM_CMN_DIR) +CPPFLAGS += -I$(LIBDRM_CMN_DIR)/etnaviv + +LDLIBS32 += -L$(ROOT)/usr/lib/xorg +LDLIBS64 += -L$(ROOT)/usr/lib/xorg/$(MACH64) + +LDLIBS += -lpciaccess -ldrm -lc + +all : $(LIBS) $(PCS) + +lint : + +include ../../libdrm/Makefile.pc +include ../../Makefile.targ + +.KEEP_STATE: diff --git a/usr/src/lib/libdrm_etnaviv/amd64/Makefile b/usr/src/lib/libdrm_etnaviv/amd64/Makefile new file mode 100644 index 00000000..894077fe --- /dev/null +++ b/usr/src/lib/libdrm_etnaviv/amd64/Makefile @@ -0,0 +1,21 @@ +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2022 Klaus Ziegler +# + +include ../Makefile.com +include ../../Makefile.lib.64 + +DYNFLAGS += -R/usr/lib/xorg/$(MACH64) + +install: all $(ROOTLIBS64) $(ROOTLINKS64) $(ROOTPCS64) diff --git a/usr/src/lib/libdrm_etnaviv/i386/Makefile b/usr/src/lib/libdrm_etnaviv/i386/Makefile new file mode 100644 index 00000000..c0642d56 --- /dev/null +++ b/usr/src/lib/libdrm_etnaviv/i386/Makefile @@ -0,0 +1,20 @@ +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2022 Klaus Ziegler +# + +include ../Makefile.com + +DYNFLAGS += -R/usr/lib/xorg + +install: all $(ROOTLIBS) $(ROOTLINKS) $(ROOTPCS) diff --git a/usr/src/lib/libdrm_intel/Makefile.com b/usr/src/lib/libdrm_intel/Makefile.com index e78a23cb..e6872bef 100644 --- a/usr/src/lib/libdrm_intel/Makefile.com +++ b/usr/src/lib/libdrm_intel/Makefile.com @@ -31,7 +31,7 @@ VERS= .1 # See common/libdrm/libdrm-*/intel/Makefile.in am_libdrm_intel_la_OBJECTS OBJECTS= \ intel_bufmgr.o intel_bufmgr_fake.o \ - intel_bufmgr_gem.o intel_decode.o mm.o + intel_bufmgr_gem.o intel_decode.o mm.o intel_chipset.o include ../../Makefile.lib include $(SRC)/common/libdrm/Makefile.drm diff --git a/usr/src/lib/libdrm_nouveau/Makefile b/usr/src/lib/libdrm_nouveau/Makefile new file mode 100644 index 00000000..571c1640 --- /dev/null +++ b/usr/src/lib/libdrm_nouveau/Makefile @@ -0,0 +1,74 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# +# +# Copyright 2006 Sun Microsystems, Inc. All rights reserved. +# Use is subject to license terms. +# +# Copyright 2022 Klaus Ziegler +# + +# include library definitions +include ../Makefile.lib + +include $(SRC)/common/libdrm/Makefile.drm + +SUBDIRS = $(MACH) +$(BUILD64)SUBDIRS += $(MACH64) + +all := TARGET= all +clean := TARGET= clean +clobber := TARGET= clobber +install := TARGET= install +lint := TARGET= lint + +ROOTHDRDIR= $(ROOT)/usr/include/drm + +HDRS= nouveau.h + +.KEEP_STATE: + +install: all .WAIT $(SUBDIRS) + +all clean clobber lint: $(SUBDIRS) + +install_h: $(ROOTHDRS) + +# need to make ROOTHDRDIR +$(ROOTHDRS) : $(ROOTHDRDIR) +$(ROOTHDRDIR) : + $(INS.dir) $@ + +check: $(CHECKHDRS) + +_msg: # no msgfiles here + +$(POFILE): pofile_MSGFILES + +# install rule for install_h target +$(ROOTHDRDIR)/%: $(LIBDRM_CMN_DIR)/nouveau/% + $(INS.file) + +$(SUBDIRS): FRC + @cd $@; pwd; $(MAKE) $(TARGET) + +FRC: + +include ../Makefile.targ diff --git a/usr/src/lib/libdrm_nouveau/Makefile.com b/usr/src/lib/libdrm_nouveau/Makefile.com new file mode 100644 index 00000000..c119678c --- /dev/null +++ b/usr/src/lib/libdrm_nouveau/Makefile.com @@ -0,0 +1,58 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# +# +# Copyright 2008 Sun Microsystems, Inc. All rights reserved. +# Use is subject to license terms. +# +# Copyright 2021 Klaus Ziegler +# + +LIBRARY= libdrm_nouveau.a +VERS= .1 + +OBJECTS= nouveau.o pushbuf.o bufctx.o abi16.o + +include ../../Makefile.lib +include $(SRC)/common/libdrm/Makefile.drm + +LIBS = $(DYNLIB) +PCS = $(LIBRARY:.a=.pc) + +MAPFILES= +SRCDIR = $(LIBDRM_CMN_DIR)/nouveau +SRCS = $(OBJECTS:%.o=$(SRCDIR)/%.c) + +CPPFLAGS += -I$(LIBDRM_CMN_DIR) +CPPFLAGS += -I$(LIBDRM_CMN_DIR)/nouveau + +LDLIBS32 += -L$(ROOT)/usr/lib/xorg +LDLIBS64 += -L$(ROOT)/usr/lib/xorg/$(MACH64) + +LDLIBS += -lpciaccess -ldrm -lc + +all : $(LIBS) $(PCS) + +lint : + +include ../../libdrm/Makefile.pc +include ../../Makefile.targ + +.KEEP_STATE: diff --git a/usr/src/lib/libdrm_nouveau/amd64/Makefile b/usr/src/lib/libdrm_nouveau/amd64/Makefile new file mode 100644 index 00000000..894077fe --- /dev/null +++ b/usr/src/lib/libdrm_nouveau/amd64/Makefile @@ -0,0 +1,21 @@ +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2022 Klaus Ziegler +# + +include ../Makefile.com +include ../../Makefile.lib.64 + +DYNFLAGS += -R/usr/lib/xorg/$(MACH64) + +install: all $(ROOTLIBS64) $(ROOTLINKS64) $(ROOTPCS64) diff --git a/usr/src/lib/libdrm_nouveau/i386/Makefile b/usr/src/lib/libdrm_nouveau/i386/Makefile new file mode 100644 index 00000000..c0642d56 --- /dev/null +++ b/usr/src/lib/libdrm_nouveau/i386/Makefile @@ -0,0 +1,20 @@ +# +# This file and its contents are supplied under the terms of the +# Common Development and Distribution License ("CDDL"), version 1.0. +# You may only use this file in accordance with the terms of version +# 1.0 of the CDDL. +# +# A full copy of the text of the CDDL should have accompanied this +# source. A copy of the CDDL is also available via the Internet at +# http://www.illumos.org/license/CDDL. +# + +# +# Copyright 2022 Klaus Ziegler +# + +include ../Makefile.com + +DYNFLAGS += -R/usr/lib/xorg + +install: all $(ROOTLIBS) $(ROOTLINKS) $(ROOTPCS) diff --git a/usr/src/man/Makefile b/usr/src/man/Makefile index 74517d31..7f16b32d 100644 --- a/usr/src/man/Makefile +++ b/usr/src/man/Makefile @@ -14,9 +14,7 @@ # SUBDIRS= man1 \ - man3 \ man3x \ - man7 \ man7d \ man7i diff --git a/usr/src/pkg/Makefile b/usr/src/pkg/Makefile index e49f1253..47fd7237 100644 --- a/usr/src/pkg/Makefile +++ b/usr/src/pkg/Makefile @@ -488,7 +488,7 @@ $(REPOS:%=$(PKGDEST)/repo.%): $(PDIR)/%.mog: manifests/%.mf @print "Processing manifest $( set name=pkg.fmri value=pkg:/driver/graphics/agpgart@$(PKGVERS) -set name=pkg.description value="AGP GART driver for x86 workstations" set name=pkg.summary value="AGP GART Driver" -set name=info.classification \ - value=org.opensolaris.category.2008:Drivers/Display +set name=pkg.description value="AGP GART driver for x86 workstations" +set name=info.classification value=org.opensolaris.category.2008:Drivers/Display set name=org.opensolaris.noincorp value=true set name=variant.arch value=i386 -dir path=kernel group=sys -dir path=kernel/drv group=sys -dir path=kernel/drv/$(ARCH64) group=sys -dir path=kernel/misc group=sys -dir path=kernel/misc/$(ARCH64) group=sys -dir path=usr/share/man -dir path=usr/share/man/man7i +dir path=kernel group=sys +dir path=kernel/drv group=sys +dir path=kernel/drv/$(ARCH64) group=sys +file path=kernel/drv/$(ARCH64)/$(ARCH64)_gart group=sys mode=0755 +file path=kernel/drv/$(ARCH64)/agpgart group=sys mode=0755 +file path=kernel/drv/$(ARCH64)/agptarget group=sys mode=0755 +file path=kernel/drv/agpgart.conf group=sys mode=0644 +dir path=kernel/misc group=sys +dir path=kernel/misc/$(ARCH64) group=sys +file path=kernel/misc/$(ARCH64)/agpmaster group=sys mode=0755 +dir path=usr/share/man +dir path=usr/share/man/man7i +file path=usr/share/man/man7i/agpgart_io.7i driver name=agpgart perms="* 0644 root sys" # Note: The authoritative list of PCI IDs for this driver is # the array gsm_modes[] in agptarget.c (INTEL_BR_810 etc.). @@ -50,6 +55,10 @@ driver name=agpgart perms="* 0644 root sys" # so no need to add any PCI IDs here for those devices. driver name=agptarget perms="* 0644 root sys" \ alias=pci1022,7454 \ + alias=pci8086,40 \ + alias=pci8086,44 \ + alias=pci8086,62 \ + alias=pci8086,6a \ alias=pci8086,1130 \ alias=pci8086,2560 \ alias=pci8086,2570 \ @@ -76,21 +85,11 @@ driver name=agptarget perms="* 0644 root sys" \ alias=pci8086,3340 \ alias=pci8086,3575 \ alias=pci8086,3580 \ - alias=pci8086,40 \ - alias=pci8086,44 \ - alias=pci8086,62 \ - alias=pci8086,6a \ alias=pci8086,7120 \ alias=pci8086,7122 \ alias=pci8086,7124 # Note: the name of this driver _really_is_ amd64_gart... -driver name=amd64_gart alias=pci1022,1103 perms="* 0644 root sys" -file path=kernel/drv/$(ARCH64)/$(ARCH64)_gart group=sys mode=0755 -file path=kernel/drv/$(ARCH64)/agpgart group=sys mode=0755 -file path=kernel/drv/$(ARCH64)/agptarget group=sys mode=0755 -file path=kernel/drv/agpgart.conf group=sys mode=0644 -file path=kernel/misc/$(ARCH64)/agpmaster group=sys mode=0755 -file path=usr/share/man/man7i/agpgart_io.7i +driver name=amd64_gart perms="* 0644 root sys" alias=pci1022,1103 legacy pkg=SUNWagp desc="AGP GART driver for x86 workstations" \ name="AGP GART Driver" license cr_Sun license=cr_Sun diff --git a/usr/src/pkg/manifests/driver-graphics-drm.mf b/usr/src/pkg/manifests/driver-graphics-drm.mf index b10812ce..cba39db9 100644 --- a/usr/src/pkg/manifests/driver-graphics-drm.mf +++ b/usr/src/pkg/manifests/driver-graphics-drm.mf @@ -29,35 +29,43 @@ # set name=pkg.fmri value=pkg:/driver/graphics/drm@$(PKGVERS) +set name=pkg.summary value="DRM Kernel Drivers" set name=pkg.description \ value="Direct Rendering Manager kernel drivers and modules" -set name=pkg.summary value="DRM Kernel Drivers" -set name=info.classification \ - value=org.opensolaris.category.2008:Drivers/Display +set name=info.classification value=org.opensolaris.category.2008:Drivers/Display set name=info.upstream value="Direct Rendering Infrastructure (DRI) project" set name=info.upstream-url value=http://dri.freedesktop.org/ set name=org.opensolaris.noincorp value=true set name=variant.arch value=i386 -dir path=kernel group=sys -dir path=kernel/drv group=sys -dir path=kernel/drv/$(ARCH64) group=sys -dir path=kernel/kmdb group=sys -dir path=kernel/kmdb/$(ARCH64) group=sys -dir path=kernel/misc group=sys -dir path=kernel/misc/$(ARCH64) group=sys -dir path=usr/lib -dir path=usr/lib/devfsadm group=sys -dir path=usr/lib/devfsadm/linkmod group=sys -dir path=usr/lib/mdb group=sys -dir path=usr/lib/mdb/kvm group=sys -dir path=usr/lib/mdb/kvm/$(ARCH64) group=sys -dir path=usr/share -dir path=usr/share/man -dir path=usr/share/man/man7d +dir path=kernel group=sys +dir path=kernel/drv group=sys +dir path=kernel/drv/$(ARCH64) group=sys +file path=kernel/drv/$(ARCH64)/i915 group=sys mode=0755 +dir path=kernel/kmdb group=sys +dir path=kernel/kmdb/$(ARCH64) group=sys +#file path=kernel/drv/$(ARCH64)/radeon group=sys mode=0755 +file path=kernel/kmdb/$(ARCH64)/i915 group=sys mode=0555 +dir path=kernel/misc group=sys +dir path=kernel/misc/$(ARCH64) group=sys +file path=kernel/misc/$(ARCH64)/drm group=sys mode=0755 +dir path=usr/lib +dir path=usr/lib/devfsadm group=sys +dir path=usr/lib/devfsadm/linkmod group=sys +file path=usr/lib/devfsadm/linkmod/SUNW_drm_link_i386.so group=sys mode=0755 +dir path=usr/lib/mdb group=sys +dir path=usr/lib/mdb/kvm group=sys +dir path=usr/lib/mdb/kvm/$(ARCH64) group=sys +file path=usr/lib/mdb/kvm/$(ARCH64)/i915.so group=sys mode=0555 +dir path=usr/share +dir path=usr/share/man +dir path=usr/share/man/man7d +file path=usr/share/man/man7d/i915.7d # Note: The authoritative list of supported PCI IDs supported by # the i915 driver is in: i915_drv.c:pciidlist[] # This list was generated by: uts/intel/io/i915/Make-PCI-ID-list.awk driver name=i915 perms="* 0644 root sys" \ + alias=pci8086,42 \ + alias=pci8086,46 \ alias=pci8086,102 \ alias=pci8086,106 \ alias=pci8086,10a \ @@ -73,33 +81,6 @@ driver name=i915 perms="* 0644 root sys" \ alias=pci8086,162 \ alias=pci8086,166 \ alias=pci8086,16a \ - alias=pci8086,2562 \ - alias=pci8086,2572 \ - alias=pci8086,2582 \ - alias=pci8086,258a \ - alias=pci8086,2592 \ - alias=pci8086,2772 \ - alias=pci8086,27a2 \ - alias=pci8086,27ae \ - alias=pci8086,2972 \ - alias=pci8086,2982 \ - alias=pci8086,2992 \ - alias=pci8086,29a2 \ - alias=pci8086,29b2 \ - alias=pci8086,29c2 \ - alias=pci8086,29d2 \ - alias=pci8086,2a02 \ - alias=pci8086,2a12 \ - alias=pci8086,2a42 \ - alias=pci8086,2e02 \ - alias=pci8086,2e12 \ - alias=pci8086,2e22 \ - alias=pci8086,2e32 \ - alias=pci8086,2e42 \ - alias=pci8086,2e92 \ - alias=pci8086,3577 \ - alias=pci8086,3582 \ - alias=pci8086,358e \ alias=pci8086,402 \ alias=pci8086,406 \ alias=pci8086,40a \ @@ -110,15 +91,11 @@ driver name=i915 perms="* 0644 root sys" \ alias=pci8086,41a \ alias=pci8086,41b \ alias=pci8086,41e \ - alias=pci8086,42 \ alias=pci8086,422 \ alias=pci8086,426 \ alias=pci8086,42a \ alias=pci8086,42b \ alias=pci8086,42e \ - alias=pci8086,46 \ - alias=pci8086,a001 \ - alias=pci8086,a011 \ alias=pci8086,a02 \ alias=pci8086,a06 \ alias=pci8086,a0a \ @@ -167,14 +144,36 @@ driver name=i915 perms="* 0644 root sys" \ alias=pci8086,f30 \ alias=pci8086,f31 \ alias=pci8086,f32 \ - alias=pci8086,f33 -file path=kernel/drv/$(ARCH64)/i915 group=sys mode=0755 -#file path=kernel/drv/$(ARCH64)/radeon group=sys mode=0755 -file path=kernel/kmdb/$(ARCH64)/i915 group=sys mode=0555 -file path=kernel/misc/$(ARCH64)/drm group=sys mode=0755 -file path=usr/lib/devfsadm/linkmod/SUNW_drm_link_i386.so group=sys mode=0755 -file path=usr/lib/mdb/kvm/$(ARCH64)/i915.so group=sys mode=0555 -file path=usr/share/man/man7d/i915.7d + alias=pci8086,f33 \ + alias=pci8086,2562 \ + alias=pci8086,2572 \ + alias=pci8086,2582 \ + alias=pci8086,258a \ + alias=pci8086,2592 \ + alias=pci8086,2772 \ + alias=pci8086,27a2 \ + alias=pci8086,27ae \ + alias=pci8086,2972 \ + alias=pci8086,2982 \ + alias=pci8086,2992 \ + alias=pci8086,29a2 \ + alias=pci8086,29b2 \ + alias=pci8086,29c2 \ + alias=pci8086,29d2 \ + alias=pci8086,2a02 \ + alias=pci8086,2a12 \ + alias=pci8086,2a42 \ + alias=pci8086,2e02 \ + alias=pci8086,2e12 \ + alias=pci8086,2e22 \ + alias=pci8086,2e32 \ + alias=pci8086,2e42 \ + alias=pci8086,2e92 \ + alias=pci8086,3577 \ + alias=pci8086,3582 \ + alias=pci8086,358e \ + alias=pci8086,a001 \ + alias=pci8086,a011 #file path=usr/share/man/man7d/radeon.7d legacy pkg=SUNWdrmr desc="Direct Rendering Manager kernel drivers and modules" \ name="DRM Kernel Drivers, (Root)" @@ -182,4 +181,4 @@ license usr/src/uts/common/io/drm/LICENSE_DRM \ license=usr/src/uts/common/io/drm/LICENSE_DRM license usr/src/uts/intel/io/i915/LICENSE_I915 \ license=usr/src/uts/intel/io/i915/LICENSE_I915 -depend fmri=pkg:/driver/graphics/agpgart type=require +depend type=require fmri=pkg:/driver/graphics/agpgart diff --git a/usr/src/pkg/manifests/system-header-header-agp.mf b/usr/src/pkg/manifests/system-header-header-agp.mf index bfc6bbd8..4367e0d0 100644 --- a/usr/src/pkg/manifests/system-header-header-agp.mf +++ b/usr/src/pkg/manifests/system-header-header-agp.mf @@ -24,15 +24,15 @@ # set name=pkg.fmri value=pkg:/system/header/header-agp@$(PKGVERS) -set name=pkg.description value="AGP GART Header Files for x86 Workstations" set name=pkg.summary value="AGP GART Driver Header Files" +set name=pkg.description value="AGP GART Header Files for x86 Workstations" set name=info.classification \ value=org.opensolaris.category.2008:Development/System set name=variant.arch value=i386 -dir path=usr group=sys -dir path=usr/include -dir path=usr/include/sys -dir path=usr/include/sys/agp +dir path=usr group=sys +dir path=usr/include +dir path=usr/include/sys +dir path=usr/include/sys/agp file path=usr/include/sys/agp/agp$(ARCH64)gart_io.h file path=usr/include/sys/agp/agpdefs.h file path=usr/include/sys/agp/agpgart_impl.h diff --git a/usr/src/pkg/manifests/system-header-header-drm.mf b/usr/src/pkg/manifests/system-header-header-drm.mf index 628c3c76..1580d499 100644 --- a/usr/src/pkg/manifests/system-header-header-drm.mf +++ b/usr/src/pkg/manifests/system-header-header-drm.mf @@ -24,14 +24,14 @@ # set name=pkg.fmri value=pkg:/system/header/header-drm@$(PKGVERS) -set name=pkg.description value="DRM Driver Header Files for x86 Workstations" set name=pkg.summary value="DRM Driver Header Files" +set name=pkg.description value="DRM Driver Header Files for x86 Workstations" set name=info.classification \ value=org.opensolaris.category.2008:Development/System set name=variant.arch value=i386 -dir path=usr group=sys -dir path=usr/include -dir path=usr/include/drm +dir path=usr group=sys +dir path=usr/include +dir path=usr/include/drm file path=usr/include/drm/drm.h file path=usr/include/drm/drm_fourcc.h file path=usr/include/drm/drm_mode.h diff --git a/usr/src/pkg/manifests/system-test-libdrm.mf b/usr/src/pkg/manifests/system-test-libdrm.mf index 2d01a073..09fb0eaf 100644 --- a/usr/src/pkg/manifests/system-test-libdrm.mf +++ b/usr/src/pkg/manifests/system-test-libdrm.mf @@ -15,13 +15,13 @@ default mode 0555> set name=pkg.fmri value=pkg:/system/test/libdrm@$(PKGVERS) -set name=pkg.description value="DRM Library Unit Tests" set name=pkg.summary value="DRM Library Unit Test Suite" +set name=pkg.description value="DRM Library Unit Tests" set name=info.classification \ value=org.opensolaris.category.2008:Development/System set name=variant.arch value=$(ARCH) -dir path=opt/drm-tests -dir path=opt/drm-tests/$(ARCH64) +dir path=opt/drm-tests +dir path=opt/drm-tests/$(ARCH64) file path=opt/drm-tests/$(ARCH64)/drmdevice file path=opt/drm-tests/$(ARCH64)/drmsl file path=opt/drm-tests/$(ARCH64)/exynos_fimg2d_event @@ -36,7 +36,6 @@ file path=opt/drm-tests/$(ARCH64)/modeprint file path=opt/drm-tests/$(ARCH64)/modetest file path=opt/drm-tests/$(ARCH64)/proptest file path=opt/drm-tests/$(ARCH64)/radeon_ttm -file path=opt/drm-tests/$(ARCH64)/random file path=opt/drm-tests/$(ARCH64)/tegra_openclose file path=opt/drm-tests/$(ARCH64)/vbltest file path=opt/drm-tests/Run_all.sh @@ -54,7 +53,6 @@ file path=opt/drm-tests/modeprint file path=opt/drm-tests/modetest file path=opt/drm-tests/proptest file path=opt/drm-tests/radeon_ttm -file path=opt/drm-tests/random file path=opt/drm-tests/tegra_openclose file path=opt/drm-tests/vbltest -depend fmri=pkg:/x11/library/libdrm type=require +depend type=require fmri=pkg:/x11/library/libdrm diff --git a/usr/src/pkg/manifests/x11-library-libdrm.mf b/usr/src/pkg/manifests/x11-library-libdrm.mf index dd3a9429..0eacfaca 100644 --- a/usr/src/pkg/manifests/x11-library-libdrm.mf +++ b/usr/src/pkg/manifests/x11-library-libdrm.mf @@ -15,24 +15,16 @@ set name=pkg.fmri \ value=pkg:/x11/library/libdrm@$(LIBDRM_VERS),$(PKGVERS_BUILTON)-$(PKGVERS_BRANCH) -set name=pkg.description value="Direct Rendering Manager (DRM) Libraries" set name=pkg.summary value="DRM Libraries" +set name=pkg.description value="Direct Rendering Manager (DRM) Libraries" set name=info.classification value=System/X11 set name=info.source-url \ - value=http://dri.freedesktop.org/libdrm-$(LIBDRM_VERS).tar.bz2 + value=http://dri.freedesktop.org/libdrm-$(LIBDRM_VERS).tar.xz set name=info.upstream-url value=http://dri.freedesktop.org # -dir path=usr group=sys -dir path=usr/include -dir path=usr/include/drm -dir path=usr/include/exynos -dir path=usr/include/freedreno -dir path=usr/lib -dir path=usr/lib/$(ARCH64) -dir path=usr/lib/$(ARCH64)/pkgconfig group=other -dir path=usr/lib/pkgconfig group=other -dir path=usr/lib/xorg -dir path=usr/lib/xorg/$(ARCH64) +dir path=usr group=sys +dir path=usr/include +dir path=usr/include/drm # file path=usr/include/drm/amdgpu.h file path=usr/include/drm/amdgpu_drm.h @@ -68,75 +60,95 @@ file path=usr/include/drm/vc4_drm.h file path=usr/include/drm/via_drm.h #file path=usr/include/drm/virtgpu_drm.h file path=usr/include/drm/vmwgfx_drm.h +dir path=usr/include/exynos file path=usr/include/exynos/exynos_drm.h file path=usr/include/exynos/exynos_fimg2d.h +dir path=usr/include/freedreno file path=usr/include/freedreno/freedreno_drmif.h file path=usr/include/freedreno/freedreno_ringbuffer.h +# +link path=usr/include/libdrm target=drm file path=usr/include/libkms/libkms.h file path=usr/include/libsync.h file path=usr/include/omap/omap_drm.h file path=usr/include/xf86drm.h file path=usr/include/xf86drmMode.h +dir path=usr/lib +dir path=usr/lib/$(ARCH64) +dir path=usr/lib/$(ARCH64)/pkgconfig group=other # file path=usr/lib/$(ARCH64)/pkgconfig/libdrm.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_amdgpu.pc +file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_etnaviv.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_exynos.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_freedreno.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_intel.pc +file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_nouveau.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_omap.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_radeon.pc file path=usr/lib/$(ARCH64)/pkgconfig/libdrm_tegra.pc file path=usr/lib/$(ARCH64)/pkgconfig/libkms.pc +dir path=usr/lib/pkgconfig group=other file path=usr/lib/pkgconfig/libdrm.pc file path=usr/lib/pkgconfig/libdrm_amdgpu.pc +file path=usr/lib/pkgconfig/libdrm_etnaviv.pc file path=usr/lib/pkgconfig/libdrm_exynos.pc file path=usr/lib/pkgconfig/libdrm_freedreno.pc file path=usr/lib/pkgconfig/libdrm_intel.pc +file path=usr/lib/pkgconfig/libdrm_nouveau.pc file path=usr/lib/pkgconfig/libdrm_omap.pc file path=usr/lib/pkgconfig/libdrm_radeon.pc file path=usr/lib/pkgconfig/libdrm_tegra.pc file path=usr/lib/pkgconfig/libkms.pc +dir path=usr/lib/xorg +dir path=usr/lib/xorg/$(ARCH64) +link path=usr/lib/xorg/$(ARCH64)/libdrm.so target=libdrm.so.2 # file path=usr/lib/xorg/$(ARCH64)/libdrm.so.2 +link path=usr/lib/xorg/$(ARCH64)/libdrm_amdgpu.so target=libdrm_amdgpu.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_amdgpu.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_etnaviv.so target=libdrm_etnaviv.so.1 +file path=usr/lib/xorg/$(ARCH64)/libdrm_etnaviv.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_exynos.so target=libdrm_exynos.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_exynos.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_freedreno.so \ + target=libdrm_freedreno.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_freedreno.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_intel.so target=libdrm_intel.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_intel.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_nouveau.so target=libdrm_nouveau.so.1 +file path=usr/lib/xorg/$(ARCH64)/libdrm_nouveau.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_omap.so target=libdrm_omap.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_omap.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_radeon.so target=libdrm_radeon.so.1 file path=usr/lib/xorg/$(ARCH64)/libdrm_radeon.so.1 +link path=usr/lib/xorg/$(ARCH64)/libdrm_tegra.so target=libdrm_tegra.so.0 file path=usr/lib/xorg/$(ARCH64)/libdrm_tegra.so.0 +link path=usr/lib/xorg/$(ARCH64)/libkms.so target=libkms.so.1 file path=usr/lib/xorg/$(ARCH64)/libkms.so.1 +link path=usr/lib/xorg/libdrm.so target=libdrm.so.2 file path=usr/lib/xorg/libdrm.so.2 +link path=usr/lib/xorg/libdrm_amdgpu.so target=libdrm_amdgpu.so.1 file path=usr/lib/xorg/libdrm_amdgpu.so.1 +link path=usr/lib/xorg/libdrm_etnaviv.so target=libdrm_etnaviv.so.1 +file path=usr/lib/xorg/libdrm_etnaviv.so.1 +link path=usr/lib/xorg/libdrm_exynos.so target=libdrm_exynos.so.1 file path=usr/lib/xorg/libdrm_exynos.so.1 +link path=usr/lib/xorg/libdrm_freedreno.so target=libdrm_freedreno.so.1 file path=usr/lib/xorg/libdrm_freedreno.so.1 +link path=usr/lib/xorg/libdrm_intel.so target=libdrm_intel.so.1 file path=usr/lib/xorg/libdrm_intel.so.1 +link path=usr/lib/xorg/libdrm_nouveau.so target=libdrm_nouveau.so.1 +file path=usr/lib/xorg/libdrm_nouveau.so.1 +link path=usr/lib/xorg/libdrm_omap.so target=libdrm_omap.so.1 file path=usr/lib/xorg/libdrm_omap.so.1 +link path=usr/lib/xorg/libdrm_radeon.so target=libdrm_radeon.so.1 file path=usr/lib/xorg/libdrm_radeon.so.1 +link path=usr/lib/xorg/libdrm_tegra.so target=libdrm_tegra.so.0 file path=usr/lib/xorg/libdrm_tegra.so.0 +link path=usr/lib/xorg/libkms.so target=libkms.so.1 file path=usr/lib/xorg/libkms.so.1 # license usr/src/common/libdrm/LICENSE_LIBDRM \ license=usr/src/common/libdrm/LICENSE_LIBDRM -# -link path=usr/include/libdrm target=drm -link path=usr/lib/xorg/$(ARCH64)/libdrm.so target=libdrm.so.2 -link path=usr/lib/xorg/$(ARCH64)/libdrm_amdgpu.so target=libdrm_amdgpu.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_exynos.so target=libdrm_exynos.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_freedreno.so \ - target=libdrm_freedreno.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_intel.so target=libdrm_intel.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_omap.so target=libdrm_omap.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_radeon.so target=libdrm_radeon.so.1 -link path=usr/lib/xorg/$(ARCH64)/libdrm_tegra.so target=libdrm_tegra.so.0 -link path=usr/lib/xorg/$(ARCH64)/libkms.so target=libkms.so.1 -link path=usr/lib/xorg/libdrm.so target=libdrm.so.2 -link path=usr/lib/xorg/libdrm_amdgpu.so target=libdrm_amdgpu.so.1 -link path=usr/lib/xorg/libdrm_exynos.so target=libdrm_exynos.so.1 -link path=usr/lib/xorg/libdrm_freedreno.so target=libdrm_freedreno.so.1 -link path=usr/lib/xorg/libdrm_intel.so target=libdrm_intel.so.1 -link path=usr/lib/xorg/libdrm_omap.so target=libdrm_omap.so.1 -link path=usr/lib/xorg/libdrm_radeon.so target=libdrm_radeon.so.1 -link path=usr/lib/xorg/libdrm_tegra.so target=libdrm_tegra.so.0 -link path=usr/lib/xorg/libkms.so target=libkms.so.1 -depend fmri=pkg:/driver/graphics/drm type=require +depend type=require fmri=pkg:/driver/graphics/drm diff --git a/usr/src/tools/cw/cw.c b/usr/src/tools/cw/cw.c index 91d62075..0a6add21 100644 --- a/usr/src/tools/cw/cw.c +++ b/usr/src/tools/cw/cw.c @@ -606,17 +606,6 @@ do_gcc(cw_ictx_t *ctx) newae(ctx->i_ae, "-fdiagnostics-show-option"); newae(ctx->i_ae, "-nodefaultlibs"); -#if defined(__sparc) - /* - * The SPARC ldd and std instructions require 8-byte alignment of - * their address operand. gcc correctly uses them only when the - * ABI requires 8-byte alignment; unfortunately we have a number of - * pieces of buggy code that doesn't conform to the ABI. This - * flag makes gcc work more like Studio with -xmemalign=4. - */ - newae(ctx->i_ae, "-mno-integer-ldd-std"); -#endif - /* * This is needed because 'u' is defined * under a conditional on 'sun'. Should diff --git a/usr/src/uts/common/drm/drm.h b/usr/src/uts/common/drm/drm.h index cebbae3a..5a609274 100644 --- a/usr/src/uts/common/drm/drm.h +++ b/usr/src/uts/common/drm/drm.h @@ -1,11 +1,10 @@ -/** - * \file drm.h +/* * Header for the Direct Rendering Manager * - * \author Rickard E. (Rik) Faith + * Author: Rickard E. (Rik) Faith * - * \par Acknowledgments: - * Dec 1999, Richard Henderson , move to generic \c cmpxchg. + * Acknowledgments: + * Dec 1999, Richard Henderson , move to generic cmpxchg. */ /* @@ -44,6 +43,7 @@ typedef unsigned int drm_handle_t; #else /* One of the BSDs */ +#include #include #include typedef int8_t __s8; @@ -104,7 +104,7 @@ typedef unsigned int drm_context_t; typedef unsigned int drm_drawable_t; typedef unsigned int drm_magic_t; -/** +/* * Cliprect. * * \warning: If you change this structure, make sure you change @@ -120,7 +120,7 @@ struct drm_clip_rect { unsigned short y2; }; -/** +/* * Drawable information. */ struct drm_drawable_info { @@ -128,7 +128,7 @@ struct drm_drawable_info { struct drm_clip_rect *rects; }; -/** +/* * Texture region, */ struct drm_tex_region { @@ -139,7 +139,7 @@ struct drm_tex_region { unsigned int age; }; -/** +/* * Hardware lock. * * The lock structure is a simple cache-line aligned integer. To avoid @@ -151,7 +151,7 @@ struct drm_hw_lock { char padding[60]; /**< Pad to cache line */ }; -/** +/* * DRM_IOCTL_VERSION ioctl argument type. * * \sa drmGetVersion(). @@ -168,7 +168,7 @@ struct drm_version { char *desc; /**< User-space buffer to hold desc */ }; -/** +/* * DRM_IOCTL_GET_UNIQUE ioctl argument type. * * \sa drmGetBusid() and drmSetBusId(). @@ -187,7 +187,7 @@ struct drm_block { int unused; }; -/** +/* * DRM_IOCTL_CONTROL ioctl argument type. * * \sa drmCtlInstHandler() and drmCtlUninstHandler(). @@ -202,7 +202,7 @@ struct drm_control { int irq; }; -/** +/* * Type of memory to map. */ enum drm_map_type { @@ -215,7 +215,7 @@ enum drm_map_type { _DRM_GEM = 6 /**< GEM object (XXX: Not libdrm?) */ }; -/** +/* * Memory mapping flags. */ enum drm_map_flags { @@ -234,7 +234,7 @@ struct drm_ctx_priv_map { void *handle; /**< Handle of map */ }; -/** +/* * DRM_IOCTL_GET_MAP, DRM_IOCTL_ADD_MAP and DRM_IOCTL_RM_MAP ioctls * argument type. * @@ -252,7 +252,7 @@ struct drm_map { /* Private data */ }; -/** +/* * DRM_IOCTL_GET_CLIENT ioctl argument type. */ struct drm_client { @@ -284,7 +284,7 @@ enum drm_stat_type { /* Add to the *END* of the list */ }; -/** +/* * DRM_IOCTL_GET_STATS ioctl argument type. */ struct drm_stats { @@ -295,7 +295,7 @@ struct drm_stats { } data[15]; }; -/** +/* * Hardware locking flags. */ enum drm_lock_flags { @@ -310,7 +310,7 @@ enum drm_lock_flags { _DRM_HALT_CUR_QUEUES = 0x20 /**< Halt all current queues */ }; -/** +/* * DRM_IOCTL_LOCK, DRM_IOCTL_UNLOCK and DRM_IOCTL_FINISH ioctl argument type. * * \sa drmGetLock() and drmUnlock(). @@ -320,7 +320,7 @@ struct drm_lock { enum drm_lock_flags flags; }; -/** +/* * DMA flags * * \warning @@ -349,7 +349,7 @@ enum drm_dma_flags { _DRM_DMA_LARGER_OK = 0x40 /**< Larger-than-requested buffers OK */ }; -/** +/* * DRM_IOCTL_ADD_BUFS and DRM_IOCTL_MARK_BUFS ioctl argument type. * * \sa drmAddBufs(). @@ -376,7 +376,7 @@ struct drm_buf_desc { */ }; -/** +/* * DRM_IOCTL_INFO_BUFS ioctl argument type. */ struct drm_buf_info { @@ -384,7 +384,7 @@ struct drm_buf_info { struct drm_buf_desc *list; }; -/** +/* * DRM_IOCTL_FREE_BUFS ioctl argument type. */ struct drm_buf_free { @@ -392,7 +392,7 @@ struct drm_buf_free { int *list; }; -/** +/* * Buffer information * * \sa drm_buf_map. @@ -404,7 +404,7 @@ struct drm_buf_pub { void *address; /**< Address of buffer */ }; -/** +/* * DRM_IOCTL_MAP_BUFS ioctl argument type. */ struct drm_buf_map { @@ -418,7 +418,7 @@ struct drm_buf_map { int fd; }; -/** +/* * DRM_IOCTL_DMA ioctl argument type. * * Indices here refer to the offset into the buffer list in drm_buf_get. @@ -443,7 +443,7 @@ enum drm_ctx_flags { _DRM_CONTEXT_2DONLY = 0x02 }; -/** +/* * DRM_IOCTL_ADD_CTX ioctl argument type. * * \sa drmCreateContext() and drmDestroyContext(). @@ -453,7 +453,7 @@ struct drm_ctx { enum drm_ctx_flags flags; }; -/** +/* * DRM_IOCTL_RES_CTX ioctl argument type. */ struct drm_ctx_res { @@ -461,14 +461,14 @@ struct drm_ctx_res { struct drm_ctx *contexts; }; -/** +/* * DRM_IOCTL_ADD_DRAW and DRM_IOCTL_RM_DRAW ioctl argument type. */ struct drm_draw { drm_drawable_t handle; }; -/** +/* * DRM_IOCTL_UPDATE_DRAW ioctl argument type. */ typedef enum { @@ -482,14 +482,14 @@ struct drm_update_draw { unsigned long long data; }; -/** +/* * DRM_IOCTL_GET_MAGIC and DRM_IOCTL_AUTH_MAGIC ioctl argument type. */ struct drm_auth { drm_magic_t magic; }; -/** +/* * DRM_IOCTL_IRQ_BUSID ioctl argument type. * * \sa drmGetInterruptFromBusID(). @@ -531,7 +531,7 @@ struct drm_wait_vblank_reply { long tval_usec; }; -/** +/* * DRM_IOCTL_WAIT_VBLANK ioctl argument type. * * \sa drmWaitVBlank(). @@ -544,7 +544,7 @@ union drm_wait_vblank { #define _DRM_PRE_MODESET 1 #define _DRM_POST_MODESET 2 -/** +/* * DRM_IOCTL_MODESET_CTL ioctl argument type * * \sa drmModesetCtl(). @@ -554,7 +554,7 @@ struct drm_modeset_ctl { __u32 cmd; }; -/** +/* * DRM_IOCTL_AGP_ENABLE ioctl argument type. * * \sa drmAgpEnable(). @@ -563,7 +563,7 @@ struct drm_agp_mode { unsigned long mode; /**< AGP mode */ }; -/** +/* * DRM_IOCTL_AGP_ALLOC and DRM_IOCTL_AGP_FREE ioctls argument type. * * \sa drmAgpAlloc() and drmAgpFree(). @@ -575,7 +575,7 @@ struct drm_agp_buffer { unsigned long physical; /**< Physical used by i810 */ }; -/** +/* * DRM_IOCTL_AGP_BIND and DRM_IOCTL_AGP_UNBIND ioctls argument type. * * \sa drmAgpBind() and drmAgpUnbind(). @@ -585,7 +585,7 @@ struct drm_agp_binding { unsigned long offset; /**< In bytes -- will round to page boundary */ }; -/** +/* * DRM_IOCTL_AGP_INFO ioctl argument type. * * \sa drmAgpVersionMajor(), drmAgpVersionMinor(), drmAgpGetMode(), @@ -606,7 +606,7 @@ struct drm_agp_info { unsigned short id_device; }; -/** +/* * DRM_IOCTL_SG_ALLOC ioctl argument type. */ struct drm_scatter_gather { @@ -614,7 +614,7 @@ struct drm_scatter_gather { unsigned long handle; /**< Used for mapping / unmapping */ }; -/** +/* * DRM_IOCTL_SET_VERSION ioctl argument type. */ struct drm_set_version { @@ -624,14 +624,14 @@ struct drm_set_version { int drm_dd_minor; }; -/** DRM_IOCTL_GEM_CLOSE ioctl argument type */ +/* DRM_IOCTL_GEM_CLOSE ioctl argument type */ struct drm_gem_close { /** Handle of the object to be closed. */ __u32 handle; __u32 pad; }; -/** DRM_IOCTL_GEM_FLINK ioctl argument type */ +/* DRM_IOCTL_GEM_FLINK ioctl argument type */ struct drm_gem_flink { /** Handle for the object being named */ __u32 handle; @@ -640,7 +640,7 @@ struct drm_gem_flink { __u32 name; }; -/** DRM_IOCTL_GEM_OPEN ioctl argument type */ +/* DRM_IOCTL_GEM_OPEN ioctl argument type */ struct drm_gem_open { /** Name of object being opened */ __u32 name; @@ -652,30 +652,150 @@ struct drm_gem_open { __u64 size; }; +/** + * DRM_CAP_DUMB_BUFFER + * + * If set to 1, the driver supports creating dumb buffers via the + * &DRM_IOCTL_MODE_CREATE_DUMB ioctl. + */ #define DRM_CAP_DUMB_BUFFER 0x1 +/** + * DRM_CAP_VBLANK_HIGH_CRTC + * + * If set to 1, the kernel supports specifying a CRTC index in the high bits of + * &drm_wait_vblank_request.type. + * + * Starting kernel version 2.6.39, this capability is always set to 1. + */ #define DRM_CAP_VBLANK_HIGH_CRTC 0x2 +/** + * DRM_CAP_DUMB_PREFERRED_DEPTH + * + * The preferred bit depth for dumb buffers. + * + * The bit depth is the number of bits used to indicate the color of a single + * pixel excluding any padding. This is different from the number of bits per + * pixel. For instance, XRGB8888 has a bit depth of 24 but has 32 bits per + * pixel. + * + * Note that this preference only applies to dumb buffers, it's irrelevant for + * other types of buffers. + */ #define DRM_CAP_DUMB_PREFERRED_DEPTH 0x3 +/** + * DRM_CAP_DUMB_PREFER_SHADOW + * + * If set to 1, the driver prefers userspace to render to a shadow buffer + * instead of directly rendering to a dumb buffer. For best speed, userspace + * should do streaming ordered memory copies into the dumb buffer and never + * read from it. + * + * Note that this preference only applies to dumb buffers, it's irrelevant for + * other types of buffers. + */ #define DRM_CAP_DUMB_PREFER_SHADOW 0x4 +/** + * DRM_CAP_PRIME + * + * Bitfield of supported PRIME sharing capabilities. See &DRM_PRIME_CAP_IMPORT + * and &DRM_PRIME_CAP_EXPORT. + * + * PRIME buffers are exposed as dma-buf file descriptors. See + * Documentation/gpu/drm-mm.rst, section "PRIME Buffer Sharing". + */ #define DRM_CAP_PRIME 0x5 +/** + * DRM_PRIME_CAP_IMPORT + * + * If this bit is set in &DRM_CAP_PRIME, the driver supports importing PRIME + * buffers via the &DRM_IOCTL_PRIME_FD_TO_HANDLE ioctl. + */ #define DRM_PRIME_CAP_IMPORT 0x1 +/** + * DRM_PRIME_CAP_EXPORT + * + * If this bit is set in &DRM_CAP_PRIME, the driver supports exporting PRIME + * buffers via the &DRM_IOCTL_PRIME_HANDLE_TO_FD ioctl. + */ #define DRM_PRIME_CAP_EXPORT 0x2 +/** + * DRM_CAP_TIMESTAMP_MONOTONIC + * + * If set to 0, the kernel will report timestamps with ``CLOCK_REALTIME`` in + * struct drm_event_vblank. If set to 1, the kernel will report timestamps with + * ``CLOCK_MONOTONIC``. See ``clock_gettime(2)`` for the definition of these + * clocks. + * + * Starting from kernel version 2.6.39, the default value for this capability + * is 1. Starting kernel version 4.15, this capability is always set to 1. + */ #define DRM_CAP_TIMESTAMP_MONOTONIC 0x6 +/** + * DRM_CAP_ASYNC_PAGE_FLIP + * + * If set to 1, the driver supports &DRM_MODE_PAGE_FLIP_ASYNC. + */ #define DRM_CAP_ASYNC_PAGE_FLIP 0x7 -/* - * The CURSOR_WIDTH and CURSOR_HEIGHT capabilities return a valid widthxheight - * combination for the hardware cursor. The intention is that a hardware - * agnostic userspace can query a cursor plane size to use. +/** + * DRM_CAP_CURSOR_WIDTH + * + * The ``CURSOR_WIDTH`` and ``CURSOR_HEIGHT`` capabilities return a valid + * width x height combination for the hardware cursor. The intention is that a + * hardware agnostic userspace can query a cursor plane size to use. * * Note that the cross-driver contract is to merely return a valid size; * drivers are free to attach another meaning on top, eg. i915 returns the * maximum plane size. */ #define DRM_CAP_CURSOR_WIDTH 0x8 +/** + * DRM_CAP_CURSOR_HEIGHT + * + * See &DRM_CAP_CURSOR_WIDTH. + */ #define DRM_CAP_CURSOR_HEIGHT 0x9 +/** + * DRM_CAP_ADDFB2_MODIFIERS + * + * If set to 1, the driver supports supplying modifiers in the + * &DRM_IOCTL_MODE_ADDFB2 ioctl. + */ #define DRM_CAP_ADDFB2_MODIFIERS 0x10 +/** + * DRM_CAP_PAGE_FLIP_TARGET + * + * If set to 1, the driver supports the &DRM_MODE_PAGE_FLIP_TARGET_ABSOLUTE and + * &DRM_MODE_PAGE_FLIP_TARGET_RELATIVE flags in + * &drm_mode_crtc_page_flip_target.flags for the &DRM_IOCTL_MODE_PAGE_FLIP + * ioctl. + */ #define DRM_CAP_PAGE_FLIP_TARGET 0x11 +/** + * DRM_CAP_CRTC_IN_VBLANK_EVENT + * + * If set to 1, the kernel supports reporting the CRTC ID in + * &drm_event_vblank.crtc_id for the &DRM_EVENT_VBLANK and + * &DRM_EVENT_FLIP_COMPLETE events. + * + * Starting kernel version 4.12, this capability is always set to 1. + */ +#define DRM_CAP_CRTC_IN_VBLANK_EVENT 0x12 +/** + * DRM_CAP_SYNCOBJ + * + * If set to 1, the driver supports sync objects. See + * Documentation/gpu/drm-mm.rst, section "DRM Sync Objects". + */ +#define DRM_CAP_SYNCOBJ 0x13 +/** + * DRM_CAP_SYNCOBJ_TIMELINE + * + * If set to 1, the driver supports timeline operations on sync objects. See + * Documentation/gpu/drm-mm.rst, section "DRM Sync Objects". + */ +#define DRM_CAP_SYNCOBJ_TIMELINE 0x14 -/** DRM_IOCTL_GET_CAP ioctl argument type */ +/* DRM_IOCTL_GET_CAP ioctl argument type */ struct drm_get_cap { __u64 capability; __u64 value; @@ -684,9 +804,12 @@ struct drm_get_cap { /** * DRM_CLIENT_CAP_STEREO_3D * - * if set to 1, the DRM core will expose the stereo 3D capabilities of the + * If set to 1, the DRM core will expose the stereo 3D capabilities of the * monitor by advertising the supported 3D layouts in the flags of struct - * drm_mode_modeinfo. + * drm_mode_modeinfo. See ``DRM_MODE_FLAG_3D_*``. + * + * This capability is always supported for all drivers starting from kernel + * version 3.13. */ #define DRM_CLIENT_CAP_STEREO_3D 1 @@ -695,17 +818,52 @@ struct drm_get_cap { * * If set to 1, the DRM core will expose all planes (overlay, primary, and * cursor) to userspace. + * + * This capability has been introduced in kernel version 3.15. Starting from + * kernel version 3.17, this capability is always supported for all drivers. */ #define DRM_CLIENT_CAP_UNIVERSAL_PLANES 2 /** * DRM_CLIENT_CAP_ATOMIC * - * If set to 1, the DRM core will expose atomic properties to userspace + * If set to 1, the DRM core will expose atomic properties to userspace. This + * implicitly enables &DRM_CLIENT_CAP_UNIVERSAL_PLANES and + * &DRM_CLIENT_CAP_ASPECT_RATIO. + * + * If the driver doesn't support atomic mode-setting, enabling this capability + * will fail with -EOPNOTSUPP. + * + * This capability has been introduced in kernel version 4.0. Starting from + * kernel version 4.2, this capability is always supported for atomic-capable + * drivers. */ #define DRM_CLIENT_CAP_ATOMIC 3 -/** DRM_IOCTL_SET_CLIENT_CAP ioctl argument type */ +/** + * DRM_CLIENT_CAP_ASPECT_RATIO + * + * If set to 1, the DRM core will provide aspect ratio information in modes. + * See ``DRM_MODE_FLAG_PIC_AR_*``. + * + * This capability is always supported for all drivers starting from kernel + * version 4.18. + */ +#define DRM_CLIENT_CAP_ASPECT_RATIO 4 + +/** + * DRM_CLIENT_CAP_WRITEBACK_CONNECTORS + * + * If set to 1, the DRM core will expose special connectors to be used for + * writing back to memory the scene setup in the commit. The client must enable + * &DRM_CLIENT_CAP_ATOMIC first. + * + * This capability is always supported for atomic-capable drivers starting from + * kernel version 4.19. + */ +#define DRM_CLIENT_CAP_WRITEBACK_CONNECTORS 5 + +/* DRM_IOCTL_SET_CLIENT_CAP ioctl argument type */ struct drm_set_client_cap { __u64 capability; __u64 value; @@ -723,6 +881,99 @@ struct drm_prime_handle { __s32 fd; }; +struct drm_syncobj_create { + __u32 handle; +#define DRM_SYNCOBJ_CREATE_SIGNALED (1 << 0) + __u32 flags; +}; + +struct drm_syncobj_destroy { + __u32 handle; + __u32 pad; +}; + +#define DRM_SYNCOBJ_FD_TO_HANDLE_FLAGS_IMPORT_SYNC_FILE (1 << 0) +#define DRM_SYNCOBJ_HANDLE_TO_FD_FLAGS_EXPORT_SYNC_FILE (1 << 0) +struct drm_syncobj_handle { + __u32 handle; + __u32 flags; + + __s32 fd; + __u32 pad; +}; + +struct drm_syncobj_transfer { + __u32 src_handle; + __u32 dst_handle; + __u64 src_point; + __u64 dst_point; + __u32 flags; + __u32 pad; +}; + +#define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_ALL (1 << 0) +#define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_FOR_SUBMIT (1 << 1) +#define DRM_SYNCOBJ_WAIT_FLAGS_WAIT_AVAILABLE (1 << 2) /* wait for time point to become available */ +struct drm_syncobj_wait { + __u64 handles; + /* absolute timeout */ + __s64 timeout_nsec; + __u32 count_handles; + __u32 flags; + __u32 first_signaled; /* only valid when not waiting all */ + __u32 pad; +}; + +struct drm_syncobj_timeline_wait { + __u64 handles; + /* wait on specific timeline point for every handles*/ + __u64 points; + /* absolute timeout */ + __s64 timeout_nsec; + __u32 count_handles; + __u32 flags; + __u32 first_signaled; /* only valid when not waiting all */ + __u32 pad; +}; + + +struct drm_syncobj_array { + __u64 handles; + __u32 count_handles; + __u32 pad; +}; + +#define DRM_SYNCOBJ_QUERY_FLAGS_LAST_SUBMITTED (1 << 0) /* last available point on timeline syncobj */ +struct drm_syncobj_timeline_array { + __u64 handles; + __u64 points; + __u32 count_handles; + __u32 flags; +}; + + +/* Query current scanout sequence number */ +struct drm_crtc_get_sequence { + __u32 crtc_id; /* requested crtc_id */ + __u32 active; /* return: crtc output is active */ + __u64 sequence; /* return: most recent vblank sequence */ + __s64 sequence_ns; /* return: most recent time of first pixel out */ +}; + +/* Queue event to be delivered at specified sequence. Time stamp marks + * when the first pixel of the refresh cycle leaves the display engine + * for the display + */ +#define DRM_CRTC_SEQUENCE_RELATIVE 0x00000001 /* sequence is relative to current */ +#define DRM_CRTC_SEQUENCE_NEXT_ON_MISS 0x00000002 /* Use next sequence if we've missed */ + +struct drm_crtc_queue_sequence { + __u32 crtc_id; + __u32 flags; + __u64 sequence; /* on input, target sequence. on output, actual sequence */ + __u64 user_data; /* user data passed to event */ +}; + #if defined(__cplusplus) } #endif @@ -805,6 +1056,9 @@ extern "C" { #define DRM_IOCTL_WAIT_VBLANK DRM_IOWR(0x3a, union drm_wait_vblank) +#define DRM_IOCTL_CRTC_GET_SEQUENCE DRM_IOWR(0x3b, struct drm_crtc_get_sequence) +#define DRM_IOCTL_CRTC_QUEUE_SEQUENCE DRM_IOWR(0x3c, struct drm_crtc_queue_sequence) + #define DRM_IOCTL_UPDATE_DRAW DRM_IOW(0x3f, struct drm_update_draw) #define DRM_IOCTL_MODE_GETRESOURCES DRM_IOWR(0xA0, struct drm_mode_card_res) @@ -841,7 +1095,27 @@ extern "C" { #define DRM_IOCTL_MODE_CREATEPROPBLOB DRM_IOWR(0xBD, struct drm_mode_create_blob) #define DRM_IOCTL_MODE_DESTROYPROPBLOB DRM_IOWR(0xBE, struct drm_mode_destroy_blob) -/** +#define DRM_IOCTL_SYNCOBJ_CREATE DRM_IOWR(0xBF, struct drm_syncobj_create) +#define DRM_IOCTL_SYNCOBJ_DESTROY DRM_IOWR(0xC0, struct drm_syncobj_destroy) +#define DRM_IOCTL_SYNCOBJ_HANDLE_TO_FD DRM_IOWR(0xC1, struct drm_syncobj_handle) +#define DRM_IOCTL_SYNCOBJ_FD_TO_HANDLE DRM_IOWR(0xC2, struct drm_syncobj_handle) +#define DRM_IOCTL_SYNCOBJ_WAIT DRM_IOWR(0xC3, struct drm_syncobj_wait) +#define DRM_IOCTL_SYNCOBJ_RESET DRM_IOWR(0xC4, struct drm_syncobj_array) +#define DRM_IOCTL_SYNCOBJ_SIGNAL DRM_IOWR(0xC5, struct drm_syncobj_array) + +#define DRM_IOCTL_MODE_CREATE_LEASE DRM_IOWR(0xC6, struct drm_mode_create_lease) +#define DRM_IOCTL_MODE_LIST_LESSEES DRM_IOWR(0xC7, struct drm_mode_list_lessees) +#define DRM_IOCTL_MODE_GET_LEASE DRM_IOWR(0xC8, struct drm_mode_get_lease) +#define DRM_IOCTL_MODE_REVOKE_LEASE DRM_IOWR(0xC9, struct drm_mode_revoke_lease) + +#define DRM_IOCTL_SYNCOBJ_TIMELINE_WAIT DRM_IOWR(0xCA, struct drm_syncobj_timeline_wait) +#define DRM_IOCTL_SYNCOBJ_QUERY DRM_IOWR(0xCB, struct drm_syncobj_timeline_array) +#define DRM_IOCTL_SYNCOBJ_TRANSFER DRM_IOWR(0xCC, struct drm_syncobj_transfer) +#define DRM_IOCTL_SYNCOBJ_TIMELINE_SIGNAL DRM_IOWR(0xCD, struct drm_syncobj_timeline_array) + +#define DRM_IOCTL_MODE_GETFB2 DRM_IOWR(0xCE, struct drm_mode_fb_cmd2) + +/* * Device specific ioctls should only be in their respective headers * The device specific ioctl range is from 0x40 to 0x9f. * Generic IOCTLS restart at 0xA0. @@ -852,7 +1126,7 @@ extern "C" { #define DRM_COMMAND_BASE 0x40 #define DRM_COMMAND_END 0xA0 -/** +/* * Header for events written back to userspace on the drm fd. The * type defines the type of event, the length specifies the total * length of the event (including the header), and user_data is @@ -871,6 +1145,7 @@ struct drm_event { #define DRM_EVENT_VBLANK 0x01 #define DRM_EVENT_FLIP_COMPLETE 0x02 +#define DRM_EVENT_CRTC_SEQUENCE 0x03 struct drm_event_vblank { struct drm_event base; @@ -878,7 +1153,17 @@ struct drm_event_vblank { __u32 tv_sec; __u32 tv_usec; __u32 sequence; - __u32 reserved; + __u32 crtc_id; /* 0 on older kernels that do not support this */ +}; + +/* Event delivered at sequence. Time stamp marks when the first pixel + * of the refresh cycle leaves the display engine for the display + */ +struct drm_event_crtc_sequence { + struct drm_event base; + __u64 user_data; + __s64 time_ns; + __u64 sequence; }; /* typedef area */ diff --git a/usr/src/uts/common/drm/drm_crtc.h b/usr/src/uts/common/drm/drm_crtc.h index 8d254d7b..b6b85680 100644 --- a/usr/src/uts/common/drm/drm_crtc.h +++ b/usr/src/uts/common/drm/drm_crtc.h @@ -204,7 +204,7 @@ enum subpixel_order { * Describes a given display (e.g. CRT or flat panel) and its limitations. */ struct drm_display_info { - char name[DRM_DISPLAY_INFO_LEN]; + char name[DRM_DISPLAY_MODE_LEN]; /* Physical size */ unsigned int width_mm; diff --git a/usr/src/uts/common/drm/drm_fourcc.h b/usr/src/uts/common/drm/drm_fourcc.h index 4d8da699..957c7be2 100644 --- a/usr/src/uts/common/drm/drm_fourcc.h +++ b/usr/src/uts/common/drm/drm_fourcc.h @@ -26,10 +26,77 @@ #include "drm.h" +#if defined(__cplusplus) +extern "C" { +#endif + +/** + * DOC: overview + * + * In the DRM subsystem, framebuffer pixel formats are described using the + * fourcc codes defined in `include/uapi/drm/drm_fourcc.h`. In addition to the + * fourcc code, a Format Modifier may optionally be provided, in order to + * further describe the buffer's format - for example tiling or compression. + * + * Format Modifiers + * ---------------- + * + * Format modifiers are used in conjunction with a fourcc code, forming a + * unique fourcc:modifier pair. This format:modifier pair must fully define the + * format and data layout of the buffer, and should be the only way to describe + * that particular buffer. + * + * Having multiple fourcc:modifier pairs which describe the same layout should + * be avoided, as such aliases run the risk of different drivers exposing + * different names for the same data format, forcing userspace to understand + * that they are aliases. + * + * Format modifiers may change any property of the buffer, including the number + * of planes and/or the required allocation size. Format modifiers are + * vendor-namespaced, and as such the relationship between a fourcc code and a + * modifier is specific to the modifer being used. For example, some modifiers + * may preserve meaning - such as number of planes - from the fourcc code, + * whereas others may not. + * + * Modifiers must uniquely encode buffer layout. In other words, a buffer must + * match only a single modifier. A modifier must not be a subset of layouts of + * another modifier. For instance, it's incorrect to encode pitch alignment in + * a modifier: a buffer may match a 64-pixel aligned modifier and a 32-pixel + * aligned modifier. That said, modifiers can have implicit minimal + * requirements. + * + * For modifiers where the combination of fourcc code and modifier can alias, + * a canonical pair needs to be defined and used by all drivers. Preferred + * combinations are also encouraged where all combinations might lead to + * confusion and unnecessarily reduced interoperability. An example for the + * latter is AFBC, where the ABGR layouts are preferred over ARGB layouts. + * + * There are two kinds of modifier users: + * + * - Kernel and user-space drivers: for drivers it's important that modifiers + * don't alias, otherwise two drivers might support the same format but use + * different aliases, preventing them from sharing buffers in an efficient + * format. + * - Higher-level programs interfacing with KMS/GBM/EGL/Vulkan/etc: these users + * see modifiers as opaque tokens they can check for equality and intersect. + * These users musn't need to know to reason about the modifier value + * (i.e. they are not expected to extract information out of the modifier). + * + * Vendors should document their modifier usage in as much detail as + * possible, to ensure maximum compatibility across devices, drivers and + * applications. + * + * The authoritative list of format modifier codes is found in + * `include/uapi/drm/drm_fourcc.h` + */ + #define fourcc_code(a, b, c, d) ((__u32)(a) | ((__u32)(b) << 8) | \ ((__u32)(c) << 16) | ((__u32)(d) << 24)) -#define DRM_FORMAT_BIG_ENDIAN (1<<31) /* format is big endian instead of little endian */ +#define DRM_FORMAT_BIG_ENDIAN (1U<<31) /* format is big endian instead of little endian */ + +/* Reserve 0 for the invalid format specifier */ +#define DRM_FORMAT_INVALID 0 /* color index */ #define DRM_FORMAT_C8 fourcc_code('C', '8', ' ', ' ') /* [7:0] C */ @@ -37,10 +104,17 @@ /* 8 bpp Red */ #define DRM_FORMAT_R8 fourcc_code('R', '8', ' ', ' ') /* [7:0] R */ +/* 16 bpp Red */ +#define DRM_FORMAT_R16 fourcc_code('R', '1', '6', ' ') /* [15:0] R little endian */ + /* 16 bpp RG */ #define DRM_FORMAT_RG88 fourcc_code('R', 'G', '8', '8') /* [15:0] R:G 8:8 little endian */ #define DRM_FORMAT_GR88 fourcc_code('G', 'R', '8', '8') /* [15:0] G:R 8:8 little endian */ +/* 32 bpp RG */ +#define DRM_FORMAT_RG1616 fourcc_code('R', 'G', '3', '2') /* [31:0] R:G 16:16 little endian */ +#define DRM_FORMAT_GR1616 fourcc_code('G', 'R', '3', '2') /* [31:0] G:R 16:16 little endian */ + /* 8 bpp RGB */ #define DRM_FORMAT_RGB332 fourcc_code('R', 'G', 'B', '8') /* [7:0] R:G:B 3:3:2 */ #define DRM_FORMAT_BGR233 fourcc_code('B', 'G', 'R', '8') /* [7:0] B:G:R 2:3:3 */ @@ -94,6 +168,30 @@ #define DRM_FORMAT_RGBA1010102 fourcc_code('R', 'A', '3', '0') /* [31:0] R:G:B:A 10:10:10:2 little endian */ #define DRM_FORMAT_BGRA1010102 fourcc_code('B', 'A', '3', '0') /* [31:0] B:G:R:A 10:10:10:2 little endian */ +/* 64 bpp RGB */ +#define DRM_FORMAT_XRGB16161616 fourcc_code('X', 'R', '4', '8') /* [63:0] x:R:G:B 16:16:16:16 little endian */ +#define DRM_FORMAT_XBGR16161616 fourcc_code('X', 'B', '4', '8') /* [63:0] x:B:G:R 16:16:16:16 little endian */ + +#define DRM_FORMAT_ARGB16161616 fourcc_code('A', 'R', '4', '8') /* [63:0] A:R:G:B 16:16:16:16 little endian */ +#define DRM_FORMAT_ABGR16161616 fourcc_code('A', 'B', '4', '8') /* [63:0] A:B:G:R 16:16:16:16 little endian */ + +/* + * Floating point 64bpp RGB + * IEEE 754-2008 binary16 half-precision float + * [15:0] sign:exponent:mantissa 1:5:10 + */ +#define DRM_FORMAT_XRGB16161616F fourcc_code('X', 'R', '4', 'H') /* [63:0] x:R:G:B 16:16:16:16 little endian */ +#define DRM_FORMAT_XBGR16161616F fourcc_code('X', 'B', '4', 'H') /* [63:0] x:B:G:R 16:16:16:16 little endian */ + +#define DRM_FORMAT_ARGB16161616F fourcc_code('A', 'R', '4', 'H') /* [63:0] A:R:G:B 16:16:16:16 little endian */ +#define DRM_FORMAT_ABGR16161616F fourcc_code('A', 'B', '4', 'H') /* [63:0] A:B:G:R 16:16:16:16 little endian */ + +/* + * RGBA format with 10-bit components packed in 64-bit per pixel, with 6 bits + * of unused padding per component: + */ +#define DRM_FORMAT_AXBXGXRX106106106106 fourcc_code('A', 'B', '1', '0') /* [63:0] A:x:B:x:G:x:R:x 10:6:10:6:10:6:10:6 little endian */ + /* packed YCbCr */ #define DRM_FORMAT_YUYV fourcc_code('Y', 'U', 'Y', 'V') /* [31:0] Cr0:Y1:Cb0:Y0 8:8:8:8 little endian */ #define DRM_FORMAT_YVYU fourcc_code('Y', 'V', 'Y', 'U') /* [31:0] Cb0:Y1:Cr0:Y0 8:8:8:8 little endian */ @@ -101,6 +199,66 @@ #define DRM_FORMAT_VYUY fourcc_code('V', 'Y', 'U', 'Y') /* [31:0] Y1:Cb0:Y0:Cr0 8:8:8:8 little endian */ #define DRM_FORMAT_AYUV fourcc_code('A', 'Y', 'U', 'V') /* [31:0] A:Y:Cb:Cr 8:8:8:8 little endian */ +#define DRM_FORMAT_XYUV8888 fourcc_code('X', 'Y', 'U', 'V') /* [31:0] X:Y:Cb:Cr 8:8:8:8 little endian */ +#define DRM_FORMAT_VUY888 fourcc_code('V', 'U', '2', '4') /* [23:0] Cr:Cb:Y 8:8:8 little endian */ +#define DRM_FORMAT_VUY101010 fourcc_code('V', 'U', '3', '0') /* Y followed by U then V, 10:10:10. Non-linear modifier only */ + +/* + * packed Y2xx indicate for each component, xx valid data occupy msb + * 16-xx padding occupy lsb + */ +#define DRM_FORMAT_Y210 fourcc_code('Y', '2', '1', '0') /* [63:0] Cr0:0:Y1:0:Cb0:0:Y0:0 10:6:10:6:10:6:10:6 little endian per 2 Y pixels */ +#define DRM_FORMAT_Y212 fourcc_code('Y', '2', '1', '2') /* [63:0] Cr0:0:Y1:0:Cb0:0:Y0:0 12:4:12:4:12:4:12:4 little endian per 2 Y pixels */ +#define DRM_FORMAT_Y216 fourcc_code('Y', '2', '1', '6') /* [63:0] Cr0:Y1:Cb0:Y0 16:16:16:16 little endian per 2 Y pixels */ + +/* + * packed Y4xx indicate for each component, xx valid data occupy msb + * 16-xx padding occupy lsb except Y410 + */ +#define DRM_FORMAT_Y410 fourcc_code('Y', '4', '1', '0') /* [31:0] A:Cr:Y:Cb 2:10:10:10 little endian */ +#define DRM_FORMAT_Y412 fourcc_code('Y', '4', '1', '2') /* [63:0] A:0:Cr:0:Y:0:Cb:0 12:4:12:4:12:4:12:4 little endian */ +#define DRM_FORMAT_Y416 fourcc_code('Y', '4', '1', '6') /* [63:0] A:Cr:Y:Cb 16:16:16:16 little endian */ + +#define DRM_FORMAT_XVYU2101010 fourcc_code('X', 'V', '3', '0') /* [31:0] X:Cr:Y:Cb 2:10:10:10 little endian */ +#define DRM_FORMAT_XVYU12_16161616 fourcc_code('X', 'V', '3', '6') /* [63:0] X:0:Cr:0:Y:0:Cb:0 12:4:12:4:12:4:12:4 little endian */ +#define DRM_FORMAT_XVYU16161616 fourcc_code('X', 'V', '4', '8') /* [63:0] X:Cr:Y:Cb 16:16:16:16 little endian */ + +/* + * packed YCbCr420 2x2 tiled formats + * first 64 bits will contain Y,Cb,Cr components for a 2x2 tile + */ +/* [63:0] A3:A2:Y3:0:Cr0:0:Y2:0:A1:A0:Y1:0:Cb0:0:Y0:0 1:1:8:2:8:2:8:2:1:1:8:2:8:2:8:2 little endian */ +#define DRM_FORMAT_Y0L0 fourcc_code('Y', '0', 'L', '0') +/* [63:0] X3:X2:Y3:0:Cr0:0:Y2:0:X1:X0:Y1:0:Cb0:0:Y0:0 1:1:8:2:8:2:8:2:1:1:8:2:8:2:8:2 little endian */ +#define DRM_FORMAT_X0L0 fourcc_code('X', '0', 'L', '0') + +/* [63:0] A3:A2:Y3:Cr0:Y2:A1:A0:Y1:Cb0:Y0 1:1:10:10:10:1:1:10:10:10 little endian */ +#define DRM_FORMAT_Y0L2 fourcc_code('Y', '0', 'L', '2') +/* [63:0] X3:X2:Y3:Cr0:Y2:X1:X0:Y1:Cb0:Y0 1:1:10:10:10:1:1:10:10:10 little endian */ +#define DRM_FORMAT_X0L2 fourcc_code('X', '0', 'L', '2') + +/* + * 1-plane YUV 4:2:0 + * In these formats, the component ordering is specified (Y, followed by U + * then V), but the exact Linear layout is undefined. + * These formats can only be used with a non-Linear modifier. + */ +#define DRM_FORMAT_YUV420_8BIT fourcc_code('Y', 'U', '0', '8') +#define DRM_FORMAT_YUV420_10BIT fourcc_code('Y', 'U', '1', '0') + +/* + * 2 plane RGB + A + * index 0 = RGB plane, same format as the corresponding non _A8 format has + * index 1 = A plane, [7:0] A + */ +#define DRM_FORMAT_XRGB8888_A8 fourcc_code('X', 'R', 'A', '8') +#define DRM_FORMAT_XBGR8888_A8 fourcc_code('X', 'B', 'A', '8') +#define DRM_FORMAT_RGBX8888_A8 fourcc_code('R', 'X', 'A', '8') +#define DRM_FORMAT_BGRX8888_A8 fourcc_code('B', 'X', 'A', '8') +#define DRM_FORMAT_RGB888_A8 fourcc_code('R', '8', 'A', '8') +#define DRM_FORMAT_BGR888_A8 fourcc_code('B', '8', 'A', '8') +#define DRM_FORMAT_RGB565_A8 fourcc_code('R', '5', 'A', '8') +#define DRM_FORMAT_BGR565_A8 fourcc_code('B', '5', 'A', '8') /* * 2 plane YCbCr @@ -115,6 +273,56 @@ #define DRM_FORMAT_NV61 fourcc_code('N', 'V', '6', '1') /* 2x1 subsampled Cb:Cr plane */ #define DRM_FORMAT_NV24 fourcc_code('N', 'V', '2', '4') /* non-subsampled Cr:Cb plane */ #define DRM_FORMAT_NV42 fourcc_code('N', 'V', '4', '2') /* non-subsampled Cb:Cr plane */ +/* + * 2 plane YCbCr + * index 0 = Y plane, [39:0] Y3:Y2:Y1:Y0 little endian + * index 1 = Cr:Cb plane, [39:0] Cr1:Cb1:Cr0:Cb0 little endian + */ +#define DRM_FORMAT_NV15 fourcc_code('N', 'V', '1', '5') /* 2x2 subsampled Cr:Cb plane */ + +/* + * 2 plane YCbCr MSB aligned + * index 0 = Y plane, [15:0] Y:x [10:6] little endian + * index 1 = Cr:Cb plane, [31:0] Cr:x:Cb:x [10:6:10:6] little endian + */ +#define DRM_FORMAT_P210 fourcc_code('P', '2', '1', '0') /* 2x1 subsampled Cr:Cb plane, 10 bit per channel */ + +/* + * 2 plane YCbCr MSB aligned + * index 0 = Y plane, [15:0] Y:x [10:6] little endian + * index 1 = Cr:Cb plane, [31:0] Cr:x:Cb:x [10:6:10:6] little endian + */ +#define DRM_FORMAT_P010 fourcc_code('P', '0', '1', '0') /* 2x2 subsampled Cr:Cb plane 10 bits per channel */ + +/* + * 2 plane YCbCr MSB aligned + * index 0 = Y plane, [15:0] Y:x [12:4] little endian + * index 1 = Cr:Cb plane, [31:0] Cr:x:Cb:x [12:4:12:4] little endian + */ +#define DRM_FORMAT_P012 fourcc_code('P', '0', '1', '2') /* 2x2 subsampled Cr:Cb plane 12 bits per channel */ + +/* + * 2 plane YCbCr MSB aligned + * index 0 = Y plane, [15:0] Y little endian + * index 1 = Cr:Cb plane, [31:0] Cr:Cb [16:16] little endian + */ +#define DRM_FORMAT_P016 fourcc_code('P', '0', '1', '6') /* 2x2 subsampled Cr:Cb plane 16 bits per channel */ + +/* 3 plane non-subsampled (444) YCbCr + * 16 bits per component, but only 10 bits are used and 6 bits are padded + * index 0: Y plane, [15:0] Y:x [10:6] little endian + * index 1: Cb plane, [15:0] Cb:x [10:6] little endian + * index 2: Cr plane, [15:0] Cr:x [10:6] little endian + */ +#define DRM_FORMAT_Q410 fourcc_code('Q', '4', '1', '0') + +/* 3 plane non-subsampled (444) YCrCb + * 16 bits per component, but only 10 bits are used and 6 bits are padded + * index 0: Y plane, [15:0] Y:x [10:6] little endian + * index 1: Cr plane, [15:0] Cr:x [10:6] little endian + * index 2: Cb plane, [15:0] Cb:x [10:6] little endian + */ +#define DRM_FORMAT_Q401 fourcc_code('Q', '4', '0', '1') /* * 3 plane YCbCr @@ -149,16 +357,24 @@ */ /* Vendor Ids: */ -#define DRM_FORMAT_MOD_NONE 0 +#define DRM_FORMAT_MOD_VENDOR_NONE 0 #define DRM_FORMAT_MOD_VENDOR_INTEL 0x01 #define DRM_FORMAT_MOD_VENDOR_AMD 0x02 -#define DRM_FORMAT_MOD_VENDOR_NV 0x03 +#define DRM_FORMAT_MOD_VENDOR_NVIDIA 0x03 #define DRM_FORMAT_MOD_VENDOR_SAMSUNG 0x04 #define DRM_FORMAT_MOD_VENDOR_QCOM 0x05 +#define DRM_FORMAT_MOD_VENDOR_VIVANTE 0x06 +#define DRM_FORMAT_MOD_VENDOR_BROADCOM 0x07 +#define DRM_FORMAT_MOD_VENDOR_ARM 0x08 +#define DRM_FORMAT_MOD_VENDOR_ALLWINNER 0x09 +#define DRM_FORMAT_MOD_VENDOR_AMLOGIC 0x0a + /* add more to the end as needed */ +#define DRM_FORMAT_RESERVED ((1ULL << 56) - 1) + #define fourcc_mod_code(vendor, val) \ - ((((__u64)DRM_FORMAT_MOD_VENDOR_## vendor) << 56) | (val & 0x00ffffffffffffffULL)) + ((((__u64)DRM_FORMAT_MOD_VENDOR_## vendor) << 56) | ((val) & 0x00ffffffffffffffULL)) /* * Format Modifier tokens: @@ -166,8 +382,62 @@ * When adding a new token please document the layout with a code comment, * similar to the fourcc codes above. drm_fourcc.h is considered the * authoritative source for all of these. + * + * Generic modifier names: + * + * DRM_FORMAT_MOD_GENERIC_* definitions are used to provide vendor-neutral names + * for layouts which are common across multiple vendors. To preserve + * compatibility, in cases where a vendor-specific definition already exists and + * a generic name for it is desired, the common name is a purely symbolic alias + * and must use the same numerical value as the original definition. + * + * Note that generic names should only be used for modifiers which describe + * generic layouts (such as pixel re-ordering), which may have + * independently-developed support across multiple vendors. + * + * In future cases where a generic layout is identified before merging with a + * vendor-specific modifier, a new 'GENERIC' vendor or modifier using vendor + * 'NONE' could be considered. This should only be for obvious, exceptional + * cases to avoid polluting the 'GENERIC' namespace with modifiers which only + * apply to a single vendor. + * + * Generic names should not be used for cases where multiple hardware vendors + * have implementations of the same standardised compression scheme (such as + * AFBC). In those cases, all implementations should use the same format + * modifier(s), reflecting the vendor of the standard. */ +#define DRM_FORMAT_MOD_GENERIC_16_16_TILE DRM_FORMAT_MOD_SAMSUNG_16_16_TILE + +/* + * Invalid Modifier + * + * This modifier can be used as a sentinel to terminate the format modifiers + * list, or to initialize a variable with an invalid modifier. It might also be + * used to report an error back to userspace for certain APIs. + */ +#define DRM_FORMAT_MOD_INVALID fourcc_mod_code(NONE, DRM_FORMAT_RESERVED) + +/* + * Linear Layout + * + * Just plain linear layout. Note that this is different from no specifying any + * modifier (e.g. not setting DRM_MODE_FB_MODIFIERS in the DRM_ADDFB2 ioctl), + * which tells the driver to also take driver-internal information into account + * and so might actually result in a tiled framebuffer. + */ +#define DRM_FORMAT_MOD_LINEAR fourcc_mod_code(NONE, 0) + +/* + * Deprecated: use DRM_FORMAT_MOD_LINEAR instead + * + * The "none" format modifier doesn't actually mean that the modifier is + * implicit, instead it means that the layout is linear. Whether modifiers are + * used is out-of-band information carried in an API-specific way (e.g. in a + * flag for drm_mode_fb_cmd2). + */ +#define DRM_FORMAT_MOD_NONE 0 + /* Intel framebuffer modifiers */ /* @@ -178,9 +448,12 @@ * a platform-dependent stride. On top of that the memory can apply * platform-depending swizzling of some higher address bits into bit6. * - * This format is highly platforms specific and not useful for cross-driver - * sharing. It exists since on a given platform it does uniquely identify the - * layout in a simple way for i915-specific userspace. + * Note that this layout is only accurate on intel gen 8+ or valleyview chipsets. + * On earlier platforms the is highly platforms specific and not useful for + * cross-driver sharing. It exists since on a given platform it does uniquely + * identify the layout in a simple way for i915-specific userspace, which + * facilitated conversion of userspace to modifiers. Additionally the exact + * format on some really old platforms is not known. */ #define I915_FORMAT_MOD_X_TILED fourcc_mod_code(INTEL, 1) @@ -193,9 +466,12 @@ * memory can apply platform-depending swizzling of some higher address bits * into bit6. * - * This format is highly platforms specific and not useful for cross-driver - * sharing. It exists since on a given platform it does uniquely identify the - * layout in a simple way for i915-specific userspace. + * Note that this layout is only accurate on intel gen 8+ or valleyview chipsets. + * On earlier platforms the is highly platforms specific and not useful for + * cross-driver sharing. It exists since on a given platform it does uniquely + * identify the layout in a simple way for i915-specific userspace, which + * facilitated conversion of userspace to modifiers. Additionally the exact + * format on some really old platforms is not known. */ #define I915_FORMAT_MOD_Y_TILED fourcc_mod_code(INTEL, 2) @@ -214,6 +490,69 @@ */ #define I915_FORMAT_MOD_Yf_TILED fourcc_mod_code(INTEL, 3) +/* + * Intel color control surface (CCS) for render compression + * + * The framebuffer format must be one of the 8:8:8:8 RGB formats. + * The main surface will be plane index 0 and must be Y/Yf-tiled, + * the CCS will be plane index 1. + * + * Each CCS tile matches a 1024x512 pixel area of the main surface. + * To match certain aspects of the 3D hardware the CCS is + * considered to be made up of normal 128Bx32 Y tiles, Thus + * the CCS pitch must be specified in multiples of 128 bytes. + * + * In reality the CCS tile appears to be a 64Bx64 Y tile, composed + * of QWORD (8 bytes) chunks instead of OWORD (16 bytes) chunks. + * But that fact is not relevant unless the memory is accessed + * directly. + */ +#define I915_FORMAT_MOD_Y_TILED_CCS fourcc_mod_code(INTEL, 4) +#define I915_FORMAT_MOD_Yf_TILED_CCS fourcc_mod_code(INTEL, 5) + +/* + * Intel color control surfaces (CCS) for Gen-12 render compression. + * + * The main surface is Y-tiled and at plane index 0, the CCS is linear and + * at index 1. A 64B CCS cache line corresponds to an area of 4x1 tiles in + * main surface. In other words, 4 bits in CCS map to a main surface cache + * line pair. The main surface pitch is required to be a multiple of four + * Y-tile widths. + */ +#define I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS fourcc_mod_code(INTEL, 6) + +/* + * Intel color control surfaces (CCS) for Gen-12 media compression + * + * The main surface is Y-tiled and at plane index 0, the CCS is linear and + * at index 1. A 64B CCS cache line corresponds to an area of 4x1 tiles in + * main surface. In other words, 4 bits in CCS map to a main surface cache + * line pair. The main surface pitch is required to be a multiple of four + * Y-tile widths. For semi-planar formats like NV12, CCS planes follow the + * Y and UV planes i.e., planes 0 and 1 are used for Y and UV surfaces, + * planes 2 and 3 for the respective CCS. + */ +#define I915_FORMAT_MOD_Y_TILED_GEN12_MC_CCS fourcc_mod_code(INTEL, 7) + +/* + * Intel Color Control Surface with Clear Color (CCS) for Gen-12 render + * compression. + * + * The main surface is Y-tiled and is at plane index 0 whereas CCS is linear + * and at index 1. The clear color is stored at index 2, and the pitch should + * be ignored. The clear color structure is 256 bits. The first 128 bits + * represents Raw Clear Color Red, Green, Blue and Alpha color each represented + * by 32 bits. The raw clear color is consumed by the 3d engine and generates + * the converted clear color of size 64 bits. The first 32 bits store the Lower + * Converted Clear Color value and the next 32 bits store the Higher Converted + * Clear Color value when applicable. The Converted Clear Color values are + * consumed by the DE. The last 64 bits are used to store Color Discard Enable + * and Depth Clear Value Valid which are ignored by the DE. A CCS cache line + * corresponds to an area of 4x1 tiles in the main surface. The main surface + * pitch is required to be a multiple of 4 tile widths. + */ +#define I915_FORMAT_MOD_Y_TILED_GEN12_RC_CCS_CC fourcc_mod_code(INTEL, 8) + /* * Tiled, NV12MT, grouped in 64 (pixels) x 32 (lines) -sized macroblocks * @@ -229,4 +568,798 @@ */ #define DRM_FORMAT_MOD_SAMSUNG_64_32_TILE fourcc_mod_code(SAMSUNG, 1) +/* + * Tiled, 16 (pixels) x 16 (lines) - sized macroblocks + * + * This is a simple tiled layout using tiles of 16x16 pixels in a row-major + * layout. For YCbCr formats Cb/Cr components are taken in such a way that + * they correspond to their 16x16 luma block. + */ +#define DRM_FORMAT_MOD_SAMSUNG_16_16_TILE fourcc_mod_code(SAMSUNG, 2) + +/* + * Qualcomm Compressed Format + * + * Refers to a compressed variant of the base format that is compressed. + * Implementation may be platform and base-format specific. + * + * Each macrotile consists of m x n (mostly 4 x 4) tiles. + * Pixel data pitch/stride is aligned with macrotile width. + * Pixel data height is aligned with macrotile height. + * Entire pixel data buffer is aligned with 4k(bytes). + */ +#define DRM_FORMAT_MOD_QCOM_COMPRESSED fourcc_mod_code(QCOM, 1) + +/* Vivante framebuffer modifiers */ + +/* + * Vivante 4x4 tiling layout + * + * This is a simple tiled layout using tiles of 4x4 pixels in a row-major + * layout. + */ +#define DRM_FORMAT_MOD_VIVANTE_TILED fourcc_mod_code(VIVANTE, 1) + +/* + * Vivante 64x64 super-tiling layout + * + * This is a tiled layout using 64x64 pixel super-tiles, where each super-tile + * contains 8x4 groups of 2x4 tiles of 4x4 pixels (like above) each, all in row- + * major layout. + * + * For more information: see + * https://github.com/etnaviv/etna_viv/blob/master/doc/hardware.md#texture-tiling + */ +#define DRM_FORMAT_MOD_VIVANTE_SUPER_TILED fourcc_mod_code(VIVANTE, 2) + +/* + * Vivante 4x4 tiling layout for dual-pipe + * + * Same as the 4x4 tiling layout, except every second 4x4 pixel tile starts at a + * different base address. Offsets from the base addresses are therefore halved + * compared to the non-split tiled layout. + */ +#define DRM_FORMAT_MOD_VIVANTE_SPLIT_TILED fourcc_mod_code(VIVANTE, 3) + +/* + * Vivante 64x64 super-tiling layout for dual-pipe + * + * Same as the 64x64 super-tiling layout, except every second 4x4 pixel tile + * starts at a different base address. Offsets from the base addresses are + * therefore halved compared to the non-split super-tiled layout. + */ +#define DRM_FORMAT_MOD_VIVANTE_SPLIT_SUPER_TILED fourcc_mod_code(VIVANTE, 4) + +/* NVIDIA frame buffer modifiers */ + +/* + * Tegra Tiled Layout, used by Tegra 2, 3 and 4. + * + * Pixels are arranged in simple tiles of 16 x 16 bytes. + */ +#define DRM_FORMAT_MOD_NVIDIA_TEGRA_TILED fourcc_mod_code(NVIDIA, 1) + +/* + * Generalized Block Linear layout, used by desktop GPUs starting with NV50/G80, + * and Tegra GPUs starting with Tegra K1. + * + * Pixels are arranged in Groups of Bytes (GOBs). GOB size and layout varies + * based on the architecture generation. GOBs themselves are then arranged in + * 3D blocks, with the block dimensions (in terms of GOBs) always being a power + * of two, and hence expressible as their log2 equivalent (E.g., "2" represents + * a block depth or height of "4"). + * + * Chapter 20 "Pixel Memory Formats" of the Tegra X1 TRM describes this format + * in full detail. + * + * Macro + * Bits Param Description + * ---- ----- ----------------------------------------------------------------- + * + * 3:0 h log2(height) of each block, in GOBs. Placed here for + * compatibility with the existing + * DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK()-based modifiers. + * + * 4:4 - Must be 1, to indicate block-linear layout. Necessary for + * compatibility with the existing + * DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK()-based modifiers. + * + * 8:5 - Reserved (To support 3D-surfaces with variable log2(depth) block + * size). Must be zero. + * + * Note there is no log2(width) parameter. Some portions of the + * hardware support a block width of two gobs, but it is impractical + * to use due to lack of support elsewhere, and has no known + * benefits. + * + * 11:9 - Reserved (To support 2D-array textures with variable array stride + * in blocks, specified via log2(tile width in blocks)). Must be + * zero. + * + * 19:12 k Page Kind. This value directly maps to a field in the page + * tables of all GPUs >= NV50. It affects the exact layout of bits + * in memory and can be derived from the tuple + * + * (format, GPU model, compression type, samples per pixel) + * + * Where compression type is defined below. If GPU model were + * implied by the format modifier, format, or memory buffer, page + * kind would not need to be included in the modifier itself, but + * since the modifier should define the layout of the associated + * memory buffer independent from any device or other context, it + * must be included here. + * + * 21:20 g GOB Height and Page Kind Generation. The height of a GOB changed + * starting with Fermi GPUs. Additionally, the mapping between page + * kind and bit layout has changed at various points. + * + * 0 = Gob Height 8, Fermi - Volta, Tegra K1+ Page Kind mapping + * 1 = Gob Height 4, G80 - GT2XX Page Kind mapping + * 2 = Gob Height 8, Turing+ Page Kind mapping + * 3 = Reserved for future use. + * + * 22:22 s Sector layout. On Tegra GPUs prior to Xavier, there is a further + * bit remapping step that occurs at an even lower level than the + * page kind and block linear swizzles. This causes the layout of + * surfaces mapped in those SOC's GPUs to be incompatible with the + * equivalent mapping on other GPUs in the same system. + * + * 0 = Tegra K1 - Tegra Parker/TX2 Layout. + * 1 = Desktop GPU and Tegra Xavier+ Layout + * + * 25:23 c Lossless Framebuffer Compression type. + * + * 0 = none + * 1 = ROP/3D, layout 1, exact compression format implied by Page + * Kind field + * 2 = ROP/3D, layout 2, exact compression format implied by Page + * Kind field + * 3 = CDE horizontal + * 4 = CDE vertical + * 5 = Reserved for future use + * 6 = Reserved for future use + * 7 = Reserved for future use + * + * 55:25 - Reserved for future use. Must be zero. + */ +#define DRM_FORMAT_MOD_NVIDIA_BLOCK_LINEAR_2D(c, s, g, k, h) \ + fourcc_mod_code(NVIDIA, (0x10 | \ + ((h) & 0xf) | \ + (((k) & 0xff) << 12) | \ + (((g) & 0x3) << 20) | \ + (((s) & 0x1) << 22) | \ + (((c) & 0x7) << 23))) + +/* To grandfather in prior block linear format modifiers to the above layout, + * the page kind "0", which corresponds to "pitch/linear" and hence is unusable + * with block-linear layouts, is remapped within drivers to the value 0xfe, + * which corresponds to the "generic" kind used for simple single-sample + * uncompressed color formats on Fermi - Volta GPUs. + */ +static __inline__ __u64 +drm_fourcc_canonicalize_nvidia_format_mod(__u64 modifier) +{ + if (!(modifier & 0x10) || (modifier & (0xff << 12))) + return modifier; + else + return modifier | (0xfe << 12); +} + +/* + * 16Bx2 Block Linear layout, used by Tegra K1 and later + * + * Pixels are arranged in 64x8 Groups Of Bytes (GOBs). GOBs are then stacked + * vertically by a power of 2 (1 to 32 GOBs) to form a block. + * + * Within a GOB, data is ordered as 16B x 2 lines sectors laid in Z-shape. + * + * Parameter 'v' is the log2 encoding of the number of GOBs stacked vertically. + * Valid values are: + * + * 0 == ONE_GOB + * 1 == TWO_GOBS + * 2 == FOUR_GOBS + * 3 == EIGHT_GOBS + * 4 == SIXTEEN_GOBS + * 5 == THIRTYTWO_GOBS + * + * Chapter 20 "Pixel Memory Formats" of the Tegra X1 TRM describes this format + * in full detail. + */ +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(v) \ + DRM_FORMAT_MOD_NVIDIA_BLOCK_LINEAR_2D(0, 0, 0, 0, (v)) + +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_ONE_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(0) +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_TWO_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(1) +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_FOUR_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(2) +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_EIGHT_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(3) +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_SIXTEEN_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(4) +#define DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK_THIRTYTWO_GOB \ + DRM_FORMAT_MOD_NVIDIA_16BX2_BLOCK(5) + +/* + * Some Broadcom modifiers take parameters, for example the number of + * vertical lines in the image. Reserve the lower 32 bits for modifier + * type, and the next 24 bits for parameters. Top 8 bits are the + * vendor code. + */ +#define __fourcc_mod_broadcom_param_shift 8 +#define __fourcc_mod_broadcom_param_bits 48 +#define fourcc_mod_broadcom_code(val, params) \ + fourcc_mod_code(BROADCOM, ((((__u64)params) << __fourcc_mod_broadcom_param_shift) | val)) +#define fourcc_mod_broadcom_param(m) \ + ((int)(((m) >> __fourcc_mod_broadcom_param_shift) & \ + ((1ULL << __fourcc_mod_broadcom_param_bits) - 1))) +#define fourcc_mod_broadcom_mod(m) \ + ((m) & ~(((1ULL << __fourcc_mod_broadcom_param_bits) - 1) << \ + __fourcc_mod_broadcom_param_shift)) + +/* + * Broadcom VC4 "T" format + * + * This is the primary layout that the V3D GPU can texture from (it + * can't do linear). The T format has: + * + * - 64b utiles of pixels in a raster-order grid according to cpp. It's 4x4 + * pixels at 32 bit depth. + * + * - 1k subtiles made of a 4x4 raster-order grid of 64b utiles (so usually + * 16x16 pixels). + * + * - 4k tiles made of a 2x2 grid of 1k subtiles (so usually 32x32 pixels). On + * even 4k tile rows, they're arranged as (BL, TL, TR, BR), and on odd rows + * they're (TR, BR, BL, TL), where bottom left is start of memory. + * + * - an image made of 4k tiles in rows either left-to-right (even rows of 4k + * tiles) or right-to-left (odd rows of 4k tiles). + */ +#define DRM_FORMAT_MOD_BROADCOM_VC4_T_TILED fourcc_mod_code(BROADCOM, 1) + +/* + * Broadcom SAND format + * + * This is the native format that the H.264 codec block uses. For VC4 + * HVS, it is only valid for H.264 (NV12/21) and RGBA modes. + * + * The image can be considered to be split into columns, and the + * columns are placed consecutively into memory. The width of those + * columns can be either 32, 64, 128, or 256 pixels, but in practice + * only 128 pixel columns are used. + * + * The pitch between the start of each column is set to optimally + * switch between SDRAM banks. This is passed as the number of lines + * of column width in the modifier (we can't use the stride value due + * to various core checks that look at it , so you should set the + * stride to width*cpp). + * + * Note that the column height for this format modifier is the same + * for all of the planes, assuming that each column contains both Y + * and UV. Some SAND-using hardware stores UV in a separate tiled + * image from Y to reduce the column height, which is not supported + * with these modifiers. + */ + +#define DRM_FORMAT_MOD_BROADCOM_SAND32_COL_HEIGHT(v) \ + fourcc_mod_broadcom_code(2, v) +#define DRM_FORMAT_MOD_BROADCOM_SAND64_COL_HEIGHT(v) \ + fourcc_mod_broadcom_code(3, v) +#define DRM_FORMAT_MOD_BROADCOM_SAND128_COL_HEIGHT(v) \ + fourcc_mod_broadcom_code(4, v) +#define DRM_FORMAT_MOD_BROADCOM_SAND256_COL_HEIGHT(v) \ + fourcc_mod_broadcom_code(5, v) + +#define DRM_FORMAT_MOD_BROADCOM_SAND32 \ + DRM_FORMAT_MOD_BROADCOM_SAND32_COL_HEIGHT(0) +#define DRM_FORMAT_MOD_BROADCOM_SAND64 \ + DRM_FORMAT_MOD_BROADCOM_SAND64_COL_HEIGHT(0) +#define DRM_FORMAT_MOD_BROADCOM_SAND128 \ + DRM_FORMAT_MOD_BROADCOM_SAND128_COL_HEIGHT(0) +#define DRM_FORMAT_MOD_BROADCOM_SAND256 \ + DRM_FORMAT_MOD_BROADCOM_SAND256_COL_HEIGHT(0) + +/* Broadcom UIF format + * + * This is the common format for the current Broadcom multimedia + * blocks, including V3D 3.x and newer, newer video codecs, and + * displays. + * + * The image consists of utiles (64b blocks), UIF blocks (2x2 utiles), + * and macroblocks (4x4 UIF blocks). Those 4x4 UIF block groups are + * stored in columns, with padding between the columns to ensure that + * moving from one column to the next doesn't hit the same SDRAM page + * bank. + * + * To calculate the padding, it is assumed that each hardware block + * and the software driving it knows the platform's SDRAM page size, + * number of banks, and XOR address, and that it's identical between + * all blocks using the format. This tiling modifier will use XOR as + * necessary to reduce the padding. If a hardware block can't do XOR, + * the assumption is that a no-XOR tiling modifier will be created. + */ +#define DRM_FORMAT_MOD_BROADCOM_UIF fourcc_mod_code(BROADCOM, 6) + +/* + * Arm Framebuffer Compression (AFBC) modifiers + * + * AFBC is a proprietary lossless image compression protocol and format. + * It provides fine-grained random access and minimizes the amount of data + * transferred between IP blocks. + * + * AFBC has several features which may be supported and/or used, which are + * represented using bits in the modifier. Not all combinations are valid, + * and different devices or use-cases may support different combinations. + * + * Further information on the use of AFBC modifiers can be found in + * Documentation/gpu/afbc.rst + */ + +/* + * The top 4 bits (out of the 56 bits alloted for specifying vendor specific + * modifiers) denote the category for modifiers. Currently we have three + * categories of modifiers ie AFBC, MISC and AFRC. We can have a maximum of + * sixteen different categories. + */ +#define DRM_FORMAT_MOD_ARM_CODE(__type, __val) \ + fourcc_mod_code(ARM, ((__u64)(__type) << 52) | ((__val) & 0x000fffffffffffffULL)) + +#define DRM_FORMAT_MOD_ARM_TYPE_AFBC 0x00 +#define DRM_FORMAT_MOD_ARM_TYPE_MISC 0x01 + +#define DRM_FORMAT_MOD_ARM_AFBC(__afbc_mode) \ + DRM_FORMAT_MOD_ARM_CODE(DRM_FORMAT_MOD_ARM_TYPE_AFBC, __afbc_mode) + +/* + * AFBC superblock size + * + * Indicates the superblock size(s) used for the AFBC buffer. The buffer + * size (in pixels) must be aligned to a multiple of the superblock size. + * Four lowest significant bits(LSBs) are reserved for block size. + * + * Where one superblock size is specified, it applies to all planes of the + * buffer (e.g. 16x16, 32x8). When multiple superblock sizes are specified, + * the first applies to the Luma plane and the second applies to the Chroma + * plane(s). e.g. (32x8_64x4 means 32x8 Luma, with 64x4 Chroma). + * Multiple superblock sizes are only valid for multi-plane YCbCr formats. + */ +#define AFBC_FORMAT_MOD_BLOCK_SIZE_MASK 0xf +#define AFBC_FORMAT_MOD_BLOCK_SIZE_16x16 (1ULL) +#define AFBC_FORMAT_MOD_BLOCK_SIZE_32x8 (2ULL) +#define AFBC_FORMAT_MOD_BLOCK_SIZE_64x4 (3ULL) +#define AFBC_FORMAT_MOD_BLOCK_SIZE_32x8_64x4 (4ULL) + +/* + * AFBC lossless colorspace transform + * + * Indicates that the buffer makes use of the AFBC lossless colorspace + * transform. + */ +#define AFBC_FORMAT_MOD_YTR (1ULL << 4) + +/* + * AFBC block-split + * + * Indicates that the payload of each superblock is split. The second + * half of the payload is positioned at a predefined offset from the start + * of the superblock payload. + */ +#define AFBC_FORMAT_MOD_SPLIT (1ULL << 5) + +/* + * AFBC sparse layout + * + * This flag indicates that the payload of each superblock must be stored at a + * predefined position relative to the other superblocks in the same AFBC + * buffer. This order is the same order used by the header buffer. In this mode + * each superblock is given the same amount of space as an uncompressed + * superblock of the particular format would require, rounding up to the next + * multiple of 128 bytes in size. + */ +#define AFBC_FORMAT_MOD_SPARSE (1ULL << 6) + +/* + * AFBC copy-block restrict + * + * Buffers with this flag must obey the copy-block restriction. The restriction + * is such that there are no copy-blocks referring across the border of 8x8 + * blocks. For the subsampled data the 8x8 limitation is also subsampled. + */ +#define AFBC_FORMAT_MOD_CBR (1ULL << 7) + +/* + * AFBC tiled layout + * + * The tiled layout groups superblocks in 8x8 or 4x4 tiles, where all + * superblocks inside a tile are stored together in memory. 8x8 tiles are used + * for pixel formats up to and including 32 bpp while 4x4 tiles are used for + * larger bpp formats. The order between the tiles is scan line. + * When the tiled layout is used, the buffer size (in pixels) must be aligned + * to the tile size. + */ +#define AFBC_FORMAT_MOD_TILED (1ULL << 8) + +/* + * AFBC solid color blocks + * + * Indicates that the buffer makes use of solid-color blocks, whereby bandwidth + * can be reduced if a whole superblock is a single color. + */ +#define AFBC_FORMAT_MOD_SC (1ULL << 9) + +/* + * AFBC double-buffer + * + * Indicates that the buffer is allocated in a layout safe for front-buffer + * rendering. + */ +#define AFBC_FORMAT_MOD_DB (1ULL << 10) + +/* + * AFBC buffer content hints + * + * Indicates that the buffer includes per-superblock content hints. + */ +#define AFBC_FORMAT_MOD_BCH (1ULL << 11) + +/* AFBC uncompressed storage mode + * + * Indicates that the buffer is using AFBC uncompressed storage mode. + * In this mode all superblock payloads in the buffer use the uncompressed + * storage mode, which is usually only used for data which cannot be compressed. + * The buffer layout is the same as for AFBC buffers without USM set, this only + * affects the storage mode of the individual superblocks. Note that even a + * buffer without USM set may use uncompressed storage mode for some or all + * superblocks, USM just guarantees it for all. + */ +#define AFBC_FORMAT_MOD_USM (1ULL << 12) + +/* + * Arm Fixed-Rate Compression (AFRC) modifiers + * + * AFRC is a proprietary fixed rate image compression protocol and format, + * designed to provide guaranteed bandwidth and memory footprint + * reductions in graphics and media use-cases. + * + * AFRC buffers consist of one or more planes, with the same components + * and meaning as an uncompressed buffer using the same pixel format. + * + * Within each plane, the pixel/luma/chroma values are grouped into + * "coding unit" blocks which are individually compressed to a + * fixed size (in bytes). All coding units within a given plane of a buffer + * store the same number of values, and have the same compressed size. + * + * The coding unit size is configurable, allowing different rates of compression. + * + * The start of each AFRC buffer plane must be aligned to an alignment granule which + * depends on the coding unit size. + * + * Coding Unit Size Plane Alignment + * ---------------- --------------- + * 16 bytes 1024 bytes + * 24 bytes 512 bytes + * 32 bytes 2048 bytes + * + * Coding units are grouped into paging tiles. AFRC buffer dimensions must be aligned + * to a multiple of the paging tile dimensions. + * The dimensions of each paging tile depend on whether the buffer is optimised for + * scanline (SCAN layout) or rotated (ROT layout) access. + * + * Layout Paging Tile Width Paging Tile Height + * ------ ----------------- ------------------ + * SCAN 16 coding units 4 coding units + * ROT 8 coding units 8 coding units + * + * The dimensions of each coding unit depend on the number of components + * in the compressed plane and whether the buffer is optimised for + * scanline (SCAN layout) or rotated (ROT layout) access. + * + * Number of Components in Plane Layout Coding Unit Width Coding Unit Height + * ----------------------------- --------- ----------------- ------------------ + * 1 SCAN 16 samples 4 samples + * Example: 16x4 luma samples in a 'Y' plane + * 16x4 chroma 'V' values, in the 'V' plane of a fully-planar YUV buffer + * ----------------------------- --------- ----------------- ------------------ + * 1 ROT 8 samples 8 samples + * Example: 8x8 luma samples in a 'Y' plane + * 8x8 chroma 'V' values, in the 'V' plane of a fully-planar YUV buffer + * ----------------------------- --------- ----------------- ------------------ + * 2 DONT CARE 8 samples 4 samples + * Example: 8x4 chroma pairs in the 'UV' plane of a semi-planar YUV buffer + * ----------------------------- --------- ----------------- ------------------ + * 3 DONT CARE 4 samples 4 samples + * Example: 4x4 pixels in an RGB buffer without alpha + * ----------------------------- --------- ----------------- ------------------ + * 4 DONT CARE 4 samples 4 samples + * Example: 4x4 pixels in an RGB buffer with alpha + */ + +#define DRM_FORMAT_MOD_ARM_TYPE_AFRC 0x02 + +#define DRM_FORMAT_MOD_ARM_AFRC(__afrc_mode) \ + DRM_FORMAT_MOD_ARM_CODE(DRM_FORMAT_MOD_ARM_TYPE_AFRC, __afrc_mode) + +/* + * AFRC coding unit size modifier. + * + * Indicates the number of bytes used to store each compressed coding unit for + * one or more planes in an AFRC encoded buffer. The coding unit size for chrominance + * is the same for both Cb and Cr, which may be stored in separate planes. + * + * AFRC_FORMAT_MOD_CU_SIZE_P0 indicates the number of bytes used to store + * each compressed coding unit in the first plane of the buffer. For RGBA buffers + * this is the only plane, while for semi-planar and fully-planar YUV buffers, + * this corresponds to the luma plane. + * + * AFRC_FORMAT_MOD_CU_SIZE_P12 indicates the number of bytes used to store + * each compressed coding unit in the second and third planes in the buffer. + * For semi-planar and fully-planar YUV buffers, this corresponds to the chroma plane(s). + * + * For single-plane buffers, AFRC_FORMAT_MOD_CU_SIZE_P0 must be specified + * and AFRC_FORMAT_MOD_CU_SIZE_P12 must be zero. + * For semi-planar and fully-planar buffers, both AFRC_FORMAT_MOD_CU_SIZE_P0 and + * AFRC_FORMAT_MOD_CU_SIZE_P12 must be specified. + */ +#define AFRC_FORMAT_MOD_CU_SIZE_MASK 0xf +#define AFRC_FORMAT_MOD_CU_SIZE_16 (1ULL) +#define AFRC_FORMAT_MOD_CU_SIZE_24 (2ULL) +#define AFRC_FORMAT_MOD_CU_SIZE_32 (3ULL) + +#define AFRC_FORMAT_MOD_CU_SIZE_P0(__afrc_cu_size) (__afrc_cu_size) +#define AFRC_FORMAT_MOD_CU_SIZE_P12(__afrc_cu_size) ((__afrc_cu_size) << 4) + +/* + * AFRC scanline memory layout. + * + * Indicates if the buffer uses the scanline-optimised layout + * for an AFRC encoded buffer, otherwise, it uses the rotation-optimised layout. + * The memory layout is the same for all planes. + */ +#define AFRC_FORMAT_MOD_LAYOUT_SCAN (1ULL << 8) + +/* + * Arm 16x16 Block U-Interleaved modifier + * + * This is used by Arm Mali Utgard and Midgard GPUs. It divides the image + * into 16x16 pixel blocks. Blocks are stored linearly in order, but pixels + * in the block are reordered. + */ +#define DRM_FORMAT_MOD_ARM_16X16_BLOCK_U_INTERLEAVED \ + DRM_FORMAT_MOD_ARM_CODE(DRM_FORMAT_MOD_ARM_TYPE_MISC, 1ULL) + +/* + * Allwinner tiled modifier + * + * This tiling mode is implemented by the VPU found on all Allwinner platforms, + * codenamed sunxi. It is associated with a YUV format that uses either 2 or 3 + * planes. + * + * With this tiling, the luminance samples are disposed in tiles representing + * 32x32 pixels and the chrominance samples in tiles representing 32x64 pixels. + * The pixel order in each tile is linear and the tiles are disposed linearly, + * both in row-major order. + */ +#define DRM_FORMAT_MOD_ALLWINNER_TILED fourcc_mod_code(ALLWINNER, 1) + +/* + * Amlogic Video Framebuffer Compression modifiers + * + * Amlogic uses a proprietary lossless image compression protocol and format + * for their hardware video codec accelerators, either video decoders or + * video input encoders. + * + * It considerably reduces memory bandwidth while writing and reading + * frames in memory. + * + * The underlying storage is considered to be 3 components, 8bit or 10-bit + * per component YCbCr 420, single plane : + * - DRM_FORMAT_YUV420_8BIT + * - DRM_FORMAT_YUV420_10BIT + * + * The first 8 bits of the mode defines the layout, then the following 8 bits + * defines the options changing the layout. + * + * Not all combinations are valid, and different SoCs may support different + * combinations of layout and options. + */ +#define __fourcc_mod_amlogic_layout_mask 0xff +#define __fourcc_mod_amlogic_options_shift 8 +#define __fourcc_mod_amlogic_options_mask 0xff + +#define DRM_FORMAT_MOD_AMLOGIC_FBC(__layout, __options) \ + fourcc_mod_code(AMLOGIC, \ + ((__layout) & __fourcc_mod_amlogic_layout_mask) | \ + (((__options) & __fourcc_mod_amlogic_options_mask) \ + << __fourcc_mod_amlogic_options_shift)) + +/* Amlogic FBC Layouts */ + +/* + * Amlogic FBC Basic Layout + * + * The basic layout is composed of: + * - a body content organized in 64x32 superblocks with 4096 bytes per + * superblock in default mode. + * - a 32 bytes per 128x64 header block + * + * This layout is transferrable between Amlogic SoCs supporting this modifier. + */ +#define AMLOGIC_FBC_LAYOUT_BASIC (1ULL) + +/* + * Amlogic FBC Scatter Memory layout + * + * Indicates the header contains IOMMU references to the compressed + * frames content to optimize memory access and layout. + * + * In this mode, only the header memory address is needed, thus the + * content memory organization is tied to the current producer + * execution and cannot be saved/dumped neither transferrable between + * Amlogic SoCs supporting this modifier. + * + * Due to the nature of the layout, these buffers are not expected to + * be accessible by the user-space clients, but only accessible by the + * hardware producers and consumers. + * + * The user-space clients should expect a failure while trying to mmap + * the DMA-BUF handle returned by the producer. + */ +#define AMLOGIC_FBC_LAYOUT_SCATTER (2ULL) + +/* Amlogic FBC Layout Options Bit Mask */ + +/* + * Amlogic FBC Memory Saving mode + * + * Indicates the storage is packed when pixel size is multiple of word + * boudaries, i.e. 8bit should be stored in this mode to save allocation + * memory. + * + * This mode reduces body layout to 3072 bytes per 64x32 superblock with + * the basic layout and 3200 bytes per 64x32 superblock combined with + * the scatter layout. + */ +#define AMLOGIC_FBC_OPTION_MEM_SAVING (1ULL << 0) + +/* + * AMD modifiers + * + * Memory layout: + * + * without DCC: + * - main surface + * + * with DCC & without DCC_RETILE: + * - main surface in plane 0 + * - DCC surface in plane 1 (RB-aligned, pipe-aligned if DCC_PIPE_ALIGN is set) + * + * with DCC & DCC_RETILE: + * - main surface in plane 0 + * - displayable DCC surface in plane 1 (not RB-aligned & not pipe-aligned) + * - pipe-aligned DCC surface in plane 2 (RB-aligned & pipe-aligned) + * + * For multi-plane formats the above surfaces get merged into one plane for + * each format plane, based on the required alignment only. + * + * Bits Parameter Notes + * ----- ------------------------ --------------------------------------------- + * + * 7:0 TILE_VERSION Values are AMD_FMT_MOD_TILE_VER_* + * 12:8 TILE Values are AMD_FMT_MOD_TILE__* + * 13 DCC + * 14 DCC_RETILE + * 15 DCC_PIPE_ALIGN + * 16 DCC_INDEPENDENT_64B + * 17 DCC_INDEPENDENT_128B + * 19:18 DCC_MAX_COMPRESSED_BLOCK Values are AMD_FMT_MOD_DCC_BLOCK_* + * 20 DCC_CONSTANT_ENCODE + * 23:21 PIPE_XOR_BITS Only for some chips + * 26:24 BANK_XOR_BITS Only for some chips + * 29:27 PACKERS Only for some chips + * 32:30 RB Only for some chips + * 35:33 PIPE Only for some chips + * 55:36 - Reserved for future use, must be zero + */ +#define AMD_FMT_MOD fourcc_mod_code(AMD, 0) + +#define IS_AMD_FMT_MOD(val) (((val) >> 56) == DRM_FORMAT_MOD_VENDOR_AMD) + +/* Reserve 0 for GFX8 and older */ +#define AMD_FMT_MOD_TILE_VER_GFX9 1 +#define AMD_FMT_MOD_TILE_VER_GFX10 2 +#define AMD_FMT_MOD_TILE_VER_GFX10_RBPLUS 3 + +/* + * 64K_S is the same for GFX9/GFX10/GFX10_RBPLUS and hence has GFX9 as canonical + * version. + */ +#define AMD_FMT_MOD_TILE_GFX9_64K_S 9 + +/* + * 64K_D for non-32 bpp is the same for GFX9/GFX10/GFX10_RBPLUS and hence has + * GFX9 as canonical version. + */ +#define AMD_FMT_MOD_TILE_GFX9_64K_D 10 +#define AMD_FMT_MOD_TILE_GFX9_64K_S_X 25 +#define AMD_FMT_MOD_TILE_GFX9_64K_D_X 26 +#define AMD_FMT_MOD_TILE_GFX9_64K_R_X 27 + +#define AMD_FMT_MOD_DCC_BLOCK_64B 0 +#define AMD_FMT_MOD_DCC_BLOCK_128B 1 +#define AMD_FMT_MOD_DCC_BLOCK_256B 2 + +#define AMD_FMT_MOD_TILE_VERSION_SHIFT 0 +#define AMD_FMT_MOD_TILE_VERSION_MASK 0xFF +#define AMD_FMT_MOD_TILE_SHIFT 8 +#define AMD_FMT_MOD_TILE_MASK 0x1F + +/* Whether DCC compression is enabled. */ +#define AMD_FMT_MOD_DCC_SHIFT 13 +#define AMD_FMT_MOD_DCC_MASK 0x1 + +/* + * Whether to include two DCC surfaces, one which is rb & pipe aligned, and + * one which is not-aligned. + */ +#define AMD_FMT_MOD_DCC_RETILE_SHIFT 14 +#define AMD_FMT_MOD_DCC_RETILE_MASK 0x1 + +/* Only set if DCC_RETILE = false */ +#define AMD_FMT_MOD_DCC_PIPE_ALIGN_SHIFT 15 +#define AMD_FMT_MOD_DCC_PIPE_ALIGN_MASK 0x1 + +#define AMD_FMT_MOD_DCC_INDEPENDENT_64B_SHIFT 16 +#define AMD_FMT_MOD_DCC_INDEPENDENT_64B_MASK 0x1 +#define AMD_FMT_MOD_DCC_INDEPENDENT_128B_SHIFT 17 +#define AMD_FMT_MOD_DCC_INDEPENDENT_128B_MASK 0x1 +#define AMD_FMT_MOD_DCC_MAX_COMPRESSED_BLOCK_SHIFT 18 +#define AMD_FMT_MOD_DCC_MAX_COMPRESSED_BLOCK_MASK 0x3 + +/* + * DCC supports embedding some clear colors directly in the DCC surface. + * However, on older GPUs the rendering HW ignores the embedded clear color + * and prefers the driver provided color. This necessitates doing a fastclear + * eliminate operation before a process transfers control. + * + * If this bit is set that means the fastclear eliminate is not needed for these + * embeddable colors. + */ +#define AMD_FMT_MOD_DCC_CONSTANT_ENCODE_SHIFT 20 +#define AMD_FMT_MOD_DCC_CONSTANT_ENCODE_MASK 0x1 + +/* + * The below fields are for accounting for per GPU differences. These are only + * relevant for GFX9 and later and if the tile field is *_X/_T. + * + * PIPE_XOR_BITS = always needed + * BANK_XOR_BITS = only for TILE_VER_GFX9 + * PACKERS = only for TILE_VER_GFX10_RBPLUS + * RB = only for TILE_VER_GFX9 & DCC + * PIPE = only for TILE_VER_GFX9 & DCC & (DCC_RETILE | DCC_PIPE_ALIGN) + */ +#define AMD_FMT_MOD_PIPE_XOR_BITS_SHIFT 21 +#define AMD_FMT_MOD_PIPE_XOR_BITS_MASK 0x7 +#define AMD_FMT_MOD_BANK_XOR_BITS_SHIFT 24 +#define AMD_FMT_MOD_BANK_XOR_BITS_MASK 0x7 +#define AMD_FMT_MOD_PACKERS_SHIFT 27 +#define AMD_FMT_MOD_PACKERS_MASK 0x7 +#define AMD_FMT_MOD_RB_SHIFT 30 +#define AMD_FMT_MOD_RB_MASK 0x7 +#define AMD_FMT_MOD_PIPE_SHIFT 33 +#define AMD_FMT_MOD_PIPE_MASK 0x7 + +#define AMD_FMT_MOD_SET(field, value) \ + ((uint64_t)(value) << AMD_FMT_MOD_##field##_SHIFT) +#define AMD_FMT_MOD_GET(field, value) \ + (((value) >> AMD_FMT_MOD_##field##_SHIFT) & AMD_FMT_MOD_##field##_MASK) +#define AMD_FMT_MOD_CLEAR(field) \ + (~((uint64_t)AMD_FMT_MOD_##field##_MASK << AMD_FMT_MOD_##field##_SHIFT)) + +#if defined(__cplusplus) +} +#endif + #endif /* DRM_FOURCC_H */ diff --git a/usr/src/uts/common/drm/drm_mode.h b/usr/src/uts/common/drm/drm_mode.h index df0e3504..9b6722d4 100644 --- a/usr/src/uts/common/drm/drm_mode.h +++ b/usr/src/uts/common/drm/drm_mode.h @@ -33,21 +33,41 @@ extern "C" { #endif -#define DRM_DISPLAY_INFO_LEN 32 +/** + * DOC: overview + * + * DRM exposes many UAPI and structure definition to have a consistent + * and standardized interface with user. + * Userspace can refer to these structure definitions and UAPI formats + * to communicate to driver + */ + #define DRM_CONNECTOR_NAME_LEN 32 #define DRM_DISPLAY_MODE_LEN 32 #define DRM_PROP_NAME_LEN 32 -#define DRM_MODE_TYPE_BUILTIN (1<<0) -#define DRM_MODE_TYPE_CLOCK_C ((1<<1) | DRM_MODE_TYPE_BUILTIN) -#define DRM_MODE_TYPE_CRTC_C ((1<<2) | DRM_MODE_TYPE_BUILTIN) +#define DRM_MODE_TYPE_BUILTIN (1<<0) /* deprecated */ +#define DRM_MODE_TYPE_CLOCK_C ((1<<1) | DRM_MODE_TYPE_BUILTIN) /* deprecated */ +#define DRM_MODE_TYPE_CRTC_C ((1<<2) | DRM_MODE_TYPE_BUILTIN) /* deprecated */ #define DRM_MODE_TYPE_PREFERRED (1<<3) -#define DRM_MODE_TYPE_DEFAULT (1<<4) +#define DRM_MODE_TYPE_DEFAULT (1<<4) /* deprecated */ #define DRM_MODE_TYPE_USERDEF (1<<5) #define DRM_MODE_TYPE_DRIVER (1<<6) +#define DRM_MODE_TYPE_ALL (DRM_MODE_TYPE_PREFERRED | \ + DRM_MODE_TYPE_USERDEF | \ + DRM_MODE_TYPE_DRIVER) + /* Video mode flags */ -/* bit compatible with the xorg definitions. */ +/* bit compatible with the xrandr RR_ definitions (bits 0-13) + * + * ABI warning: Existing userspace really expects + * the mode flags to match the xrandr definitions. Any + * changes that don't match the xrandr definitions will + * likely need a new client cap or some other mechanism + * to avoid breaking existing userspace. This includes + * allocating new flags in the previously unused bits! + */ #define DRM_MODE_FLAG_PHSYNC (1<<0) #define DRM_MODE_FLAG_NHSYNC (1<<1) #define DRM_MODE_FLAG_PVSYNC (1<<2) @@ -58,8 +78,8 @@ extern "C" { #define DRM_MODE_FLAG_PCSYNC (1<<7) #define DRM_MODE_FLAG_NCSYNC (1<<8) #define DRM_MODE_FLAG_HSKEW (1<<9) /* hskew provided */ -#define DRM_MODE_FLAG_BCAST (1<<10) -#define DRM_MODE_FLAG_PIXMUX (1<<11) +#define DRM_MODE_FLAG_BCAST (1<<10) /* deprecated */ +#define DRM_MODE_FLAG_PIXMUX (1<<11) /* deprecated */ #define DRM_MODE_FLAG_DBLCLK (1<<12) #define DRM_MODE_FLAG_CLKDIV2 (1<<13) /* @@ -67,7 +87,7 @@ extern "C" { * (define not exposed to user space). */ #define DRM_MODE_FLAG_3D_MASK (0x1f<<14) -#define DRM_MODE_FLAG_3D_NONE (0<<14) +#define DRM_MODE_FLAG_3D_NONE (0<<14) #define DRM_MODE_FLAG_3D_FRAME_PACKING (1<<14) #define DRM_MODE_FLAG_3D_FIELD_ALTERNATIVE (2<<14) #define DRM_MODE_FLAG_3D_LINE_ALTERNATIVE (3<<14) @@ -77,6 +97,46 @@ extern "C" { #define DRM_MODE_FLAG_3D_TOP_AND_BOTTOM (7<<14) #define DRM_MODE_FLAG_3D_SIDE_BY_SIDE_HALF (8<<14) +/* Picture aspect ratio options */ +#define DRM_MODE_PICTURE_ASPECT_NONE 0 +#define DRM_MODE_PICTURE_ASPECT_4_3 1 +#define DRM_MODE_PICTURE_ASPECT_16_9 2 +#define DRM_MODE_PICTURE_ASPECT_64_27 3 +#define DRM_MODE_PICTURE_ASPECT_256_135 4 + +/* Content type options */ +#define DRM_MODE_CONTENT_TYPE_NO_DATA 0 +#define DRM_MODE_CONTENT_TYPE_GRAPHICS 1 +#define DRM_MODE_CONTENT_TYPE_PHOTO 2 +#define DRM_MODE_CONTENT_TYPE_CINEMA 3 +#define DRM_MODE_CONTENT_TYPE_GAME 4 + +/* Aspect ratio flag bitmask (4 bits 22:19) */ +#define DRM_MODE_FLAG_PIC_AR_MASK (0x0F<<19) +#define DRM_MODE_FLAG_PIC_AR_NONE \ + (DRM_MODE_PICTURE_ASPECT_NONE<<19) +#define DRM_MODE_FLAG_PIC_AR_4_3 \ + (DRM_MODE_PICTURE_ASPECT_4_3<<19) +#define DRM_MODE_FLAG_PIC_AR_16_9 \ + (DRM_MODE_PICTURE_ASPECT_16_9<<19) +#define DRM_MODE_FLAG_PIC_AR_64_27 \ + (DRM_MODE_PICTURE_ASPECT_64_27<<19) +#define DRM_MODE_FLAG_PIC_AR_256_135 \ + (DRM_MODE_PICTURE_ASPECT_256_135<<19) + +#define DRM_MODE_FLAG_ALL (DRM_MODE_FLAG_PHSYNC | \ + DRM_MODE_FLAG_NHSYNC | \ + DRM_MODE_FLAG_PVSYNC | \ + DRM_MODE_FLAG_NVSYNC | \ + DRM_MODE_FLAG_INTERLACE | \ + DRM_MODE_FLAG_DBLSCAN | \ + DRM_MODE_FLAG_CSYNC | \ + DRM_MODE_FLAG_PCSYNC | \ + DRM_MODE_FLAG_NCSYNC | \ + DRM_MODE_FLAG_HSKEW | \ + DRM_MODE_FLAG_DBLCLK | \ + DRM_MODE_FLAG_CLKDIV2 | \ + DRM_MODE_FLAG_3D_MASK) /* DPMS flags */ /* bit compatible with the xorg definitions. */ @@ -92,11 +152,6 @@ extern "C" { #define DRM_MODE_SCALE_CENTER 2 /* Centered, no scaling */ #define DRM_MODE_SCALE_ASPECT 3 /* Full screen, preserve aspect */ -/* Picture aspect ratio options */ -#define DRM_MODE_PICTURE_ASPECT_NONE 0 -#define DRM_MODE_PICTURE_ASPECT_4_3 1 -#define DRM_MODE_PICTURE_ASPECT_16_9 2 - /* Dithering mode options */ #define DRM_MODE_DITHERING_OFF 0 #define DRM_MODE_DITHERING_ON 1 @@ -107,6 +162,83 @@ extern "C" { #define DRM_MODE_DIRTY_ON 1 #define DRM_MODE_DIRTY_ANNOTATE 2 +/* Link Status options */ +#define DRM_MODE_LINK_STATUS_GOOD 0 +#define DRM_MODE_LINK_STATUS_BAD 1 + +/* + * DRM_MODE_ROTATE_ + * + * Signals that a drm plane is been rotated degrees in counter + * clockwise direction. + * + * This define is provided as a convenience, looking up the property id + * using the name->prop id lookup is the preferred method. + */ +#define DRM_MODE_ROTATE_0 (1<<0) +#define DRM_MODE_ROTATE_90 (1<<1) +#define DRM_MODE_ROTATE_180 (1<<2) +#define DRM_MODE_ROTATE_270 (1<<3) + +/* + * DRM_MODE_ROTATE_MASK + * + * Bitmask used to look for drm plane rotations. + */ +#define DRM_MODE_ROTATE_MASK (\ + DRM_MODE_ROTATE_0 | \ + DRM_MODE_ROTATE_90 | \ + DRM_MODE_ROTATE_180 | \ + DRM_MODE_ROTATE_270) + +/* + * DRM_MODE_REFLECT_ + * + * Signals that the contents of a drm plane is reflected along the axis, + * in the same way as mirroring. + * See kerneldoc chapter "Plane Composition Properties" for more details. + * + * This define is provided as a convenience, looking up the property id + * using the name->prop id lookup is the preferred method. + */ +#define DRM_MODE_REFLECT_X (1<<4) +#define DRM_MODE_REFLECT_Y (1<<5) + +/* + * DRM_MODE_REFLECT_MASK + * + * Bitmask used to look for drm plane reflections. + */ +#define DRM_MODE_REFLECT_MASK (\ + DRM_MODE_REFLECT_X | \ + DRM_MODE_REFLECT_Y) + +/* Content Protection Flags */ +#define DRM_MODE_CONTENT_PROTECTION_UNDESIRED 0 +#define DRM_MODE_CONTENT_PROTECTION_DESIRED 1 +#define DRM_MODE_CONTENT_PROTECTION_ENABLED 2 + +/** + * struct drm_mode_modeinfo - Display mode information. + * @clock: pixel clock in kHz + * @hdisplay: horizontal display size + * @hsync_start: horizontal sync start + * @hsync_end: horizontal sync end + * @htotal: horizontal total size + * @hskew: horizontal skew + * @vdisplay: vertical display size + * @vsync_start: vertical sync start + * @vsync_end: vertical sync end + * @vtotal: vertical total size + * @vscan: vertical scan + * @vrefresh: approximate vertical refresh rate in Hz + * @flags: bitmask of misc. flags, see DRM_MODE_FLAG_* defines + * @type: bitmask of type flags, see DRM_MODE_TYPE_* defines + * @name: string describing the mode resolution + * + * This is the user-space API display mode information structure. For the + * kernel version see struct drm_display_mode. + */ struct drm_mode_modeinfo { __u32 clock; __u16 hdisplay; @@ -220,14 +352,21 @@ struct drm_mode_get_encoder { /* This is for connectors with multiple signal types. */ /* Try to match DRM_MODE_CONNECTOR_X as closely as possible. */ -#define DRM_MODE_SUBCONNECTOR_Automatic 0 -#define DRM_MODE_SUBCONNECTOR_Unknown 0 -#define DRM_MODE_SUBCONNECTOR_DVID 3 -#define DRM_MODE_SUBCONNECTOR_DVIA 4 -#define DRM_MODE_SUBCONNECTOR_Composite 5 -#define DRM_MODE_SUBCONNECTOR_SVIDEO 6 -#define DRM_MODE_SUBCONNECTOR_Component 8 -#define DRM_MODE_SUBCONNECTOR_SCART 9 +enum drm_mode_subconnector { + DRM_MODE_SUBCONNECTOR_Automatic = 0, /* DVI-I, TV */ + DRM_MODE_SUBCONNECTOR_Unknown = 0, /* DVI-I, TV, DP */ + DRM_MODE_SUBCONNECTOR_VGA = 1, /* DP */ + DRM_MODE_SUBCONNECTOR_DVID = 3, /* DVI-I DP */ + DRM_MODE_SUBCONNECTOR_DVIA = 4, /* DVI-I */ + DRM_MODE_SUBCONNECTOR_Composite = 5, /* TV */ + DRM_MODE_SUBCONNECTOR_SVIDEO = 6, /* TV */ + DRM_MODE_SUBCONNECTOR_Component = 8, /* TV */ + DRM_MODE_SUBCONNECTOR_SCART = 9, /* TV */ + DRM_MODE_SUBCONNECTOR_DisplayPort = 10, /* DP */ + DRM_MODE_SUBCONNECTOR_HDMIA = 11, /* DP */ + DRM_MODE_SUBCONNECTOR_Native = 15, /* DP */ + DRM_MODE_SUBCONNECTOR_Wireless = 18, /* DP */ +}; #define DRM_MODE_CONNECTOR_Unknown 0 #define DRM_MODE_CONNECTOR_VGA 1 @@ -247,32 +386,101 @@ struct drm_mode_get_encoder { #define DRM_MODE_CONNECTOR_VIRTUAL 15 #define DRM_MODE_CONNECTOR_DSI 16 #define DRM_MODE_CONNECTOR_DPI 17 +#define DRM_MODE_CONNECTOR_WRITEBACK 18 +#define DRM_MODE_CONNECTOR_SPI 19 +#define DRM_MODE_CONNECTOR_USB 20 +/** + * struct drm_mode_get_connector - Get connector metadata. + * + * User-space can perform a GETCONNECTOR ioctl to retrieve information about a + * connector. User-space is expected to retrieve encoders, modes and properties + * by performing this ioctl at least twice: the first time to retrieve the + * number of elements, the second time to retrieve the elements themselves. + * + * To retrieve the number of elements, set @count_props and @count_encoders to + * zero, set @count_modes to 1, and set @modes_ptr to a temporary struct + * drm_mode_modeinfo element. + * + * To retrieve the elements, allocate arrays for @encoders_ptr, @modes_ptr, + * @props_ptr and @prop_values_ptr, then set @count_modes, @count_props and + * @count_encoders to their capacity. + * + * Performing the ioctl only twice may be racy: the number of elements may have + * changed with a hotplug event in-between the two ioctls. User-space is + * expected to retry the last ioctl until the number of elements stabilizes. + * The kernel won't fill any array which doesn't have the expected length. + * + * **Force-probing a connector** + * + * If the @count_modes field is set to zero and the DRM client is the current + * DRM master, the kernel will perform a forced probe on the connector to + * refresh the connector status, modes and EDID. A forced-probe can be slow, + * might cause flickering and the ioctl will block. + * + * User-space needs to force-probe connectors to ensure their metadata is + * up-to-date at startup and after receiving a hot-plug event. User-space + * may perform a forced-probe when the user explicitly requests it. User-space + * shouldn't perform a forced-probe in other situations. + */ struct drm_mode_get_connector { - + /** @encoders_ptr: Pointer to ``__u32`` array of object IDs. */ __u64 encoders_ptr; + /** @modes_ptr: Pointer to struct drm_mode_modeinfo array. */ __u64 modes_ptr; + /** @props_ptr: Pointer to ``__u32`` array of property IDs. */ __u64 props_ptr; + /** @prop_values_ptr: Pointer to ``__u64`` array of property values. */ __u64 prop_values_ptr; + /** @count_modes: Number of modes. */ __u32 count_modes; + /** @count_props: Number of properties. */ __u32 count_props; + /** @count_encoders: Number of encoders. */ __u32 count_encoders; - __u32 encoder_id; /**< Current Encoder */ - __u32 connector_id; /**< Id */ + /** @encoder_id: Object ID of the current encoder. */ + __u32 encoder_id; + /** @connector_id: Object ID of the connector. */ + __u32 connector_id; + /** + * @connector_type: Type of the connector. + * + * See DRM_MODE_CONNECTOR_* defines. + */ __u32 connector_type; + /** + * @connector_type_id: Type-specific connector number. + * + * This is not an object ID. This is a per-type connector number. Each + * (type, type_id) combination is unique across all connectors of a DRM + * device. + */ __u32 connector_type_id; + /** + * @connection: Status of the connector. + * + * See enum drm_connector_status. + */ __u32 connection; - __u32 mm_width; /**< width in millimeters */ - __u32 mm_height; /**< height in millimeters */ + /** @mm_width: Width of the connected sink in millimeters. */ + __u32 mm_width; + /** @mm_height: Height of the connected sink in millimeters. */ + __u32 mm_height; + /** + * @subpixel: Subpixel order of the connected sink. + * + * See enum subpixel_order. + */ __u32 subpixel; + /** @pad: Padding, must be zero. */ __u32 pad; }; -#define DRM_MODE_PROP_PENDING (1<<0) +#define DRM_MODE_PROP_PENDING (1<<0) /* deprecated, do not use */ #define DRM_MODE_PROP_RANGE (1<<1) #define DRM_MODE_PROP_IMMUTABLE (1<<2) #define DRM_MODE_PROP_ENUM (1<<3) /* enumerated type with text strings */ @@ -382,7 +590,7 @@ struct drm_mode_fb_cmd2 { * In case of planar formats, this ioctl allows up to 4 * buffer objects with offsets and pitches per plane. * The pitch and offset order is dictated by the fourcc, - * e.g. NV12 (http://fourcc.org/yuv.php#NV12) is described as: + * e.g. NV12 (https://fourcc.org/yuv.php#NV12) is described as: * * YUV 4:2:0 image with a plane of 8 bit Y samples * followed by an interleaved U/V plane containing @@ -392,17 +600,20 @@ struct drm_mode_fb_cmd2 { * offsets[1]. Note that offsets[0] will generally * be 0 (but this is not required). * - * To accommodate tiled, compressed, etc formats, a per-plane + * To accommodate tiled, compressed, etc formats, a * modifier can be specified. The default value of zero * indicates "native" format as specified by the fourcc. - * Vendor specific modifier token. This allows, for example, - * different tiling/swizzling pattern on different planes. - * See discussion above of DRM_FORMAT_MOD_xxx. + * Vendor specific modifier token. Note that even though + * it looks like we have a modifier per-plane, we in fact + * do not. The modifier for each plane must be identical. + * Thus all combinations of different data layouts for + * multi plane formats must be enumerated as separate + * modifiers. */ __u32 handles[4]; __u32 pitches[4]; /* pitch for each plane */ __u32 offsets[4]; /* offset of each plane */ - __u64 modifier[4]; /* ie, tiling, compressed (per plane) */ + __u64 modifier[4]; /* ie, tiling, compress */ }; #define DRM_MODE_FB_DIRTY_ANNOTATE_COPY 0x01 @@ -504,13 +715,17 @@ struct drm_mode_crtc_lut { }; struct drm_color_ctm { - /* Conversion matrix in S31.32 format. */ - __s64 matrix[9]; + /* + * Conversion matrix in S31.32 sign-magnitude + * (not two's complement!) format. + */ + __u64 matrix[9]; }; struct drm_color_lut { /* - * Data is U0.16 fixed point format. + * Values are mapped linearly to 0.0 - 1.0 range, with 0x0 == 0.0 and + * 0xffff == 1.0. */ __u16 red; __u16 green; @@ -518,6 +733,92 @@ struct drm_color_lut { __u16 reserved; }; +/** + * struct hdr_metadata_infoframe - HDR Metadata Infoframe Data. + * + * HDR Metadata Infoframe as per CTA 861.G spec. This is expected + * to match exactly with the spec. + * + * Userspace is expected to pass the metadata information as per + * the format described in this structure. + */ +struct hdr_metadata_infoframe { + /** + * @eotf: Electro-Optical Transfer Function (EOTF) + * used in the stream. + */ + __u8 eotf; + /** + * @metadata_type: Static_Metadata_Descriptor_ID. + */ + __u8 metadata_type; + /** + * @display_primaries: Color Primaries of the Data. + * These are coded as unsigned 16-bit values in units of + * 0.00002, where 0x0000 represents zero and 0xC350 + * represents 1.0000. + * @display_primaries.x: X cordinate of color primary. + * @display_primaries.y: Y cordinate of color primary. + */ + struct { + __u16 x, y; + } display_primaries[3]; + /** + * @white_point: White Point of Colorspace Data. + * These are coded as unsigned 16-bit values in units of + * 0.00002, where 0x0000 represents zero and 0xC350 + * represents 1.0000. + * @white_point.x: X cordinate of whitepoint of color primary. + * @white_point.y: Y cordinate of whitepoint of color primary. + */ + struct { + __u16 x, y; + } white_point; + /** + * @max_display_mastering_luminance: Max Mastering Display Luminance. + * This value is coded as an unsigned 16-bit value in units of 1 cd/m2, + * where 0x0001 represents 1 cd/m2 and 0xFFFF represents 65535 cd/m2. + */ + __u16 max_display_mastering_luminance; + /** + * @min_display_mastering_luminance: Min Mastering Display Luminance. + * This value is coded as an unsigned 16-bit value in units of + * 0.0001 cd/m2, where 0x0001 represents 0.0001 cd/m2 and 0xFFFF + * represents 6.5535 cd/m2. + */ + __u16 min_display_mastering_luminance; + /** + * @max_cll: Max Content Light Level. + * This value is coded as an unsigned 16-bit value in units of 1 cd/m2, + * where 0x0001 represents 1 cd/m2 and 0xFFFF represents 65535 cd/m2. + */ + __u16 max_cll; + /** + * @max_fall: Max Frame Average Light Level. + * This value is coded as an unsigned 16-bit value in units of 1 cd/m2, + * where 0x0001 represents 1 cd/m2 and 0xFFFF represents 65535 cd/m2. + */ + __u16 max_fall; +}; + +/** + * struct hdr_output_metadata - HDR output metadata + * + * Metadata Information to be passed from userspace + */ +struct hdr_output_metadata { + /** + * @metadata_type: Static_Metadata_Descriptor_ID. + */ + __u32 metadata_type; + /** + * @hdmi_metadata_type1: HDR Metadata Infoframe. + */ + union { + struct hdr_metadata_infoframe hdmi_metadata_type1; + }; +}; + #define DRM_MODE_PAGE_FLIP_EVENT 0x01 #define DRM_MODE_PAGE_FLIP_ASYNC 0x02 #define DRM_MODE_PAGE_FLIP_TARGET_ABSOLUTE 0x4 @@ -640,26 +941,187 @@ struct drm_mode_atomic { __u64 user_data; }; +struct drm_format_modifier_blob { +#define FORMAT_BLOB_CURRENT 1 + /* Version of this blob format */ + __u32 version; + + /* Flags */ + __u32 flags; + + /* Number of fourcc formats supported */ + __u32 count_formats; + + /* Where in this blob the formats exist (in bytes) */ + __u32 formats_offset; + + /* Number of drm_format_modifiers */ + __u32 count_modifiers; + + /* Where in this blob the modifiers exist (in bytes) */ + __u32 modifiers_offset; + + /* __u32 formats[] */ + /* struct drm_format_modifier modifiers[] */ +}; + +struct drm_format_modifier { + /* Bitmask of formats in get_plane format list this info applies to. The + * offset allows a sliding window of which 64 formats (bits). + * + * Some examples: + * In today's world with < 65 formats, and formats 0, and 2 are + * supported + * 0x0000000000000005 + * ^-offset = 0, formats = 5 + * + * If the number formats grew to 128, and formats 98-102 are + * supported with the modifier: + * + * 0x0000007c00000000 0000000000000000 + * ^ + * |__offset = 64, formats = 0x7c00000000 + * + */ + __u64 formats; + __u32 offset; + __u32 pad; + + /* The modifier that applies to the >get_plane format list bitmask. */ + __u64 modifier; +}; + /** + * struct drm_mode_create_blob - Create New blob property + * * Create a new 'blob' data property, copying length bytes from data pointer, * and returning new blob ID. */ struct drm_mode_create_blob { - /** Pointer to data to copy. */ + /** @data: Pointer to data to copy. */ __u64 data; - /** Length of data to copy. */ + /** @length: Length of data to copy. */ __u32 length; - /** Return: new property ID. */ + /** @blob_id: Return: new property ID. */ __u32 blob_id; }; /** + * struct drm_mode_destroy_blob - Destroy user blob + * @blob_id: blob_id to destroy + * * Destroy a user-created blob property. + * + * User-space can release blobs as soon as they do not need to refer to them by + * their blob object ID. For instance, if you are using a MODE_ID blob in an + * atomic commit and you will not make another commit re-using the same ID, you + * can destroy the blob as soon as the commit has been issued, without waiting + * for it to complete. */ struct drm_mode_destroy_blob { __u32 blob_id; }; +/** + * struct drm_mode_create_lease - Create lease + * + * Lease mode resources, creating another drm_master. + */ +struct drm_mode_create_lease { + /** @object_ids: Pointer to array of object ids (__u32) */ + __u64 object_ids; + /** @object_count: Number of object ids */ + __u32 object_count; + /** @flags: flags for new FD (O_CLOEXEC, etc) */ + __u32 flags; + + /** @lessee_id: Return: unique identifier for lessee. */ + __u32 lessee_id; + /** @fd: Return: file descriptor to new drm_master file */ + __u32 fd; +}; + +/** + * struct drm_mode_list_lessees - List lessees + * + * List lesses from a drm_master. + */ +struct drm_mode_list_lessees { + /** + * @count_lessees: Number of lessees. + * + * On input, provides length of the array. + * On output, provides total number. No + * more than the input number will be written + * back, so two calls can be used to get + * the size and then the data. + */ + __u32 count_lessees; + /** @pad: Padding. */ + __u32 pad; + + /** + * @lessees_ptr: Pointer to lessees. + * + * Pointer to __u64 array of lessee ids + */ + __u64 lessees_ptr; +}; + +/** + * struct drm_mode_get_lease - Get Lease + * + * Get leased objects. + */ +struct drm_mode_get_lease { + /** + * @count_objects: Number of leased objects. + * + * On input, provides length of the array. + * On output, provides total number. No + * more than the input number will be written + * back, so two calls can be used to get + * the size and then the data. + */ + __u32 count_objects; + /** @pad: Padding. */ + __u32 pad; + + /** + * @objects_ptr: Pointer to objects. + * + * Pointer to __u32 array of object ids. + */ + __u64 objects_ptr; +}; + +/** + * struct drm_mode_revoke_lease - Revoke lease + */ +struct drm_mode_revoke_lease { + /** @lessee_id: Unique ID of lessee */ + __u32 lessee_id; +}; + +/** + * struct drm_mode_rect - Two dimensional rectangle. + * @x1: Horizontal starting coordinate (inclusive). + * @y1: Vertical starting coordinate (inclusive). + * @x2: Horizontal ending coordinate (exclusive). + * @y2: Vertical ending coordinate (exclusive). + * + * With drm subsystem using struct drm_rect to manage rectangular area this + * export it to user-space. + * + * Currently used by drm_mode_atomic blob property FB_DAMAGE_CLIPS. + */ +struct drm_mode_rect { + __s32 x1; + __s32 y1; + __s32 x2; + __s32 y2; +}; + #if defined(__cplusplus) } #endif diff --git a/usr/src/uts/common/drm/drm_sarea.h b/usr/src/uts/common/drm/drm_sarea.h index 502934ed..93025be8 100644 --- a/usr/src/uts/common/drm/drm_sarea.h +++ b/usr/src/uts/common/drm/drm_sarea.h @@ -34,6 +34,10 @@ #include "drm.h" +#if defined(__cplusplus) +extern "C" { +#endif + /* SAREA area needs to be at least a page */ #if defined(__alpha__) #define SAREA_MAX 0x2000U @@ -81,4 +85,8 @@ typedef struct drm_sarea_drawable drm_sarea_drawable_t; typedef struct drm_sarea_frame drm_sarea_frame_t; typedef struct drm_sarea drm_sarea_t; +#if defined(__cplusplus) +} +#endif + #endif /* _DRM_SAREA_H_ */ diff --git a/usr/src/uts/common/drm/i915_drm.h b/usr/src/uts/common/drm/i915_drm.h index b406ce88..356a37ec 100644 --- a/usr/src/uts/common/drm/i915_drm.h +++ b/usr/src/uts/common/drm/i915_drm.h @@ -62,6 +62,28 @@ extern "C" { #define I915_ERROR_UEVENT "ERROR" #define I915_RESET_UEVENT "RESET" +/* + * i915_user_extension: Base class for defining a chain of extensions + * + * Many interfaces need to grow over time. In most cases we can simply + * extend the struct and have userspace pass in more data. Another option, + * as demonstrated by Vulkan's approach to providing extensions for forward + * and backward compatibility, is to use a list of optional structs to + * provide those extra details. + * + * The key advantage to using an extension chain is that it allows us to + * redefine the interface more easily than an ever growing struct of + * increasing complexity, and for large parts of that interface to be + * entirely optional. The downside is more pointer chasing; chasing across + * the boundary with pointers encapsulated inside u64. + */ +struct i915_user_extension { + __u64 next_extension; + __u32 name; + __u32 flags; /* All undefined bits must be zero. */ + __u32 rsvd[4]; /* Reserved for future use; must be zero. */ +}; + /* * MOCS indexes used for GPU surfaces, defining the cacheability of the * surface data and the coherency for this data wrt. CPU vs. GPU accesses. @@ -86,6 +108,64 @@ enum i915_mocs_table_index { I915_MOCS_CACHED, }; +/* + * Different engines serve different roles, and there may be more than one + * engine serving each role. enum drm_i915_gem_engine_class provides a + * classification of the role of the engine, which may be used when requesting + * operations to be performed on a certain subset of engines, or for providing + * information about that group. + */ +enum drm_i915_gem_engine_class { + I915_ENGINE_CLASS_RENDER = 0, + I915_ENGINE_CLASS_COPY = 1, + I915_ENGINE_CLASS_VIDEO = 2, + I915_ENGINE_CLASS_VIDEO_ENHANCE = 3, + + /* should be kept compact */ + + I915_ENGINE_CLASS_INVALID = -1 +}; + +/** + * DOC: perf_events exposed by i915 through /sys/bus/event_sources/drivers/i915 + * + */ + +enum drm_i915_pmu_engine_sample { + I915_SAMPLE_BUSY = 0, + I915_SAMPLE_WAIT = 1, + I915_SAMPLE_SEMA = 2 +}; + +#define I915_PMU_SAMPLE_BITS (4) +#define I915_PMU_SAMPLE_MASK (0xf) +#define I915_PMU_SAMPLE_INSTANCE_BITS (8) +#define I915_PMU_CLASS_SHIFT \ + (I915_PMU_SAMPLE_BITS + I915_PMU_SAMPLE_INSTANCE_BITS) + +#define __I915_PMU_ENGINE(class, instance, sample) \ + ((class) << I915_PMU_CLASS_SHIFT | \ + (instance) << I915_PMU_SAMPLE_BITS | \ + (sample)) + +#define I915_PMU_ENGINE_BUSY(class, instance) \ + __I915_PMU_ENGINE(class, instance, I915_SAMPLE_BUSY) + +#define I915_PMU_ENGINE_WAIT(class, instance) \ + __I915_PMU_ENGINE(class, instance, I915_SAMPLE_WAIT) + +#define I915_PMU_ENGINE_SEMA(class, instance) \ + __I915_PMU_ENGINE(class, instance, I915_SAMPLE_SEMA) + +#define __I915_PMU_OTHER(x) (__I915_PMU_ENGINE(0xff, 0xff, 0xf) + 1 + (x)) + +#define I915_PMU_ACTUAL_FREQUENCY __I915_PMU_OTHER(0) +#define I915_PMU_REQUESTED_FREQUENCY __I915_PMU_OTHER(1) +#define I915_PMU_INTERRUPTS __I915_PMU_OTHER(2) +#define I915_PMU_RC6_RESIDENCY __I915_PMU_OTHER(3) + +#define I915_PMU_LAST I915_PMU_RC6_RESIDENCY + /* Each region is a minimum of 16k, and there are at most 255 of them. */ #define I915_NR_TEX_REGIONS 255 /* table size 2k - maximum due to use @@ -263,6 +343,10 @@ typedef struct _drm_i915_sarea { #define DRM_I915_GEM_CONTEXT_GETPARAM 0x34 #define DRM_I915_GEM_CONTEXT_SETPARAM 0x35 #define DRM_I915_PERF_OPEN 0x36 +#define DRM_I915_PERF_ADD_CONFIG 0x37 +#define DRM_I915_PERF_REMOVE_CONFIG 0x38 +#define DRM_I915_QUERY 0x39 +/* Must be kept compact -- no holes */ #define DRM_IOCTL_I915_INIT DRM_IOW( DRM_COMMAND_BASE + DRM_I915_INIT, drm_i915_init_t) #define DRM_IOCTL_I915_FLUSH DRM_IO ( DRM_COMMAND_BASE + DRM_I915_FLUSH) @@ -314,6 +398,7 @@ typedef struct _drm_i915_sarea { #define DRM_IOCTL_I915_GET_SPRITE_COLORKEY DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GET_SPRITE_COLORKEY, struct drm_intel_sprite_colorkey) #define DRM_IOCTL_I915_GEM_WAIT DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_GEM_WAIT, struct drm_i915_gem_wait) #define DRM_IOCTL_I915_GEM_CONTEXT_CREATE DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GEM_CONTEXT_CREATE, struct drm_i915_gem_context_create) +#define DRM_IOCTL_I915_GEM_CONTEXT_CREATE_EXT DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GEM_CONTEXT_CREATE, struct drm_i915_gem_context_create_ext) #define DRM_IOCTL_I915_GEM_CONTEXT_DESTROY DRM_IOW (DRM_COMMAND_BASE + DRM_I915_GEM_CONTEXT_DESTROY, struct drm_i915_gem_context_destroy) #define DRM_IOCTL_I915_REG_READ DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_REG_READ, struct drm_i915_reg_read) #define DRM_IOCTL_I915_GET_RESET_STATS DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GET_RESET_STATS, struct drm_i915_reset_stats) @@ -321,6 +406,9 @@ typedef struct _drm_i915_sarea { #define DRM_IOCTL_I915_GEM_CONTEXT_GETPARAM DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GEM_CONTEXT_GETPARAM, struct drm_i915_gem_context_param) #define DRM_IOCTL_I915_GEM_CONTEXT_SETPARAM DRM_IOWR (DRM_COMMAND_BASE + DRM_I915_GEM_CONTEXT_SETPARAM, struct drm_i915_gem_context_param) #define DRM_IOCTL_I915_PERF_OPEN DRM_IOW(DRM_COMMAND_BASE + DRM_I915_PERF_OPEN, struct drm_i915_perf_open_param) +#define DRM_IOCTL_I915_PERF_ADD_CONFIG DRM_IOW(DRM_COMMAND_BASE + DRM_I915_PERF_ADD_CONFIG, struct drm_i915_perf_oa_config) +#define DRM_IOCTL_I915_PERF_REMOVE_CONFIG DRM_IOW(DRM_COMMAND_BASE + DRM_I915_PERF_REMOVE_CONFIG, __u64) +#define DRM_IOCTL_I915_QUERY DRM_IOWR(DRM_COMMAND_BASE + DRM_I915_QUERY, struct drm_i915_query) /* Allow drivers to submit batchbuffers directly to hardware, relying * on the security mechanisms provided by hardware. @@ -378,6 +466,14 @@ typedef struct drm_i915_irq_wait { int irq_seq; } drm_i915_irq_wait_t; +/* + * Different modes of per-process Graphics Translation Table, + * see I915_PARAM_HAS_ALIASING_PPGTT + */ +#define I915_GEM_PPGTT_NONE 0 +#define I915_GEM_PPGTT_ALIASING 1 +#define I915_GEM_PPGTT_FULL 2 + /* Ioctl to query kernel params: */ #define I915_PARAM_IRQ_ACTIVE 1 @@ -421,10 +517,21 @@ typedef struct drm_i915_irq_wait { #define I915_PARAM_MIN_EU_IN_POOL 39 #define I915_PARAM_MMAP_GTT_VERSION 40 -/* Query whether DRM_I915_GEM_EXECBUFFER2 supports user defined execution +/* + * Query whether DRM_I915_GEM_EXECBUFFER2 supports user defined execution * priorities and the driver will attempt to execute batches in priority order. + * The param returns a capability bitmask, nonzero implies that the scheduler + * is enabled, with different features present according to the mask. + * + * The initial priority for each batch is supplied by the context and is + * controlled via I915_CONTEXT_PARAM_PRIORITY. */ #define I915_PARAM_HAS_SCHEDULER 41 +#define I915_SCHEDULER_CAP_ENABLED (1ul << 0) +#define I915_SCHEDULER_CAP_PRIORITY (1ul << 1) +#define I915_SCHEDULER_CAP_PREEMPTION (1ul << 2) +#define I915_SCHEDULER_CAP_SEMAPHORES (1ul << 3) + #define I915_PARAM_HUC_STATUS 42 /* Query whether DRM_I915_GEM_EXECBUFFER2 supports the ability to opt-out of @@ -440,6 +547,75 @@ typedef struct drm_i915_irq_wait { */ #define I915_PARAM_HAS_EXEC_FENCE 44 +/* Query whether DRM_I915_GEM_EXECBUFFER2 supports the ability to capture + * user specified buffers for post-mortem debugging of GPU hangs. See + * EXEC_OBJECT_CAPTURE. + */ +#define I915_PARAM_HAS_EXEC_CAPTURE 45 + +#define I915_PARAM_SLICE_MASK 46 + +/* Assuming it's uniform for each slice, this queries the mask of subslices + * per-slice for this system. + */ +#define I915_PARAM_SUBSLICE_MASK 47 + +/* + * Query whether DRM_I915_GEM_EXECBUFFER2 supports supplying the batch buffer + * as the first execobject as opposed to the last. See I915_EXEC_BATCH_FIRST. + */ +#define I915_PARAM_HAS_EXEC_BATCH_FIRST 48 + +/* Query whether DRM_I915_GEM_EXECBUFFER2 supports supplying an array of + * drm_i915_gem_exec_fence structures. See I915_EXEC_FENCE_ARRAY. + */ +#define I915_PARAM_HAS_EXEC_FENCE_ARRAY 49 + +/* + * Query whether every context (both per-file default and user created) is + * isolated (insofar as HW supports). If this parameter is not true, then + * freshly created contexts may inherit values from an existing context, + * rather than default HW values. If true, it also ensures (insofar as HW + * supports) that all state set by this context will not leak to any other + * context. + * + * As not every engine across every gen support contexts, the returned + * value reports the support of context isolation for individual engines by + * returning a bitmask of each engine class set to true if that class supports + * isolation. + */ +#define I915_PARAM_HAS_CONTEXT_ISOLATION 50 + +/* Frequency of the command streamer timestamps given by the *_TIMESTAMP + * registers. This used to be fixed per platform but from CNL onwards, this + * might vary depending on the parts. + */ +#define I915_PARAM_CS_TIMESTAMP_FREQUENCY 51 + +/* + * Once upon a time we supposed that writes through the GGTT would be + * immediately in physical memory (once flushed out of the CPU path). However, + * on a few different processors and chipsets, this is not necessarily the case + * as the writes appear to be buffered internally. Thus a read of the backing + * storage (physical memory) via a different path (with different physical tags + * to the indirect write via the GGTT) will see stale values from before + * the GGTT write. Inside the kernel, we can for the most part keep track of + * the different read/write domains in use (e.g. set-domain), but the assumption + * of coherency is baked into the ABI, hence reporting its true state in this + * parameter. + * + * Reports true when writes via mmap_gtt are immediately visible following an + * lfence to flush the WCB. + * + * Reports false when writes via mmap_gtt are indeterminately delayed in an in + * internal buffer and are _not_ immediately visible to third parties accessing + * directly via mmap_cpu/mmap_wc. Use of mmap_gtt as part of an IPC + * communications channel when reporting false is strongly disadvised. + */ +#define I915_PARAM_MMAP_GTT_COHERENT 52 + +/* Must be kept compact -- no holes and well documented */ + typedef struct drm_i915_getparam { __s32 param; /* @@ -460,6 +636,7 @@ typedef struct drm_i915_getparam32 { #define I915_SETPARAM_TEX_LRU_LOG_GRANULARITY 2 #define I915_SETPARAM_ALLOW_BATCHBUFFER 3 #define I915_SETPARAM_NUM_USED_FENCES 4 +/* Must be kept compact -- no holes */ typedef struct drm_i915_setparam { int param; @@ -706,6 +883,8 @@ struct drm_i915_gem_relocation_entry { #define I915_GEM_DOMAIN_VERTEX 0x00000020 /** GTT domain - aperture and scanout */ #define I915_GEM_DOMAIN_GTT 0x00000040 +/** WC domain - uncached access */ +#define I915_GEM_DOMAIN_WC 0x00000080 /** @} */ struct drm_i915_gem_exec_object { @@ -813,8 +992,15 @@ struct drm_i915_gem_exec_object2 { * I915_PARAM_HAS_EXEC_FENCE to order execbufs and execute them asynchronously. */ #define EXEC_OBJECT_ASYNC (1<<6) +/* Request that the contents of this execobject be copied into the error + * state upon a GPU hang involving this batch for post-mortem debugging. + * These buffers are recorded in no particular order as "user" in + * /sys/class/drm/cardN/error. Query I915_PARAM_HAS_EXEC_CAPTURE to see + * if the kernel supports this flag. + */ +#define EXEC_OBJECT_CAPTURE (1<<7) /* All remaining bits are MBZ and RESERVED FOR FUTURE USE */ -#define __EXEC_OBJECT_UNKNOWN_FLAGS -(EXEC_OBJECT_ASYNC<<1) +#define __EXEC_OBJECT_UNKNOWN_FLAGS -(EXEC_OBJECT_CAPTURE<<1) __u64 flags; union { @@ -824,6 +1010,18 @@ struct drm_i915_gem_exec_object2 { __u64 rsvd2; }; +struct drm_i915_gem_exec_fence { + /** + * User's handle for a drm_syncobj to wait on or signal. + */ + __u32 handle; + +#define I915_EXEC_FENCE_WAIT (1<<0) +#define I915_EXEC_FENCE_SIGNAL (1<<1) +#define __I915_EXEC_FENCE_UNKNOWN_FLAGS (-(I915_EXEC_FENCE_SIGNAL << 1)) + __u32 flags; +}; + struct drm_i915_gem_execbuffer2 { /** * List of gem_exec_object2 structs @@ -838,9 +1036,13 @@ struct drm_i915_gem_execbuffer2 { __u32 DR1; __u32 DR4; __u32 num_cliprects; - /** This is a struct drm_clip_rect *cliprects */ + /** + * This is a struct drm_clip_rect *cliprects if I915_EXEC_FENCE_ARRAY + * is not set. If I915_EXEC_FENCE_ARRAY is set, then this is a + * struct drm_i915_gem_exec_fence *fences. + */ __u64 cliprects_ptr; -#define I915_EXEC_RING_MASK (7<<0) +#define I915_EXEC_RING_MASK (0x3f) #define I915_EXEC_DEFAULT (0<<0) #define I915_EXEC_RENDER (1<<0) #define I915_EXEC_BSD (2<<0) @@ -929,7 +1131,24 @@ struct drm_i915_gem_execbuffer2 { */ #define I915_EXEC_FENCE_OUT (1<<17) -#define __I915_EXEC_UNKNOWN_FLAGS (-(I915_EXEC_FENCE_OUT<<1)) +/* + * Traditionally the execbuf ioctl has only considered the final element in + * the execobject[] to be the executable batch. Often though, the client + * will known the batch object prior to construction and being able to place + * it into the execobject[] array first can simplify the relocation tracking. + * Setting I915_EXEC_BATCH_FIRST tells execbuf to use element 0 of the + * execobject[] as the * batch instead (the default is to use the last + * element). + */ +#define I915_EXEC_BATCH_FIRST (1<<18) + +/* Setting I915_FENCE_ARRAY implies that num_cliprects and cliprects_ptr + * define an array of i915_gem_exec_fence structures which specify a set of + * dma fences to wait upon or signal. + */ +#define I915_EXEC_FENCE_ARRAY (1<<19) + +#define __I915_EXEC_UNKNOWN_FLAGS (-(I915_EXEC_FENCE_ARRAY<<1)) #define I915_EXEC_CONTEXT_ID_MASK (0xffffffff) #define i915_execbuffer2_set_context_id(eb2, context) \ @@ -971,32 +1190,34 @@ struct drm_i915_gem_busy { * as busy may become idle before the ioctl is completed. * * Furthermore, if the object is busy, which engine is busy is only - * provided as a guide. There are race conditions which prevent the - * report of which engines are busy from being always accurate. - * However, the converse is not true. If the object is idle, the - * result of the ioctl, that all engines are idle, is accurate. + * provided as a guide and only indirectly by reporting its class + * (there may be more than one engine in each class). There are race + * conditions which prevent the report of which engines are busy from + * being always accurate. However, the converse is not true. If the + * object is idle, the result of the ioctl, that all engines are idle, + * is accurate. * * The returned dword is split into two fields to indicate both - * the engines on which the object is being read, and the - * engine on which it is currently being written (if any). + * the engine classess on which the object is being read, and the + * engine class on which it is currently being written (if any). * * The low word (bits 0:15) indicate if the object is being written * to by any engine (there can only be one, as the GEM implicit * synchronisation rules force writes to be serialised). Only the - * engine for the last write is reported. + * engine class (offset by 1, I915_ENGINE_CLASS_RENDER is reported as + * 1 not 0 etc) for the last write is reported. * - * The high word (bits 16:31) are a bitmask of which engines are - * currently reading from the object. Multiple engines may be + * The high word (bits 16:31) are a bitmask of which engines classes + * are currently reading from the object. Multiple engines may be * reading from the object simultaneously. * - * The value of each engine is the same as specified in the - * EXECBUFFER2 ioctl, i.e. I915_EXEC_RENDER, I915_EXEC_BSD etc. - * Note I915_EXEC_DEFAULT is a symbolic value and is mapped to - * the I915_EXEC_RENDER engine for execution, and so it is never + * The value of each engine class is the same as specified in the + * I915_CONTEXT_SET_ENGINES parameter and via perf, i.e. + * I915_ENGINE_CLASS_RENDER, I915_ENGINE_CLASS_COPY, etc. * reported as active itself. Some hardware may have parallel * execution engines, e.g. multiple media engines, which are - * mapped to the same identifier in the EXECBUFFER2 ioctl and - * so are not separately reported for busyness. + * mapped to the same class identifier and so are not separately + * reported for busyness. * * Caveat emptor: * Only the boolean result of this query is reliable; that is whether @@ -1039,7 +1260,7 @@ struct drm_i915_gem_caching { __u32 handle; /** - * Cacheing level to apply or return value + * Caching level to apply or return value * * bits0-15 are for generic caching control (i.e. the above defined * values). bits16-31 are reserved for platform-specific variations @@ -1241,7 +1462,9 @@ struct drm_intel_overlay_attrs { * active on a given plane. */ -#define I915_SET_COLORKEY_NONE (1<<0) /* disable color key matching */ +#define I915_SET_COLORKEY_NONE (1<<0) /* Deprecated. Instead set + * flags==0 to disable colorkeying. + */ #define I915_SET_COLORKEY_DESTINATION (1<<1) #define I915_SET_COLORKEY_SOURCE (1<<2) struct drm_intel_sprite_colorkey { @@ -1261,16 +1484,159 @@ struct drm_i915_gem_wait { }; struct drm_i915_gem_context_create { - /* output: id of new context*/ - __u32 ctx_id; + __u32 ctx_id; /* output: id of new context*/ __u32 pad; }; +struct drm_i915_gem_context_create_ext { + __u32 ctx_id; /* output: id of new context*/ + __u32 flags; +#define I915_CONTEXT_CREATE_FLAGS_USE_EXTENSIONS (1u << 0) +#define I915_CONTEXT_CREATE_FLAGS_UNKNOWN \ + (-(I915_CONTEXT_CREATE_FLAGS_USE_EXTENSIONS << 1)) + __u64 extensions; +}; + +struct drm_i915_gem_context_param { + __u32 ctx_id; + __u32 size; + __u64 param; +#define I915_CONTEXT_PARAM_BAN_PERIOD 0x1 +#define I915_CONTEXT_PARAM_NO_ZEROMAP 0x2 +#define I915_CONTEXT_PARAM_GTT_SIZE 0x3 +#define I915_CONTEXT_PARAM_NO_ERROR_CAPTURE 0x4 +#define I915_CONTEXT_PARAM_BANNABLE 0x5 +#define I915_CONTEXT_PARAM_PRIORITY 0x6 +#define I915_CONTEXT_MAX_USER_PRIORITY 1023 /* inclusive */ +#define I915_CONTEXT_DEFAULT_PRIORITY 0 +#define I915_CONTEXT_MIN_USER_PRIORITY -1023 /* inclusive */ + /* + * When using the following param, value should be a pointer to + * drm_i915_gem_context_param_sseu. + */ +#define I915_CONTEXT_PARAM_SSEU 0x7 + +/* + * Not all clients may want to attempt automatic recover of a context after + * a hang (for example, some clients may only submit very small incremental + * batches relying on known logical state of previous batches which will never + * recover correctly and each attempt will hang), and so would prefer that + * the context is forever banned instead. + * + * If set to false (0), after a reset, subsequent (and in flight) rendering + * from this context is discarded, and the client will need to create a new + * context to use instead. + * + * If set to true (1), the kernel will automatically attempt to recover the + * context by skipping the hanging batch and executing the next batch starting + * from the default context state (discarding the incomplete logical context + * state lost due to the reset). + * + * On creation, all new contexts are marked as recoverable. + */ +#define I915_CONTEXT_PARAM_RECOVERABLE 0x8 +/* Must be kept compact -- no holes and well documented */ + + __u64 value; +}; + +/** + * Context SSEU programming + * + * It may be necessary for either functional or performance reason to configure + * a context to run with a reduced number of SSEU (where SSEU stands for Slice/ + * Sub-slice/EU). + * + * This is done by configuring SSEU configuration using the below + * @struct drm_i915_gem_context_param_sseu for every supported engine which + * userspace intends to use. + * + * Not all GPUs or engines support this functionality in which case an error + * code -ENODEV will be returned. + * + * Also, flexibility of possible SSEU configuration permutations varies between + * GPU generations and software imposed limitations. Requesting such a + * combination will return an error code of -EINVAL. + * + * NOTE: When perf/OA is active the context's SSEU configuration is ignored in + * favour of a single global setting. + */ +struct drm_i915_gem_context_param_sseu { + /* + * Engine class & instance to be configured or queried. + */ + __u16 engine_class; + __u16 engine_instance; + + /* + * Unused for now. Must be cleared to zero. + */ + __u32 flags; + + /* + * Mask of slices to enable for the context. Valid values are a subset + * of the bitmask value returned for I915_PARAM_SLICE_MASK. + */ + __u64 slice_mask; + + /* + * Mask of subslices to enable for the context. Valid values are a + * subset of the bitmask value return by I915_PARAM_SUBSLICE_MASK. + */ + __u64 subslice_mask; + + /* + * Minimum/Maximum number of EUs to enable per subslice for the + * context. min_eus_per_subslice must be inferior or equal to + * max_eus_per_subslice. + */ + __u16 min_eus_per_subslice; + __u16 max_eus_per_subslice; + + /* + * Unused for now. Must be cleared to zero. + */ + __u32 rsvd; +}; + +struct drm_i915_gem_context_create_ext_setparam { +#define I915_CONTEXT_CREATE_EXT_SETPARAM 0 + struct i915_user_extension base; + struct drm_i915_gem_context_param param; +}; + struct drm_i915_gem_context_destroy { __u32 ctx_id; __u32 pad; }; +/* + * DRM_I915_GEM_VM_CREATE - + * + * Create a new virtual memory address space (ppGTT) for use within a context + * on the same file. Extensions can be provided to configure exactly how the + * address space is setup upon creation. + * + * The id of new VM (bound to the fd) for use with I915_CONTEXT_PARAM_VM is + * returned in the outparam @id. + * + * No flags are defined, with all bits reserved and must be zero. + * + * An extension chain maybe provided, starting with @extensions, and terminated + * by the @next_extension being 0. Currently, no extensions are defined. + * + * DRM_I915_GEM_VM_DESTROY - + * + * Destroys a previously created VM id, specified in @id. + * + * No extensions or flags are allowed currently, and so must be zero. + */ +struct drm_i915_gem_vm_control { + __u64 extensions; + __u32 flags; + __u32 vm_id; +}; + struct drm_i915_reg_read { /* * Register offset. @@ -1279,14 +1645,17 @@ struct drm_i915_reg_read { * be specified */ __u64 offset; +#define I915_REG_READ_8B_WA (1ul << 0) + __u64 val; /* Return value */ }; + /* Known registers: * * Render engine timestamp - 0x2358 + 64bit - gen7+ * - Note this register returns an invalid value if using the default - * single instruction 8byte read, in order to workaround that use - * offset (0x2538 | 1) instead. + * single instruction 8byte read, in order to workaround that pass + * flag I915_REG_READ_8B_WA in offset field. * */ @@ -1320,26 +1689,19 @@ struct drm_i915_gem_userptr { __u32 handle; }; -struct drm_i915_gem_context_param { - __u32 ctx_id; - __u32 size; - __u64 param; -#define I915_CONTEXT_PARAM_BAN_PERIOD 0x1 -#define I915_CONTEXT_PARAM_NO_ZEROMAP 0x2 -#define I915_CONTEXT_PARAM_GTT_SIZE 0x3 -#define I915_CONTEXT_PARAM_NO_ERROR_CAPTURE 0x4 -#define I915_CONTEXT_PARAM_BANNABLE 0x5 - __u64 value; -}; - enum drm_i915_oa_format { - I915_OA_FORMAT_A13 = 1, - I915_OA_FORMAT_A29, - I915_OA_FORMAT_A13_B8_C8, - I915_OA_FORMAT_B4_C8, - I915_OA_FORMAT_A45_B8_C8, - I915_OA_FORMAT_B4_C8_A16, - I915_OA_FORMAT_C4_B8, + I915_OA_FORMAT_A13 = 1, /* HSW only */ + I915_OA_FORMAT_A29, /* HSW only */ + I915_OA_FORMAT_A13_B8_C8, /* HSW only */ + I915_OA_FORMAT_B4_C8, /* HSW only */ + I915_OA_FORMAT_A45_B8_C8, /* HSW only */ + I915_OA_FORMAT_B4_C8_A16, /* HSW only */ + I915_OA_FORMAT_C4_B8, /* HSW+ */ + + /* Gen8+ */ + I915_OA_FORMAT_A12, + I915_OA_FORMAT_A12_B8_C8, + I915_OA_FORMAT_A32u40_A4u32_B8_C8, I915_OA_FORMAT_MAX /* non-ABI */ }; @@ -1464,6 +1826,128 @@ enum drm_i915_perf_record_type { DRM_I915_PERF_RECORD_MAX /* non-ABI */ }; +/** + * Structure to upload perf dynamic configuration into the kernel. + */ +struct drm_i915_perf_oa_config { + /** String formatted like "%08x-%04x-%04x-%04x-%012x" */ + char uuid[36]; + + __u32 n_mux_regs; + __u32 n_boolean_regs; + __u32 n_flex_regs; + + /* + * These fields are pointers to tuples of u32 values (register address, + * value). For example the expected length of the buffer pointed by + * mux_regs_ptr is (2 * sizeof(u32) * n_mux_regs). + */ + __u64 mux_regs_ptr; + __u64 boolean_regs_ptr; + __u64 flex_regs_ptr; +}; + +struct drm_i915_query_item { + __u64 query_id; +#define DRM_I915_QUERY_TOPOLOGY_INFO 1 +/* Must be kept compact -- no holes and well documented */ + + /* + * When set to zero by userspace, this is filled with the size of the + * data to be written at the data_ptr pointer. The kernel sets this + * value to a negative value to signal an error on a particular query + * item. + */ + __s32 length; + + /* + * Unused for now. Must be cleared to zero. + */ + __u32 flags; + + /* + * Data will be written at the location pointed by data_ptr when the + * value of length matches the length of the data to be written by the + * kernel. + */ + __u64 data_ptr; +}; + +struct drm_i915_query { + __u32 num_items; + + /* + * Unused for now. Must be cleared to zero. + */ + __u32 flags; + + /* + * This points to an array of num_items drm_i915_query_item structures. + */ + __u64 items_ptr; +}; + +/* + * Data written by the kernel with query DRM_I915_QUERY_TOPOLOGY_INFO : + * + * data: contains the 3 pieces of information : + * + * - the slice mask with one bit per slice telling whether a slice is + * available. The availability of slice X can be queried with the following + * formula : + * + * (data[X / 8] >> (X % 8)) & 1 + * + * - the subslice mask for each slice with one bit per subslice telling + * whether a subslice is available. The availability of subslice Y in slice + * X can be queried with the following formula : + * + * (data[subslice_offset + + * X * subslice_stride + + * Y / 8] >> (Y % 8)) & 1 + * + * - the EU mask for each subslice in each slice with one bit per EU telling + * whether an EU is available. The availability of EU Z in subslice Y in + * slice X can be queried with the following formula : + * + * (data[eu_offset + + * (X * max_subslices + Y) * eu_stride + + * Z / 8] >> (Z % 8)) & 1 + */ +struct drm_i915_query_topology_info { + /* + * Unused for now. Must be cleared to zero. + */ + __u16 flags; + + __u16 max_slices; + __u16 max_subslices; + __u16 max_eus_per_subslice; + + /* + * Offset in data[] at which the subslice masks are stored. + */ + __u16 subslice_offset; + + /* + * Stride at which each of the subslice masks for each slice are + * stored. + */ + __u16 subslice_stride; + + /* + * Offset in data[] at which the EU masks are stored. + */ + __u16 eu_offset; + + /* + * Stride at which each of the EU masks for each subslice are stored. + */ + __u16 eu_stride; + + __u8 data[]; +}; + #if defined(__cplusplus) } #endif diff --git a/usr/src/uts/sparc/Makefile.files b/usr/src/uts/sparc/Makefile.files index 1c005685..99d805ac 100644 --- a/usr/src/uts/sparc/Makefile.files +++ b/usr/src/uts/sparc/Makefile.files @@ -69,8 +69,3 @@ MODSTUB_OBJ = modstubs.o LINT_DEFS += -Dsparc INC_PATH += -I$(UTSBASE)/sparc INC_PATH += -I$(UTSBASE)/sparc/krtld - -# -# Inlined assembler routines. -# -INLINES += $(UTSBASE)/sparc/ml/sparc.il diff --git a/usr/src/uts/sparc/Makefile.sparc b/usr/src/uts/sparc/Makefile.sparc index 990ccea2..06ea64b6 100644 --- a/usr/src/uts/sparc/Makefile.sparc +++ b/usr/src/uts/sparc/Makefile.sparc @@ -77,8 +77,6 @@ LINT64_FILES = $(LINT64_DIRS:%=%/llib-l$(MODULE).ln) # interfaces.) # include $(UTSBASE)/sparc/Makefile.files -include $(UTSBASE)/sparc/v9/Makefile.files -include $(UTSBASE)/sun/Makefile.files include $(UTSBASE)/common/Makefile.files # @@ -202,7 +200,7 @@ ALL_DEFS = $(MACHINE_DEFS) $(DEBUG_DEFS) $(OPTION_DEFS) # # Common Drivers (usually pseudo drivers) (/kernel/drv): # -DRV_KMODS += foo +DRV_KMODS += # # Exec Class Modules (/kernel/exec): @@ -232,7 +230,7 @@ SYS_KMODS += # # 'User' Modules (/kernel/misc): # -MISC_KMODS += +MISC_KMODS += drm # # Software Cryptographic Providers (/kernel/crypto): diff --git a/usr/src/uts/sparc/drm/Makefile b/usr/src/uts/sparc/drm/Makefile new file mode 100644 index 00000000..c5b0c5cf --- /dev/null +++ b/usr/src/uts/sparc/drm/Makefile @@ -0,0 +1,101 @@ +# +# CDDL HEADER START +# +# The contents of this file are subject to the terms of the +# Common Development and Distribution License (the "License"). +# You may not use this file except in compliance with the License. +# +# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE +# or http://www.opensolaris.org/os/licensing. +# See the License for the specific language governing permissions +# and limitations under the License. +# +# When distributing Covered Code, include this CDDL HEADER in each +# file and include the License file at usr/src/OPENSOLARIS.LICENSE. +# If applicable, add the following below this CDDL HEADER, with the +# fields enclosed by brackets "[]" replaced with your own identifying +# information: Portions Copyright [yyyy] [name of copyright owner] +# +# CDDL HEADER END +# + +# +# Copyright 2008 Sun Microsystems, Inc. All rights reserved. +# Use is subject to license terms. +# Copyright 2021 Klaus Ziegler +# + +# +# This makefile drives the production of the DRM (Direct Rendering +# Manager) common misc module. +# +# Path to the base of the uts directory tree (usually /usr/src/uts). +# +UTSBASE = ../.. + +# +# Define the module and object file sets. +# +MODULE = drm +OBJECTS = $(DRM_OBJS:%=$(OBJS_DIR)/%) +LINTS = $(DRM_OBJS:%.o=$(LINTS_DIR)/%.ln) +ROOTMODULE = $(ROOT_MISC_DIR)/$(MODULE) + +CMN_DRM = $(UTSBASE)/common/drm + +# Includes +INC_PATH += -I$(CMN_DRM) + +# Dependency SPARC does not jet has a gfx_private +# hashed out - notice from Randy fishel. +# LDFLAGS += -dy -Nmisc/gfx_private + +# +# Include common rules. +# +include $(UTSBASE)/sparc/Makefile.sparc +include $(UTSBASE)/common/io/drm/Makefile.mod + +CERRWARN += -_gcc=-Wno-parentheses +CERRWARN += -_gcc=-Wno-unused-function +CERRWARN += -_gcc=-Wno-unused-variable + +# +# Define targets +# +ALL_TARGET = $(BINARY) +LINT_TARGET = $(MODULE).lint +INSTALL_TARGET = $(BINARY) $(ROOTMODULE) + +# +# Default build targets. +# +.KEEP_STATE: + +def: $(DEF_DEPS) + +all: $(ALL_DEPS) + +clean: $(CLEAN_DEPS) + +clobber: $(CLOBBER_DEPS) + +lint: $(LINT_DEPS) + +modlintlib: $(MODLINTLIB_DEPS) + +clean.lint: $(CLEAN_LINT_DEPS) + +install: $(INSTALL_DEPS) + +$(OBJS_DIR)/%.o: $(UTSBASE)/common/io/drm/%.c + $(COMPILE.c) -o $@ $< + $(CTFCONVERT_O) + +$(LINTS_DIR)/%.ln: $(UTSBASE)/common/io/drm/%.c + @($(LHEAD) $(LINT.c) $< $(LTAIL)) + +# +# Include common targets. +# +include $(UTSBASE)/sparc/Makefile.targ