aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/char/agp/intel-agp.c24
1 files changed, 15 insertions, 9 deletions
diff --git a/drivers/char/agp/intel-agp.c b/drivers/char/agp/intel-agp.c
index ddf5def1b0da..ab1903955ac0 100644
--- a/drivers/char/agp/intel-agp.c
+++ b/drivers/char/agp/intel-agp.c
@@ -825,7 +825,8 @@ static const struct intel_driver_description {
825static int __devinit intel_gmch_probe(struct pci_dev *pdev, 825static int __devinit intel_gmch_probe(struct pci_dev *pdev,
826 struct agp_bridge_data *bridge) 826 struct agp_bridge_data *bridge)
827{ 827{
828 int i; 828 int i, mask;
829
829 bridge->driver = NULL; 830 bridge->driver = NULL;
830 831
831 for (i = 0; intel_agp_chipsets[i].name != NULL; i++) { 832 for (i = 0; intel_agp_chipsets[i].name != NULL; i++) {
@@ -845,14 +846,19 @@ static int __devinit intel_gmch_probe(struct pci_dev *pdev,
845 846
846 dev_info(&pdev->dev, "Intel %s Chipset\n", intel_agp_chipsets[i].name); 847 dev_info(&pdev->dev, "Intel %s Chipset\n", intel_agp_chipsets[i].name);
847 848
848 if (bridge->driver->mask_memory == intel_i965_mask_memory) { 849 if (bridge->driver->mask_memory == intel_gen6_mask_memory)
849 if (pci_set_dma_mask(intel_private.pcidev, DMA_BIT_MASK(36))) 850 mask = 40;
850 dev_err(&intel_private.pcidev->dev, 851 else if (bridge->driver->mask_memory == intel_i965_mask_memory)
851 "set gfx device dma mask 36bit failed!\n"); 852 mask = 36;
852 else 853 else
853 pci_set_consistent_dma_mask(intel_private.pcidev, 854 mask = 32;
854 DMA_BIT_MASK(36)); 855
855 } 856 if (pci_set_dma_mask(intel_private.pcidev, DMA_BIT_MASK(mask)))
857 dev_err(&intel_private.pcidev->dev,
858 "set gfx device dma mask %d-bit failed!\n", mask);
859 else
860 pci_set_consistent_dma_mask(intel_private.pcidev,
861 DMA_BIT_MASK(mask));
856 862
857 return 1; 863 return 1;
858} 864}