diff options
author | Dave Airlie <airlied@starflyer.(none)> | 2005-07-10 03:31:26 -0400 |
---|---|---|
committer | Dave Airlie <airlied@linux.ie> | 2005-07-10 03:31:26 -0400 |
commit | cda173806644d2af22ffd9896eed8ef99b97d356 (patch) | |
tree | 374ad48818df951a03c59d54ec75d5b19d4a24c3 /drivers/char/drm/mga_drv.c | |
parent | ceb9c27aa7d61c70f4c75f017d9fbc9de50034f1 (diff) |
drm: add test for AGP devices and driver override for it.
Added device_is_agp callback to drm_driver. This function is called by the
platform-specific drm_device_is_agp function. Added implementation of this
function the the Linux-specific portion of the MGA driver to detect PCI G450
cards. Added code to the Linux-specific portion of the generic DRM layer to
not initialize AGP infrastructure if the card is not AGP (this matches what
already existed in BSD).
Fix up i810/i830 and i915 drivers to always return AGP as they don't always
report the capability.
Fix the MGA to not report AGP for a card that has an AGP chip behind a PCI
bridge.
From: Ian Romanick, Dave Airlie, Alan Hourihane
Signed-off-by: Dave Airlie <airlied@linux.ie>
Diffstat (limited to 'drivers/char/drm/mga_drv.c')
-rw-r--r-- | drivers/char/drm/mga_drv.c | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/drivers/char/drm/mga_drv.c b/drivers/char/drm/mga_drv.c index 844cca9cb29d..94af13bc66a4 100644 --- a/drivers/char/drm/mga_drv.c +++ b/drivers/char/drm/mga_drv.c | |||
@@ -38,6 +38,7 @@ | |||
38 | 38 | ||
39 | #include "drm_pciids.h" | 39 | #include "drm_pciids.h" |
40 | 40 | ||
41 | static int mga_driver_device_is_agp(drm_device_t * dev); | ||
41 | static int postinit( struct drm_device *dev, unsigned long flags ) | 42 | static int postinit( struct drm_device *dev, unsigned long flags ) |
42 | { | 43 | { |
43 | dev->counters += 3; | 44 | dev->counters += 3; |
@@ -81,6 +82,7 @@ static struct drm_driver driver = { | |||
81 | .driver_features = DRIVER_USE_AGP | DRIVER_REQUIRE_AGP | DRIVER_USE_MTRR | DRIVER_HAVE_DMA | DRIVER_HAVE_IRQ | DRIVER_IRQ_SHARED | DRIVER_IRQ_VBL, | 82 | .driver_features = DRIVER_USE_AGP | DRIVER_REQUIRE_AGP | DRIVER_USE_MTRR | DRIVER_HAVE_DMA | DRIVER_HAVE_IRQ | DRIVER_IRQ_SHARED | DRIVER_IRQ_VBL, |
82 | .pretakedown = mga_driver_pretakedown, | 83 | .pretakedown = mga_driver_pretakedown, |
83 | .dma_quiescent = mga_driver_dma_quiescent, | 84 | .dma_quiescent = mga_driver_dma_quiescent, |
85 | .device_is_agp = mga_driver_device_is_agp, | ||
84 | .vblank_wait = mga_driver_vblank_wait, | 86 | .vblank_wait = mga_driver_vblank_wait, |
85 | .irq_preinstall = mga_driver_irq_preinstall, | 87 | .irq_preinstall = mga_driver_irq_preinstall, |
86 | .irq_postinstall = mga_driver_irq_postinstall, | 88 | .irq_postinstall = mga_driver_irq_postinstall, |
@@ -128,3 +130,38 @@ module_exit(mga_exit); | |||
128 | MODULE_AUTHOR( DRIVER_AUTHOR ); | 130 | MODULE_AUTHOR( DRIVER_AUTHOR ); |
129 | MODULE_DESCRIPTION( DRIVER_DESC ); | 131 | MODULE_DESCRIPTION( DRIVER_DESC ); |
130 | MODULE_LICENSE("GPL and additional rights"); | 132 | MODULE_LICENSE("GPL and additional rights"); |
133 | |||
134 | /** | ||
135 | * Determine if the device really is AGP or not. | ||
136 | * | ||
137 | * In addition to the usual tests performed by \c drm_device_is_agp, this | ||
138 | * function detects PCI G450 cards that appear to the system exactly like | ||
139 | * AGP G450 cards. | ||
140 | * | ||
141 | * \param dev The device to be tested. | ||
142 | * | ||
143 | * \returns | ||
144 | * If the device is a PCI G450, zero is returned. Otherwise 2 is returned. | ||
145 | */ | ||
146 | int mga_driver_device_is_agp(drm_device_t * dev) | ||
147 | { | ||
148 | const struct pci_dev * const pdev = dev->pdev; | ||
149 | |||
150 | |||
151 | /* There are PCI versions of the G450. These cards have the | ||
152 | * same PCI ID as the AGP G450, but have an additional PCI-to-PCI | ||
153 | * bridge chip. We detect these cards, which are not currently | ||
154 | * supported by this driver, by looking at the device ID of the | ||
155 | * bus the "card" is on. If vendor is 0x3388 (Hint Corp) and the | ||
156 | * device is 0x0021 (HB6 Universal PCI-PCI bridge), we reject the | ||
157 | * device. | ||
158 | */ | ||
159 | |||
160 | if ( (pdev->device == 0x0525) | ||
161 | && (pdev->bus->self->vendor == 0x3388) | ||
162 | && (pdev->bus->self->device == 0x0021) ) { | ||
163 | return 0; | ||
164 | } | ||
165 | |||
166 | return 2; | ||
167 | } | ||