diff options
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.c | 7 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/i915_drv.h | 3 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 8 |
3 files changed, 8 insertions, 10 deletions
diff --git a/drivers/gpu/drm/i915/i915_drv.c b/drivers/gpu/drm/i915/i915_drv.c index 22c8ab70db2c..8f7187915b0d 100644 --- a/drivers/gpu/drm/i915/i915_drv.c +++ b/drivers/gpu/drm/i915/i915_drv.c | |||
@@ -923,13 +923,6 @@ MODULE_AUTHOR(DRIVER_AUTHOR); | |||
923 | MODULE_DESCRIPTION(DRIVER_DESC); | 923 | MODULE_DESCRIPTION(DRIVER_DESC); |
924 | MODULE_LICENSE("GPL and additional rights"); | 924 | MODULE_LICENSE("GPL and additional rights"); |
925 | 925 | ||
926 | /* We give fast paths for the really cool registers */ | ||
927 | #define NEEDS_FORCE_WAKE(dev_priv, reg) \ | ||
928 | (((dev_priv)->info->gen >= 6) && \ | ||
929 | ((reg) < 0x40000) && \ | ||
930 | ((reg) != FORCEWAKE) && \ | ||
931 | ((reg) != ECOBUS)) | ||
932 | |||
933 | #define __i915_read(x, y) \ | 926 | #define __i915_read(x, y) \ |
934 | u##x i915_read##x(struct drm_i915_private *dev_priv, u32 reg) { \ | 927 | u##x i915_read##x(struct drm_i915_private *dev_priv, u32 reg) { \ |
935 | u##x val = 0; \ | 928 | u##x val = 0; \ |
diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index 505af3f64a07..621840c05f0c 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h | |||
@@ -1364,8 +1364,7 @@ void __gen6_gt_wait_for_fifo(struct drm_i915_private *dev_priv); | |||
1364 | #define NEEDS_FORCE_WAKE(dev_priv, reg) \ | 1364 | #define NEEDS_FORCE_WAKE(dev_priv, reg) \ |
1365 | (((dev_priv)->info->gen >= 6) && \ | 1365 | (((dev_priv)->info->gen >= 6) && \ |
1366 | ((reg) < 0x40000) && \ | 1366 | ((reg) < 0x40000) && \ |
1367 | ((reg) != FORCEWAKE) && \ | 1367 | ((reg) != FORCEWAKE)) |
1368 | ((reg) != ECOBUS)) | ||
1369 | 1368 | ||
1370 | #define __i915_read(x, y) \ | 1369 | #define __i915_read(x, y) \ |
1371 | u##x i915_read##x(struct drm_i915_private *dev_priv, u32 reg); | 1370 | u##x i915_read##x(struct drm_i915_private *dev_priv, u32 reg); |
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index cb21d5bbeccb..ff99fa267bf6 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -8591,9 +8591,15 @@ static void intel_init_display(struct drm_device *dev) | |||
8591 | if (IS_IVYBRIDGE(dev)) { | 8591 | if (IS_IVYBRIDGE(dev)) { |
8592 | u32 ecobus; | 8592 | u32 ecobus; |
8593 | 8593 | ||
8594 | /* A small trick here - if the bios hasn't configured MT forcewake, | ||
8595 | * and if the device is in RC6, then force_wake_mt_get will not wake | ||
8596 | * the device and the ECOBUS read will return zero. Which will be | ||
8597 | * (correctly) interpreted by the test below as MT forcewake being | ||
8598 | * disabled. | ||
8599 | */ | ||
8594 | mutex_lock(&dev->struct_mutex); | 8600 | mutex_lock(&dev->struct_mutex); |
8595 | __gen6_gt_force_wake_mt_get(dev_priv); | 8601 | __gen6_gt_force_wake_mt_get(dev_priv); |
8596 | ecobus = I915_READ(ECOBUS); | 8602 | ecobus = I915_READ_NOTRACE(ECOBUS); |
8597 | __gen6_gt_force_wake_mt_put(dev_priv); | 8603 | __gen6_gt_force_wake_mt_put(dev_priv); |
8598 | mutex_unlock(&dev->struct_mutex); | 8604 | mutex_unlock(&dev->struct_mutex); |
8599 | 8605 | ||