aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/gpu/drm/i915/i915_drv.c7
-rw-r--r--drivers/gpu/drm/i915/i915_drv.h3
-rw-r--r--drivers/gpu/drm/i915/intel_display.c8
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);
923MODULE_DESCRIPTION(DRIVER_DESC); 923MODULE_DESCRIPTION(DRIVER_DESC);
924MODULE_LICENSE("GPL and additional rights"); 924MODULE_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) \
934u##x i915_read##x(struct drm_i915_private *dev_priv, u32 reg) { \ 927u##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