drm/i915: disable rc6 on ilk when vt-d is enabled
authorDaniel Vetter <daniel.vetter@ffwll.ch>
Sun, 26 Aug 2012 18:33:18 +0000 (20:33 +0200)
committerDaniel Vetter <daniel.vetter@ffwll.ch>
Sun, 26 Aug 2012 18:35:57 +0000 (20:35 +0200)
It blows up. And hopefully this is the root-cause of the mysterious
rc6 related hang on ilk. For reference, the commit that enabled rc6 on
ilk again is:

commit 456470eb583f063ee84c6818251e638598be0fb8
Author: Daniel Vetter <daniel.vetter@ffwll.ch>
Date:   Wed Aug 8 23:35:40 2012 +0200

    drm/i915: enable rc6 on ilk again

Reported-by: Dave Airlie <airlied@gmail.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
drivers/gpu/drm/i915/intel_pm.c

index c0721ffb56a2ab131b736b250c8ccbd7b174ef1f..ebe3498bc9c0cae6e7c8c5062b2c691c070c122e 100644 (file)
@@ -2372,6 +2372,11 @@ int intel_enable_rc6(const struct drm_device *dev)
                return i915_enable_rc6;
 
        if (INTEL_INFO(dev)->gen == 5) {
+#ifdef CONFIG_INTEL_IOMMU
+               /* Disable rc6 on ilk if VT-d is on. */
+               if (intel_iommu_gfx_mapped)
+                       return false;
+#endif
                DRM_DEBUG_DRIVER("Ironlake: only RC6 available\n");
                return INTEL_RC6_ENABLE;
        }