aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Airlie <airlied@redhat.com>2011-03-02 12:48:23 +1000
committerDave Airlie <airlied@redhat.com>2011-03-02 12:48:23 +1000
commit0366ebbf94cfafbdb1fd8c30da47a945294fe1a1 (patch)
tree188a4118f0df3d92200f02678b4458c645476ed7
parentdd9c1549edef02290edced639f67b54a25abbe0e (diff)
parent6927faf30920b8c03dfa007e732642a1f1f20089 (diff)
downloadkernel_samsung_smdk4412-0366ebbf94cfafbdb1fd8c30da47a945294fe1a1.zip
kernel_samsung_smdk4412-0366ebbf94cfafbdb1fd8c30da47a945294fe1a1.tar.gz
kernel_samsung_smdk4412-0366ebbf94cfafbdb1fd8c30da47a945294fe1a1.tar.bz2
Merge remote branch 'intel/drm-intel-fixes' of /ssd/git/drm-next into drm-fixes
-rw-r--r--drivers/gpu/drm/i915/i915_dma.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
index 17bd766..e33d9be 100644
--- a/drivers/gpu/drm/i915/i915_dma.c
+++ b/drivers/gpu/drm/i915/i915_dma.c
@@ -1895,6 +1895,17 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
if (IS_GEN2(dev))
dma_set_coherent_mask(&dev->pdev->dev, DMA_BIT_MASK(30));
+ /* 965GM sometimes incorrectly writes to hardware status page (HWS)
+ * using 32bit addressing, overwriting memory if HWS is located
+ * above 4GB.
+ *
+ * The documentation also mentions an issue with undefined
+ * behaviour if any general state is accessed within a page above 4GB,
+ * which also needs to be handled carefully.
+ */
+ if (IS_BROADWATER(dev) || IS_CRESTLINE(dev))
+ dma_set_coherent_mask(&dev->pdev->dev, DMA_BIT_MASK(32));
+
mmio_bar = IS_GEN2(dev) ? 1 : 0;
dev_priv->regs = pci_iomap(dev->pdev, mmio_bar, 0);
if (!dev_priv->regs) {