Skip site navigation (1)Skip section navigation (2)
Date:      Mon, 16 Jan 2017 23:05:23 +0000 (UTC)
From:      Baptiste Daroussin <bapt@FreeBSD.org>
To:        ports-committers@freebsd.org, svn-ports-all@freebsd.org, svn-ports-head@freebsd.org
Subject:   svn commit: r431708 - in head/graphics/libdrm: . files
Message-ID:  <201701162305.v0GN5NnQ005211@repo.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: bapt
Date: Mon Jan 16 23:05:23 2017
New Revision: 431708
URL: https://svnweb.freebsd.org/changeset/ports/431708

Log:
  Add support to find directly the drm device via libdevq the same
  way linux uses libudev
  
  PR:		214580
  Submitted by:	matthew@reztek.cz

Added:
  head/graphics/libdrm/files/Makefile.am   (contents, props changed)
  head/graphics/libdrm/files/configure.ac   (contents, props changed)
  head/graphics/libdrm/files/patch-Makefile.in   (contents, props changed)
  head/graphics/libdrm/files/patch-config.h.in   (contents, props changed)
  head/graphics/libdrm/files/patch-configure   (contents, props changed)
  head/graphics/libdrm/files/patch-xf86drm.c   (contents, props changed)
Modified:
  head/graphics/libdrm/Makefile
  head/graphics/libdrm/files/patch-xf86drmMode.c
  head/graphics/libdrm/pkg-plist

Modified: head/graphics/libdrm/Makefile
==============================================================================
--- head/graphics/libdrm/Makefile	Mon Jan 16 22:52:16 2017	(r431707)
+++ head/graphics/libdrm/Makefile	Mon Jan 16 23:05:23 2017	(r431708)
@@ -12,7 +12,9 @@ COMMENT=	Userspace interface to kernel D
 
 LICENSE=	MIT
 
+BUILD_DEPENDS=	libdevq>=0.0.4:devel/libdevq
 LIB_DEPENDS=	libpciaccess.so:devel/libpciaccess \
+		libdevq.so:devel/libdevq \
 		libpthread-stubs.so:devel/libpthread-stubs
 
 USES=		libtool pkgconfig tar:bzip2
@@ -33,10 +35,10 @@ USES+=		gmake
 # KMS support in the kernel is only build on these archs, disable others
 .if ${ARCH} == "amd64" || ${ARCH} == "i386"
 CONFIGURE_ARGS+=--enable-libkms
-PLIST_SUB+=	KMS="" NOUVEAU=""
+PLIST_SUB+=	KMS=""
 .else
 CONFIGURE_ARGS+=--disable-libkms
-PLIST_SUB+=	KMS="@comment " NOUVEAU="@comment "
+PLIST_SUB+=	KMS="@comment "
 .endif
 
 .if ${PORT_OPTIONS:MMANPAGES}
@@ -51,13 +53,24 @@ PLIST_SUB+=	MAN="@comment "
 CONFIGURE_ARGS+=--disable-vmwgfx
 
 .if ${ARCH} == amd64 || ${ARCH} == i386
+PLIST_SUB+=	ARM_DRIVERS="@comment "
 PLIST_SUB+=	INTEL_DRIVER=""
+PLIST_SUB+=	NOUVEAU_DRIVER=""
 PLIST_SUB+=	RADEON_DRIVERS=""
-.elif ${ARCH} == ia64 || ${ARCH} == powerpc || ${ARCH} == powerpc64
+.elif ${ARCH} == powerpc || ${ARCH} == powerpc64
+PLIST_SUB+=	ARM_DRIVERS="@comment "
 PLIST_SUB+=	INTEL_DRIVER="@comment "
+PLIST_SUB+=	NOUVEAU_DRIVER=""
 PLIST_SUB+=	RADEON_DRIVERS=""
+.elif ${ARCH} == arm6 || ${ARCH} == aarch64
+PLIST_SUB+=	ARM_DRIVERS=""
+PLIST_SUB+=	INTEL_DRIVER="@comment "
+PLIST_SUB+=	NOUVEAU_DRIVER="@comment "
+PLIST_SUB+=	RADEON_DRIVERS="@comment "
 .else
+PLIST_SUB+=	ARM_DRIVERS="@comment "
 PLIST_SUB+=	INTEL_DRIVER="@comment "
