aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_ringbuffer.c
diff options
context:
space:
mode:
authorVille Syrjälä <ville.syrjala@linux.intel.com>2015-06-02 08:37:36 -0400
committerJani Nikula <jani.nikula@intel.com>2015-06-03 07:05:45 -0400
commit9cc83020616d38339e6c29dc44536e9806abfdb0 (patch)
tree81e1abb5ac7dccd9c4077776144b24941dd320f8 /drivers/gpu/drm/i915/intel_ringbuffer.c
parent64987fc59d90738715703362292f743b7dbbe76b (diff)
drm/i915: Set INSTPM_FORCE_ORDERING via LRI on gen8, drop it on gen9+
INSTPM is saved in the logical context so we should initialize it using LRIs on gen8. It actually defaults to 1 starting from HSW, but let's keep the write around anyway. Also drop the INSTPM_FORCE_ORDERING setup entirely on gen9+ since it's now a reserved bit. Signed-off-by: Ville Syrjälä <ville.syrjala@linux.intel.com> Reviewed-by: Damien Lespiau <damien.lespiau@intel.com> Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_ringbuffer.c')
-rw-r--r--drivers/gpu/drm/i915/intel_ringbuffer.c6
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/gpu/drm/i915/intel_ringbuffer.c b/drivers/gpu/drm/i915/intel_ringbuffer.c
index edd47baa119c..06f4b22c6327 100644
--- a/drivers/gpu/drm/i915/intel_ringbuffer.c
+++ b/drivers/gpu/drm/i915/intel_ringbuffer.c
@@ -800,6 +800,8 @@ static int bdw_init_workarounds(struct intel_engine_cs *ring)
800 struct drm_device *dev = ring->dev; 800 struct drm_device *dev = ring->dev;
801 struct drm_i915_private *dev_priv = dev->dev_private; 801 struct drm_i915_private *dev_priv = dev->dev_private;
802 802
803 WA_SET_BIT_MASKED(INSTPM, INSTPM_FORCE_ORDERING);
804
803 /* WaDisablePartialInstShootdown:bdw */ 805 /* WaDisablePartialInstShootdown:bdw */
804 /* WaDisableThreadStallDopClockGating:bdw (pre-production) */ 806 /* WaDisableThreadStallDopClockGating:bdw (pre-production) */
805 WA_SET_BIT_MASKED(GEN8_ROW_CHICKEN, 807 WA_SET_BIT_MASKED(GEN8_ROW_CHICKEN,
@@ -861,6 +863,8 @@ static int chv_init_workarounds(struct intel_engine_cs *ring)
861 struct drm_device *dev = ring->dev; 863 struct drm_device *dev = ring->dev;
862 struct drm_i915_private *dev_priv = dev->dev_private; 864 struct drm_i915_private *dev_priv = dev->dev_private;
863 865
866 WA_SET_BIT_MASKED(INSTPM, INSTPM_FORCE_ORDERING);
867
864 /* WaDisablePartialInstShootdown:chv */ 868 /* WaDisablePartialInstShootdown:chv */
865 /* WaDisableThreadStallDopClockGating:chv */ 869 /* WaDisableThreadStallDopClockGating:chv */
866 WA_SET_BIT_MASKED(GEN8_ROW_CHICKEN, 870 WA_SET_BIT_MASKED(GEN8_ROW_CHICKEN,
@@ -1132,7 +1136,7 @@ static int init_render_ring(struct intel_engine_cs *ring)
1132 _MASKED_BIT_DISABLE(CM0_STC_EVICT_DISABLE_LRA_SNB)); 1136 _MASKED_BIT_DISABLE(CM0_STC_EVICT_DISABLE_LRA_SNB));
1133 } 1137 }
1134 1138
1135 if (INTEL_INFO(dev)->gen >= 6) 1139 if (INTEL_INFO(dev)->gen >= 6 && INTEL_INFO(dev)->gen < 8)
1136 I915_WRITE(INSTPM, _MASKED_BIT_ENABLE(INSTPM_FORCE_ORDERING)); 1140 I915_WRITE(INSTPM, _MASKED_BIT_ENABLE(INSTPM_FORCE_ORDERING));
1137 1141
1138 if (HAS_L3_DPF(dev)) 1142 if (HAS_L3_DPF(dev))