diff options
author | rnoland <rnoland@FreeBSD.org> | 2009-03-02 02:22:02 +0800 |
---|---|---|
committer | rnoland <rnoland@FreeBSD.org> | 2009-03-02 02:22:02 +0800 |
commit | 9f8efeab8ec8bcad0b621d12f96f06ce6c802776 (patch) | |
tree | ce653eb65dbd7b44c458d0fa5f564bb6d2ade81c /x11-drivers | |
parent | 92cdb6da9b77b2ab80a3bc2a9ff7b6ad06cee17c (diff) | |
download | freebsd-ports-gnome-9f8efeab8ec8bcad0b621d12f96f06ce6c802776.tar.gz freebsd-ports-gnome-9f8efeab8ec8bcad0b621d12f96f06ce6c802776.tar.zst freebsd-ports-gnome-9f8efeab8ec8bcad0b621d12f96f06ce6c802776.zip |
The nv driver was somewhat brain-damaged, it was detecting most all
of the devices on the system as possible video devices. Pull in
a patch from git to at least try to address this.
Diffstat (limited to 'x11-drivers')
-rw-r--r-- | x11-drivers/xf86-video-nv/Makefile | 2 | ||||
-rw-r--r-- | x11-drivers/xf86-video-nv/files/patch-src-g80_driver.c | 16 | ||||
-rw-r--r-- | x11-drivers/xf86-video-nv/files/patch-src-nv_driver.c | 29 |
3 files changed, 46 insertions, 1 deletions
diff --git a/x11-drivers/xf86-video-nv/Makefile b/x11-drivers/xf86-video-nv/Makefile index 9562642c1965..fb958ef82124 100644 --- a/x11-drivers/xf86-video-nv/Makefile +++ b/x11-drivers/xf86-video-nv/Makefile @@ -7,7 +7,7 @@ PORTNAME= xf86-video-nv PORTVERSION= 2.1.12 -PORTREVISION= 1 +PORTREVISION= 2 CATEGORIES= x11-drivers MAINTAINER= x11@FreeBSD.org diff --git a/x11-drivers/xf86-video-nv/files/patch-src-g80_driver.c b/x11-drivers/xf86-video-nv/files/patch-src-g80_driver.c new file mode 100644 index 000000000000..1a1f88f6ba25 --- /dev/null +++ b/x11-drivers/xf86-video-nv/files/patch-src-g80_driver.c @@ -0,0 +1,16 @@ +--- src/g80_driver.c.orig 2008-08-04 17:08:54.000000000 -0500 ++++ src/g80_driver.c 2009-02-28 20:24:36.000000000 -0600 +@@ -206,11 +206,8 @@ + CARD32 tmp; + memType BAR1sizeKB; + +- if(flags & PROBE_DETECT) { +- xf86DrvMsg(pScrn->scrnIndex, X_ERROR, +- "G80 PROBE_DETECT unimplemented\n"); +- return FALSE; +- } ++ if(flags & PROBE_DETECT) ++ return TRUE; + + /* Check the number of entities, and fail if it isn't one. */ + if(pScrn->numEntities != 1) diff --git a/x11-drivers/xf86-video-nv/files/patch-src-nv_driver.c b/x11-drivers/xf86-video-nv/files/patch-src-nv_driver.c new file mode 100644 index 000000000000..87261c525dab --- /dev/null +++ b/x11-drivers/xf86-video-nv/files/patch-src-nv_driver.c @@ -0,0 +1,29 @@ +--- src/nv_driver.c.orig 2008-08-26 15:46:19.000000000 -0500 ++++ src/nv_driver.c 2009-02-28 20:24:36.000000000 -0600 +@@ -77,11 +77,22 @@ + static Bool NVSetModeVBE(ScrnInfoPtr pScrn, DisplayModePtr pMode); + + #if XSERVER_LIBPCIACCESS +-/* For now, just match any NVIDIA PCI device and sort through them in the probe +- * routine */ ++/* For now, just match any NVIDIA display device and sort through them in the ++ * probe routine */ ++ ++/* ++ * libpciaccess's masks are shifted by 8 bits compared to the ones in xf86Pci.h. ++ */ ++#define LIBPCIACCESS_CLASS_SHIFT (PCI_CLASS_SHIFT - 8) ++#define LIBPCIACCESS_CLASS_MASK (PCI_CLASS_MASK >> 8) ++ + static const struct pci_id_match NVPciIdMatchList[] = { +- { PCI_VENDOR_NVIDIA, PCI_MATCH_ANY, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, 0 }, +- { PCI_VENDOR_NVIDIA_SGS, PCI_MATCH_ANY, PCI_MATCH_ANY, PCI_MATCH_ANY, 0, 0, 0}, ++ { PCI_VENDOR_NVIDIA, PCI_MATCH_ANY, PCI_MATCH_ANY, PCI_MATCH_ANY, ++ PCI_CLASS_DISPLAY << LIBPCIACCESS_CLASS_SHIFT, LIBPCIACCESS_CLASS_MASK, 0 }, ++ ++ { PCI_VENDOR_NVIDIA_SGS, PCI_MATCH_ANY, PCI_MATCH_ANY, PCI_MATCH_ANY, ++ PCI_CLASS_DISPLAY << LIBPCIACCESS_CLASS_SHIFT, LIBPCIACCESS_CLASS_MASK, 0 }, ++ + { 0, 0, 0 } + }; + #endif |