From: Matt Roper <matthew.d.ro...@intel.com>

RKL and TGL share some general gen12 workarounds, but each platform also
has its own platform-specific workarounds.

Cc: Matt Atwood <matthew.s.atw...@intel.com>
Signed-off-by: Matt Roper <matthew.d.ro...@intel.com>
Link: 
https://patchwork.freedesktop.org/patch/msgid/20200504225227.464666-23-matthew.d.ro...@intel.com
---
 drivers/gpu/drm/i915/display/intel_sprite.c |  5 +-
 drivers/gpu/drm/i915/gt/intel_workarounds.c | 88 +++++++++++++--------
 2 files changed, 59 insertions(+), 34 deletions(-)

diff --git a/drivers/gpu/drm/i915/display/intel_sprite.c 
b/drivers/gpu/drm/i915/display/intel_sprite.c
index 571c36f929bd..20eea81118da 100644
--- a/drivers/gpu/drm/i915/display/intel_sprite.c
+++ b/drivers/gpu/drm/i915/display/intel_sprite.c
@@ -2842,8 +2842,9 @@ static bool skl_plane_format_mod_supported(struct 
drm_plane *_plane,
 static bool gen12_plane_supports_mc_ccs(struct drm_i915_private *dev_priv,
                                        enum plane_id plane_id)
 {
-       /* Wa_14010477008:tgl[a0..c0] */
-       if (IS_TGL_REVID(dev_priv, TGL_REVID_A0, TGL_REVID_C0))
+       /* Wa_14010477008:tgl[a0..c0],rkl[all] */
+       if (IS_ROCKETLAKE(dev_priv) ||
+           IS_TGL_REVID(dev_priv, TGL_REVID_A0, TGL_REVID_C0))
                return false;
 
        return plane_id < PLANE_SPRITE4;
diff --git a/drivers/gpu/drm/i915/gt/intel_workarounds.c 
b/drivers/gpu/drm/i915/gt/intel_workarounds.c
index fa1e15657663..31c5b85a5cf5 100644
--- a/drivers/gpu/drm/i915/gt/intel_workarounds.c
+++ b/drivers/gpu/drm/i915/gt/intel_workarounds.c
@@ -575,8 +575,8 @@ static void icl_ctx_workarounds_init(struct intel_engine_cs 
*engine,
        wa_masked_en(wal, GEN9_ROW_CHICKEN4, GEN11_DIS_PICK_2ND_EU);
 }
 
-static void tgl_ctx_workarounds_init(struct intel_engine_cs *engine,
-                                    struct i915_wa_list *wal)
+static void gen12_ctx_workarounds_init(struct intel_engine_cs *engine,
+                                      struct i915_wa_list *wal)
 {
        /*
         * Wa_1409142259:tgl
@@ -586,12 +586,28 @@ static void tgl_ctx_workarounds_init(struct 
intel_engine_cs *engine,
         * Wa_1409207793:tgl
         * Wa_1409178076:tgl
         * Wa_1408979724:tgl
+        * Wa_14010443199:rkl
+        * Wa_14010698770:rkl
         */
        WA_SET_BIT_MASKED(GEN11_COMMON_SLICE_CHICKEN3,
                          GEN12_DISABLE_CPS_AWARE_COLOR_PIPE);
 
+       /* WaDisableGPGPUMidThreadPreemption:gen12 */
+       WA_SET_FIELD_MASKED(GEN8_CS_CHICKEN1,
+                           GEN9_PREEMPT_GPGPU_LEVEL_MASK,
+                           GEN9_PREEMPT_GPGPU_THREAD_GROUP_LEVEL);
+}
+
+static void tgl_ctx_workarounds_init(struct intel_engine_cs *engine,
+                                    struct i915_wa_list *wal)
+{
+       gen12_ctx_workarounds_init(engine, wal);
+
        /*
-        * Wa_1604555607:gen12 and Wa_1608008084:gen12
+        * Wa_1604555607:tgl
+        *
+        * Note that the implementation of this workaround is further modified
+        * according to the FF_MODE2 guidance given by Wa_1608008084:gen12.
         * FF_MODE2 register will return the wrong value when read. The default
         * value for this register is zero for all fields and there are no bit
         * masks. So instead of doing a RMW we should just write the TDS timer
@@ -599,11 +615,6 @@ static void tgl_ctx_workarounds_init(struct 
intel_engine_cs *engine,
         */
        wa_add(wal, FF_MODE2, FF_MODE2_TDS_TIMER_MASK,
               FF_MODE2_TDS_TIMER_128, 0);
-
-       /* WaDisableGPGPUMidThreadPreemption:tgl */
-       WA_SET_FIELD_MASKED(GEN8_CS_CHICKEN1,
-                           GEN9_PREEMPT_GPGPU_LEVEL_MASK,
-                           GEN9_PREEMPT_GPGPU_THREAD_GROUP_LEVEL);
 }
 
 static void
@@ -618,8 +629,10 @@ __intel_engine_init_ctx_wa(struct intel_engine_cs *engine,
 
        wa_init_start(wal, name, engine->name);
 
-       if (IS_GEN(i915, 12))
+       if (IS_TIGERLAKE(i915))
                tgl_ctx_workarounds_init(engine, wal);
+       else if (IS_GEN(i915, 12))
+               gen12_ctx_workarounds_init(engine, wal);
        else if (IS_GEN(i915, 11))
                icl_ctx_workarounds_init(engine, wal);
        else if (IS_CANNONLAKE(i915))
@@ -927,9 +940,16 @@ icl_gt_workarounds_init(struct drm_i915_private *i915, 
struct i915_wa_list *wal)
 }
 
 static void
-tgl_gt_workarounds_init(struct drm_i915_private *i915, struct i915_wa_list 
*wal)
+gen12_gt_workarounds_init(struct drm_i915_private *i915,
+                         struct i915_wa_list *wal)
 {
        wa_init_mcr(i915, wal);
+}
+
+static void
+tgl_gt_workarounds_init(struct drm_i915_private *i915, struct i915_wa_list 
*wal)
+{
+       gen12_gt_workarounds_init(i915, wal);
 
        /* Wa_1409420604:tgl */
        if (IS_TGL_REVID(i915, TGL_REVID_A0, TGL_REVID_A0))
@@ -947,8 +967,10 @@ tgl_gt_workarounds_init(struct drm_i915_private *i915, 
struct i915_wa_list *wal)
 static void
 gt_init_workarounds(struct drm_i915_private *i915, struct i915_wa_list *wal)
 {
-       if (IS_GEN(i915, 12))
+       if (IS_TIGERLAKE(i915))
                tgl_gt_workarounds_init(i915, wal);
+       else if (IS_GEN(i915, 12))
+               gen12_gt_workarounds_init(i915, wal);
        else if (IS_GEN(i915, 11))
                icl_gt_workarounds_init(i915, wal);
        else if (IS_CANNONLAKE(i915))
@@ -1343,18 +1365,6 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, 
struct i915_wa_list *wal)
                            GEN9_CTX_PREEMPT_REG,
                            GEN12_DISABLE_POSH_BUSY_FF_DOP_CG);
 
-               /*
-                * Wa_1607030317:tgl
-                * Wa_1607186500:tgl
-                * Wa_1607297627:tgl there is 3 entries for this WA on BSpec, 2
-                * of then says it is fixed on B0 the other one says it is
-                * permanent
-                */
-               wa_masked_en(wal,
-                            GEN6_RC_SLEEP_PSMI_CONTROL,
-                            GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
-                            GEN8_RC_SEMA_IDLE_MSG_DISABLE);
-
                /*
                 * Wa_1606679103:tgl
                 * (see also Wa_1606682166:icl)
@@ -1373,24 +1383,38 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, 
struct i915_wa_list *wal)
                            VSUNIT_CLKGATE_DIS_TGL);
        }
 
-       if (IS_TIGERLAKE(i915)) {
-               /* Wa_1606931601:tgl */
+       if (IS_ROCKETLAKE(i915) || IS_TIGERLAKE(i915)) {
+               /* Wa_1606931601:tgl,rkl */
                wa_masked_en(wal, GEN7_ROW_CHICKEN2, GEN12_DISABLE_EARLY_READ);
 
-               /* Wa_1409804808:tgl */
+               /* Wa_1409804808:tgl,rkl */
                wa_masked_en(wal, GEN7_ROW_CHICKEN2,
                             GEN12_PUSH_CONST_DEREF_HOLD_DIS);
 
-               /* Wa_1606700617:tgl */
-               wa_masked_en(wal,
-                            GEN9_CS_DEBUG_MODE1,
-                            FF_DOP_CLOCK_GATE_DISABLE);
-
                /*
                 * Wa_1409085225:tgl
-                * Wa_14010229206:tgl
+                * Wa_14010229206:tgl,rkl
                 */
                wa_masked_en(wal, GEN9_ROW_CHICKEN4, GEN12_DISABLE_TDL_PUSH);
+
+               /*
+                * Wa_1607030317:tgl
+                * Wa_1607186500:tgl
+                * Wa_1607297627:tgl,rkl there are multiple entries for this
+                * WA in the BSpec; some indicate this is an A0-only WA,
+                * others indicate it applies to all steppings.
+                */
+               wa_masked_en(wal,
+                            GEN6_RC_SLEEP_PSMI_CONTROL,
+                            GEN12_WAIT_FOR_EVENT_POWER_DOWN_DISABLE |
+                            GEN8_RC_SEMA_IDLE_MSG_DISABLE);
+       }
+
+       if (IS_TIGERLAKE(i915)) {
+               /* Wa_1606700617:tgl */
+               wa_masked_en(wal,
+                            GEN9_CS_DEBUG_MODE1,
+                            FF_DOP_CLOCK_GATE_DISABLE);
        }
 
        if (IS_GEN(i915, 11)) {
-- 
2.26.2

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to