diff options
author | Ville Syrjälä <ville.syrjala@linux.intel.com> | 2015-06-02 08:37:36 -0400 |
---|---|---|
committer | Jani Nikula <jani.nikula@intel.com> | 2015-06-03 07:05:45 -0400 |
commit | 9cc83020616d38339e6c29dc44536e9806abfdb0 (patch) | |
tree | 81e1abb5ac7dccd9c4077776144b24941dd320f8 /drivers/gpu/drm/i915/intel_ringbuffer.c | |
parent | 64987fc59d90738715703362292f743b7dbbe76b (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.c | 6 |
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)) |