+PLIST_SUB+=	NOUVEAU_DRIVER="@comment "
 PLIST_SUB+=	RADEON_DRIVERS="@comment "
 .endif
 

Added: head/graphics/libdrm/files/Makefile.am
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/Makefile.am	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,14 @@
+--- Makefile.am.orig	2016-06-23 14:29:40.575882000 +0200
++++ Makefile.am	2016-06-23 14:38:48.752016000 +0200
+@@ -108,9 +108,9 @@
+ libdrm_la_LTLIBRARIES = libdrm.la
+ libdrm_ladir = $(libdir)
+ libdrm_la_LDFLAGS = -version-number 2:4:0 -no-undefined
+-libdrm_la_LIBADD = @CLOCK_LIB@ -lm
++libdrm_la_LIBADD = @CLOCK_LIB@ -lm @LIBDEVQ_LIBS@
+ 
+-libdrm_la_CPPFLAGS = -I$(top_srcdir)/include/drm
++libdrm_la_CPPFLAGS = -I$(top_srcdir)/include/drm @LIBDEVQ_CFLAGS@
+ AM_CFLAGS = \
+ 	$(WARN_CFLAGS) \
+ 	$(VALGRIND_CFLAGS)

Added: head/graphics/libdrm/files/configure.ac
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/configure.ac	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,39 @@
+--- configure.ac.orig	2016-04-28 02:52:47.000000000 +0200
++++ configure.ac	2016-07-09 18:53:39.021028000 +0200
+@@ -71,6 +71,11 @@
+                               [Enable support for using udev instead of mknod (default: disabled)])],
+               [UDEV=$enableval], [UDEV=no])
+ 
++AC_ARG_ENABLE([devq],
++              [AS_HELP_STRING([--enable-devq],
++                              [Enable support for using devq for device detection (default: disabled)])],
++              [DEVQ=$enableval], [DEVQ=no])
++
+ AC_ARG_ENABLE(libkms,
+ 	      AS_HELP_STRING([--disable-libkms],
+ 	      [Disable KMS mm abstraction library (default: auto, enabled on supported platforms)]),
+@@ -313,6 +318,10 @@
+ 	AC_DEFINE(UDEV, 1, [Have UDEV support])
+ fi
+ 
++if test "x$DEVQ" = xyes; then
++	AC_DEFINE(DEVQ, 1, [Have DEVQ support])
++fi
++
+ AC_CANONICAL_HOST
+ if test "x$LIBKMS" = xauto ; then
+ 	case $host_os in
+@@ -444,6 +453,13 @@
+ fi
+ AM_CONDITIONAL(HAVE_LIBUDEV, [test "x$HAVE_LIBUDEV" = xyes])
+ 
++# For FreeBSD support
++PKG_CHECK_MODULES([LIBDEVQ], [libdevq-1.0 >= 0.0.4], [HAVE_LIBDEVQ=yes], [HAVE_LIBDEVQ=no])
++if test "x$HAVE_LIBDEVQ" = xyes; then
++	AC_DEFINE(HAVE_LIBDEVQ, 1, [Have libdevq support])
++fi
++AM_CONDITIONAL(HAVE_LIBDEVQ, [test "x$HAVE_LIBDEVQ" = xyes])
++
+ # xsltproc for docbook manpages
+ AC_ARG_ENABLE([manpages],
+               AS_HELP_STRING([--enable-manpages], [enable manpages @<:@default=auto@:>@]),

Added: head/graphics/libdrm/files/patch-Makefile.in
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/patch-Makefile.in	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,13 @@
+--- Makefile.in.orig	2016-11-29 13:34:56 UTC
++++ Makefile.in
+@@ -564,8 +564,8 @@ SUBDIRS = \
+ libdrm_la_LTLIBRARIES = libdrm.la
+ libdrm_ladir = $(libdir)
+ libdrm_la_LDFLAGS = -version-number 2:4:0 -no-undefined
+-libdrm_la_LIBADD = @CLOCK_LIB@ -lm
+-libdrm_la_CPPFLAGS = -I$(top_srcdir)/include/drm
++libdrm_la_LIBADD = @CLOCK_LIB@ -lm @LIBDEVQ_LIBS@
++libdrm_la_CPPFLAGS = -I$(top_srcdir)/include/drm @LIBDEVQ_CFLAGS@
+ AM_CFLAGS = \
+ 	$(WARN_CFLAGS) \
+ 	$(VALGRIND_CFLAGS)

Added: head/graphics/libdrm/files/patch-config.h.in
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/patch-config.h.in	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,22 @@
+--- config.h.in.orig	2016-11-29 13:34:54 UTC
++++ config.h.in
+@@ -8,6 +8,9 @@
+ /* Define to 1 if using `alloca.c'. */
+ #undef C_ALLOCA
+ 
++/* Have DEVQ support */
++#undef DEVQ
++
+ /* Define to 1 if you have `alloca', as a function or macro. */
+ #undef HAVE_ALLOCA
+ 
+@@ -51,6 +54,9 @@
+ /* Define to 1 if you have the <inttypes.h> header file. */
+ #undef HAVE_INTTYPES_H
+ 
++/* Have libdevq support */
++#undef HAVE_LIBDEVQ
++
+ /* Enable if your compiler supports the Intel __sync_* atomic primitives */
+ #undef HAVE_LIBDRM_ATOMIC_PRIMITIVES
+ 

Added: head/graphics/libdrm/files/patch-configure
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/patch-configure	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,182 @@
+--- configure.orig	2017-01-15 13:16:10 UTC
++++ configure
+@@ -646,6 +646,10 @@ HAVE_MANPAGES_STYLESHEET_TRUE
+ MANPAGES_STYLESHEET
+ BUILD_MANPAGES_FALSE
+ BUILD_MANPAGES_TRUE
++HAVE_LIBDEVQ_FALSE
++HAVE_LIBDEVQ_TRUE
++LIBDEVQ_LIBS
++LIBDEVQ_CFLAGS
+ HAVE_LIBUDEV_FALSE
+ HAVE_LIBUDEV_TRUE
+ LIBUDEV_LIBS
+@@ -842,6 +846,7 @@ with_gnu_ld
+ with_sysroot
+ enable_libtool_lock
+ enable_udev
++enable_devq
+ enable_libkms
+ enable_intel
+ enable_radeon
+@@ -885,6 +890,8 @@ CAIRO_CFLAGS
+ CAIRO_LIBS
+ LIBUDEV_CFLAGS
+ LIBUDEV_LIBS
++LIBDEVQ_CFLAGS
++LIBDEVQ_LIBS
+ VALGRIND_CFLAGS
+ VALGRIND_LIBS'
+ 
+@@ -1519,6 +1526,8 @@ Optional Features:
+   --disable-libtool-lock  avoid locking (might break parallel builds)
+   --enable-udev           Enable support for using udev instead of mknod
+                           (default: disabled)
++  --enable-devq           Enable support for using devq for device detection
++                          (default: disabled)
+   --disable-libkms        Disable KMS mm abstraction library (default: auto,
+                           enabled on supported platforms)
+   --disable-intel         Enable support for intel's KMS API (default: auto,
+@@ -1602,6 +1611,10 @@ Some influential environment variables:
+               C compiler flags for LIBUDEV, overriding pkg-config
+   LIBUDEV_LIBS
+               linker flags for LIBUDEV, overriding pkg-config
++  LIBDEVQ_CFLAGS
++              C compiler flags for LIBDEVQ, overriding pkg-config
++  LIBDEVQ_LIBS
++              linker flags for LIBDEVQ, overriding pkg-config
+   VALGRIND_CFLAGS
+               C compiler flags for VALGRIND, overriding pkg-config
+   VALGRIND_LIBS
+@@ -13440,6 +13453,14 @@ else
+ fi
+ 
+ 
++# Check whether --enable-devq was given.
++if test "${enable_devq+set}" = set; then :
++  enableval=$enable_devq; DEVQ=$enableval
++else
++  DEVQ=no
++fi
++
++
+ # Check whether --enable-libkms was given.
+ if test "${enable_libkms+set}" = set; then :
+   enableval=$enable_libkms; LIBKMS=$enableval
+@@ -13976,6 +13997,12 @@ $as_echo "#define UDEV 1" >>confdefs.h
+ 
+ fi
+ 
++if test "x$DEVQ" = xyes; then
++
++$as_echo "#define DEVQ 1" >>confdefs.h
++
++fi
++
+ 
+ if test "x$LIBKMS" = xauto ; then
+ 	case $host_os in
+@@ -14520,6 +14547,92 @@ else
+ fi
+ 
+ 
++# For FreeBSD support
++
++pkg_failed=no
++{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for LIBDEVQ" >&5
++$as_echo_n "checking for LIBDEVQ... " >&6; }
++
++if test -n "$LIBDEVQ_CFLAGS"; then
++    pkg_cv_LIBDEVQ_CFLAGS="$LIBDEVQ_CFLAGS"
++ elif test -n "$PKG_CONFIG"; then
++    if test -n "$PKG_CONFIG" && \
++    { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"libdevq-1.0 >= 0.0.4\""; } >&5
++  ($PKG_CONFIG --exists --print-errors "libdevq-1.0 >= 0.0.4") 2>&5
++  ac_status=$?
++  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
++  test $ac_status = 0; }; then
++  pkg_cv_LIBDEVQ_CFLAGS=`$PKG_CONFIG --cflags "libdevq-1.0 >= 0.0.4" 2>/dev/null`
++		      test "x$?" != "x0" && pkg_failed=yes
++else
++  pkg_failed=yes
++fi
++ else
++    pkg_failed=untried
++fi
++if test -n "$LIBDEVQ_LIBS"; then
++    pkg_cv_LIBDEVQ_LIBS="$LIBDEVQ_LIBS"
++ elif test -n "$PKG_CONFIG"; then
++    if test -n "$PKG_CONFIG" && \
++    { { $as_echo "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"libdevq-1.0 >= 0.0.4\""; } >&5
++  ($PKG_CONFIG --exists --print-errors "libdevq-1.0 >= 0.0.4") 2>&5
++  ac_status=$?
++  $as_echo "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5
++  test $ac_status = 0; }; then
++  pkg_cv_LIBDEVQ_LIBS=`$PKG_CONFIG --libs "libdevq-1.0 >= 0.0.4" 2>/dev/null`
++		      test "x$?" != "x0" && pkg_failed=yes
++else
++  pkg_failed=yes
++fi
++ else
++    pkg_failed=untried
++fi
++
++
++
++if test $pkg_failed = yes; then
++   	{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
++$as_echo "no" >&6; }
++
++if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then
++        _pkg_short_errors_supported=yes
++else
++        _pkg_short_errors_supported=no
++fi
++        if test $_pkg_short_errors_supported = yes; then
++	        LIBDEVQ_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "libdevq-1.0 >= 0.0.4" 2>&1`
++        else
++	        LIBDEVQ_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "libdevq-1.0 >= 0.0.4" 2>&1`
++        fi
++	# Put the nasty error message in config.log where it belongs
++	echo "$LIBDEVQ_PKG_ERRORS" >&5
++
++	HAVE_LIBDEVQ=no
++elif test $pkg_failed = untried; then
++     	{ $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
++$as_echo "no" >&6; }
++	HAVE_LIBDEVQ=no
++else
++	LIBDEVQ_CFLAGS=$pkg_cv_LIBDEVQ_CFLAGS
++	LIBDEVQ_LIBS=$pkg_cv_LIBDEVQ_LIBS
++        { $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
++$as_echo "yes" >&6; }
++	HAVE_LIBDEVQ=yes
++fi
++if test "x$HAVE_LIBDEVQ" = xyes; then
++
++$as_echo "#define HAVE_LIBDEVQ 1" >>confdefs.h
++
++fi
++ if test "x$HAVE_LIBDEVQ" = xyes; then
++  HAVE_LIBDEVQ_TRUE=
++  HAVE_LIBDEVQ_FALSE='#'
++else
++  HAVE_LIBDEVQ_TRUE='#'
++  HAVE_LIBDEVQ_FALSE=
++fi
++
++
+ # xsltproc for docbook manpages
+ # Check whether --enable-manpages was given.
+ if test "${enable_manpages+set}" = set; then :
+@@ -14930,6 +15043,10 @@ if test -z "${HAVE_LIBUDEV_TRUE}" && tes
+   as_fn_error $? "conditional \"HAVE_LIBUDEV\" was never defined.
+ Usually this means the macro was only invoked conditionally." "$LINENO" 5
+ fi
++if test -z "${HAVE_LIBDEVQ_TRUE}" && test -z "${HAVE_LIBDEVQ_FALSE}"; then
++  as_fn_error $? "conditional \"HAVE_LIBDEVQ\" was never defined.
++Usually this means the macro was only invoked conditionally." "$LINENO" 5
++fi
+ if test -z "${BUILD_MANPAGES_TRUE}" && test -z "${BUILD_MANPAGES_FALSE}"; then
+   as_fn_error $? "conditional \"BUILD_MANPAGES\" was never defined.
+ Usually this means the macro was only invoked conditionally." "$LINENO" 5

Added: head/graphics/libdrm/files/patch-xf86drm.c
==============================================================================
--- /dev/null	00:00:00 1970	(empty, because file is newly added)
+++ head/graphics/libdrm/files/patch-xf86drm.c	Mon Jan 16 23:05:23 2017	(r431708)
@@ -0,0 +1,187 @@
+--- xf86drm.c.orig	2017-01-15 13:16:10 UTC
++++ xf86drm.c
+@@ -62,6 +62,10 @@
+ #endif
+ #include <math.h>
+ 
++#ifdef HAVE_LIBDEVQ
++#include "libdevq.h"
++#endif
++
+ /* Not all systems have MAP_FAILED defined */
+ #ifndef MAP_FAILED
+ #define MAP_FAILED ((void *)-1)
+@@ -82,8 +86,12 @@
+ #define DRM_RENDER_MINOR_NAME   "renderD"
+ #endif
+ 
+-#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__DragonFly__)
+-#define DRM_MAJOR 145
++#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__)
++#define DRM_MAJOR 0
++#endif
++
++#if defined(__DragonFly__)
++#define DRM_MAJOR 65 /* was 145 XXX needs checking */
+ #endif
+ 
+ #ifdef __NetBSD__
+@@ -532,6 +540,7 @@ static int drmGetMinorType(int minor)
+     }
+ }
+ 
++#if !defined(__FreeBSD__) && !defined(__DragonFly__)
+ static const char *drmGetMinorName(int type)
+ {
+     switch (type) {
+@@ -545,6 +554,7 @@ static const char *drmGetMinorName(int t
+         return NULL;
+     }
+ }
++#endif
+ 
+ /**
+  * Open the device by bus ID.
+@@ -2817,6 +2827,15 @@ static char *drmGetMinorNameForFD(int fd
+ 
+ out_close_dir:
+     closedir(sysdir);
++#elif defined(__FreeBSD__) || defined(__DragonFly__)
++    struct stat buf;
++    char name[64];
++
++    fstat(fd, &buf);
++    snprintf(name, sizeof(name), "/dev/%s",
++             devname(buf.st_rdev, S_IFCHR));
++
++    return strdup(name);
+ #else
+ #warning "Missing implementation of drmGetMinorNameForFD"
+ #endif
+@@ -2854,12 +2873,19 @@ static int drmParseSubsystemType(int maj
+         return DRM_BUS_PCI;
+ 
+     return -EINVAL;
++#elif defined(__FreeBSD__) || defined(__DragonFly__)
++    /* XXX: Don't know how to get the subsystem type, hardcode for now.
++     * The code following the call to this function needs depends on
++     * information provided by the /pci subsystem on linux. No replacement
++     * found yet for FreeBSD. */
++    return DRM_BUS_PCI;
+ #else
+ #warning "Missing implementation of drmParseSubsystemType"
+     return -EINVAL;
+ #endif
+ }
+ 
++#if !defined(__FreeBSD__) && !defined(__DragonFly__)
+ static int drmParsePciBusInfo(int maj, int min, drmPciBusInfoPtr info)
+ {
+ #ifdef __linux__
+@@ -2901,6 +2927,61 @@ static int drmParsePciBusInfo(int maj, i
+     return -EINVAL;
+ #endif
+ }
++#else
++
++/*
++ * XXX temporary workaround, because FreeBSD doesn't provide 
++ * pcibus device sysctl trees for renderD and controlD nodes (yet)
++ */
++static void
++drmBSDDeviceNameHack(const char *path, char *hacked_path, int length)
++{
++    int start, number;
++    const char *errstr;
++
++    if (strcmp(path, DRM_DIR_NAME "/controlD") > 0) {
++        start = 17;
++        number = strtonum(&path[start], 0, 256, &errstr) - 64;
++        snprintf(hacked_path, length, DRM_DIR_NAME "/card%i", number);
++    } else if (strcmp(path, DRM_DIR_NAME "/renderD") > 0) {
++        start = 16;
++        number = strtonum(&path[start], 0, 256, &errstr) - 128;
++        snprintf(hacked_path, length, DRM_DIR_NAME "/card%i", number);
++    } else
++        snprintf(hacked_path, length, "%s", path);
++
++  return;
++}
++
++static int
++drmParsePciBusInfoBSD(const char *path, drmPciBusInfoPtr info)
++{
++    int fd, ret;
++    int domain = 0, bus = 0, slot = 0, function = 0;
++    char hacked_path[PATH_MAX + 1];
++
++    drmBSDDeviceNameHack(path, hacked_path, PATH_MAX);
++    fd = open(hacked_path, O_RDONLY);
++
++    if (fd < 0)
++        return -errno;
++
++    ret = devq_device_get_pcibusaddr(fd, &domain, &bus, &slot, &function);
++
++    if (ret < 0) {
++        close(fd);
++        return -1;
++    }
++
++    info->domain = (uint16_t) domain;
++    info->bus = (uint8_t) bus;
++    info->dev = (uint8_t) slot;
++    info->func = (uint8_t) function;
++
++    close(fd);
++    return 0;
++}
++#endif
+ 
+ static int drmCompareBusInfo(drmDevicePtr a, drmDevicePtr b)
+ {
+@@ -2971,6 +3052,31 @@ static int drmParsePciDeviceInfo(const c
+     device->subdevice_id = config[46] | (config[47] << 8);
+ 
+     return 0;
++#elif defined(__FreeBSD__) || defined(__DragonFly__)
++    int fd, vendor_id = 0, device_id = 0, subvendor_id = 0, 
++        subdevice_id = 0, revision_id = 0;
++    char path[PATH_MAX + 1];
++    char hacked_path[PATH_MAX + 1];
++
++    snprintf(path, PATH_MAX, DRM_DIR_NAME "/%s", d_name);
++    drmBSDDeviceNameHack(path, hacked_path, PATH_MAX);
++
++    fd = open(hacked_path, O_RDONLY);
++
++    if (fd < 0)
++        return -errno;
++
++    devq_device_get_pciid_full_from_fd(fd, &vendor_id, &device_id,
++	&subvendor_id, &subdevice_id, &revision_id);
++
++    device->vendor_id = (uint16_t) vendor_id;
++    device->device_id = (uint16_t) device_id;
++    device->subvendor_id = (uint16_t) subvendor_id;
++    device->subdevice_id = (uint16_t) subdevice_id;
++    device->revision_id = (uint8_t) revision_id;
++
++    close(fd);
++    return 0;
+ #else
+ #warning "Missing implementation of drmParsePciDeviceInfo"
+     return -EINVAL;
+@@ -3030,7 +3136,12 @@ static int drmProcessPciDevice(drmDevice
+ 
+     (*device)->businfo.pci = (drmPciBusInfoPtr)addr;
+ 
++#if defined(__FreeBSD__) || defined(__DragonFly__)
++    ret = drmParsePciBusInfoBSD(node, (*device)->businfo.pci);
++#else
+     ret = drmParsePciBusInfo(maj, min, (*device)->businfo.pci);
++#endif
++
+     if (ret)
+         goto free_device;
+ 

Modified: head/graphics/libdrm/files/patch-xf86drmMode.c
==============================================================================
--- head/graphics/libdrm/files/patch-xf86drmMode.c	Mon Jan 16 22:52:16 2017	(r431707)
+++ head/graphics/libdrm/files/patch-xf86drmMode.c	Mon Jan 16 23:05:23 2017	(r431708)
@@ -2,8 +2,8 @@ Disable checking for hw.dri.%d.modesetti
 This sysctl is only available if a KMS module is loaded. But the libdrm
 check happens before X got a chance of loading the KMS module.
 
---- xf86drmMode.c.orig	2015-08-21 16:50:01.000000000 +0200
-+++ xf86drmMode.c	2015-10-20 17:34:48.000000000 +0200
+--- xf86drmMode.c.orig	2016-11-29 11:15:10 UTC
++++ xf86drmMode.c
 @@ -47,6 +47,7 @@
  #include <stdlib.h>
  #include <sys/ioctl.h>
@@ -12,7 +12,7 @@ check happens before X got a chance of l
  #include <sys/sysctl.h>
  #endif
  #include <stdio.h>
-@@ -781,38 +782,7 @@ int drmCheckModesettingSupported(const c
+@@ -797,38 +798,7 @@ int drmCheckModesettingSupported(const c
  	if (found)
  		return 0;
  #elif defined (__FreeBSD__) || defined (__FreeBSD_kernel__)

Modified: head/graphics/libdrm/pkg-plist
==============================================================================
--- head/graphics/libdrm/pkg-plist	Mon Jan 16 22:52:16 2017	(r431707)
+++ head/graphics/libdrm/pkg-plist	Mon Jan 16 23:05:23 2017	(r431708)
@@ -10,14 +10,14 @@ include/libdrm/i915_drm.h
 %%INTEL_DRIVER%%include/libdrm/intel_debug.h
 include/libdrm/mach64_drm.h
 include/libdrm/mga_drm.h
-%%NOUVEAU%%include/libdrm/nouveau/nouveau.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/cl0080.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/cl9097.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/class.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/if0002.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/if0003.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/ioctl.h
-%%NOUVEAU%%include/libdrm/nouveau/nvif/unpack.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nouveau.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/cl0080.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/cl9097.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/class.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/if0002.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/if0003.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/ioctl.h
+%%NOUVEAU_DRIVER%%include/libdrm/nouveau/nvif/unpack.h
 include/libdrm/nouveau_drm.h
 include/libdrm/qxl_drm.h
 include/libdrm/r128_drm.h
@@ -33,11 +33,13 @@ include/libdrm/radeon_drm.h
 include/libdrm/savage_drm.h
 include/libdrm/sis_drm.h
 include/libdrm/tegra_drm.h
-include/libdrm/via_drm.h
 include/libdrm/vc4_drm.h
+%%ARM_DRIVERS%%include/libdrm/vc4_packet.h
+%%ARM_DRIVERS%%include/libdrm/vc4_gpq_defines.h
+include/libdrm/via_drm.h
 include/libdrm/virtgpu_drm.h
-include/libsync.h
 %%KMS%%include/libkms/libkms.h
+include/libsync.h
 include/xf86drm.h
 include/xf86drmMode.h
 lib/libdrm.so
@@ -49,20 +51,24 @@ lib/libdrm.so.2.4.0
 %%INTEL_DRIVER%%lib/libdrm_intel.so
 %%INTEL_DRIVER%%lib/libdrm_intel.so.1
 %%INTEL_DRIVER%%lib/libdrm_intel.so.1.0.0
-%%NOUVEAU%%lib/libdrm_nouveau.so
-%%NOUVEAU%%lib/libdrm_nouveau.so.2
-%%NOUVEAU%%lib/libdrm_nouveau.so.2.0.0
+%%NOUVEAU_DRIVER%%lib/libdrm_nouveau.so
+%%NOUVEAU_DRIVER%%lib/libdrm_nouveau.so.2
+%%NOUVEAU_DRIVER%%lib/libdrm_nouveau.so.2.0.0
 %%RADEON_DRIVERS%%lib/libdrm_radeon.so
 %%RADEON_DRIVERS%%lib/libdrm_radeon.so.1
 %%RADEON_DRIVERS%%lib/libdrm_radeon.so.1.0.1
+%%ARM_DRIVERS%%lib/libdrm_vc4.so
+%%ARM_DRIVERS%%lib/libdrm_vc4.so.1
+%%ARM_DRIVERS%%lib/libdrm_vc4.so.1.0.0
 %%KMS%%lib/libkms.so
 %%KMS%%lib/libkms.so.1
 %%KMS%%lib/libkms.so.1.0.0
 libdata/pkgconfig/libdrm.pc
 %%RADEON_DRIVERS%%libdata/pkgconfig/libdrm_amdgpu.pc
 %%INTEL_DRIVER%%libdata/pkgconfig/libdrm_intel.pc
-%%NOUVEAU%%libdata/pkgconfig/libdrm_nouveau.pc
+%%NOUVEAU_DRIVER%%libdata/pkgconfig/libdrm_nouveau.pc
 %%RADEON_DRIVERS%%libdata/pkgconfig/libdrm_radeon.pc
+%%ARM_DRIVERS%%libdata/pkgconfig/libdrm_vc4.pc
 %%KMS%%libdata/pkgconfig/libkms.pc
 %%MAN%%man/man3/drmAvailable.3.gz
 %%MAN%%man/man3/drmHandleEvent.3.gz



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?201701162305.v0GN5NnQ005211>