The workarounds for disabling Render Cache Operational Flush and
PIXEL_SUBSPAN_COLLECT_OPT_DISABLE were previously applied in
rcs_engine_wa_init(). These are specific to Gen7 platforms
so move them to gen7_ctx_workarounds_init() for better alignment with
platform-specific initialization.

Signed-off-by: Sebastian Brzezinka <[email protected]>
---
 drivers/gpu/drm/i915/gt/intel_workarounds.c | 23 ++++++++++-----------
 1 file changed, 11 insertions(+), 12 deletions(-)

diff --git a/drivers/gpu/drm/i915/gt/intel_workarounds.c 
b/drivers/gpu/drm/i915/gt/intel_workarounds.c
index 79298618cda6..c4f364a29724 100644
--- a/drivers/gpu/drm/i915/gt/intel_workarounds.c
+++ b/drivers/gpu/drm/i915/gt/intel_workarounds.c
@@ -343,6 +343,17 @@ static void gen7_ctx_workarounds_init(struct 
intel_engine_cs *engine,
                                      struct i915_wa_list *wal)
 {
        wa_masked_en(wal, INSTPM, INSTPM_FORCE_ORDERING);
+       /* WaDisable_RenderCache_OperationalFlush:ivb,vlv,hsw */
+       wa_masked_dis(wal, CACHE_MODE_0_GEN7, RC_OP_FLUSH_ENABLE);
+
+       /*
+        * BSpec says this must be set, even though
+        * WaDisable4x2SubspanOptimization:ivb,hsw
+        * WaDisable4x2SubspanOptimization isn't listed for VLV.
+        */
+       wa_masked_en(wal,
+                    CACHE_MODE_1,
+                    PIXEL_SUBSPAN_COLLECT_OPT_DISABLE);
 }
 
 static void gen8_ctx_workarounds_init(struct intel_engine_cs *engine,
@@ -2567,18 +2578,6 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, 
struct i915_wa_list *wal)
                             RING_MODE_GEN7(RENDER_RING_BASE),
                             GFX_TLB_INVALIDATE_EXPLICIT | GFX_REPLAY_MODE);
 
-               /* WaDisable_RenderCache_OperationalFlush:ivb,vlv,hsw */
-               wa_masked_dis(wal, CACHE_MODE_0_GEN7, RC_OP_FLUSH_ENABLE);
-
-               /*
-                * BSpec says this must be set, even though
-                * WaDisable4x2SubspanOptimization:ivb,hsw
-                * WaDisable4x2SubspanOptimization isn't listed for VLV.
-                */
-               wa_masked_en(wal,
-                            CACHE_MODE_1,
-                            PIXEL_SUBSPAN_COLLECT_OPT_DISABLE);
-
                /*
                 * BSpec recommends 8x4 when MSAA is used,
                 * however in practice 16x4 seems fastest.
-- 
2.34.1

Reply via email to