drm/i915/mtl: Add initial gt workarounds
authorMatt Roper <matthew.d.roper@intel.com>
Thu, 5 Jan 2023 23:44:08 +0000 (15:44 -0800)
committerRadhakrishna Sripada <radhakrishna.sripada@intel.com>
Fri, 6 Jan 2023 19:27:10 +0000 (11:27 -0800)
This patch introduces initial gt workarounds for the MTL platform.

v2: drop redundant/stale comments specifying wa platforms affected
(Lucas).
v3: drop additional redundant stale comments (MattR)

Bspec: 66622

Signed-off-by: Matt Roper <matthew.d.roper@intel.com>
Signed-off-by: Matt Atwood <matthew.s.atwood@intel.com>
Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
Signed-off-by: Radhakrishna Sripada <radhakrishna.sripada@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20230105234408.277750-1-matthew.s.atwood@intel.com
drivers/gpu/drm/i915/gt/intel_engine_cs.c
drivers/gpu/drm/i915/gt/intel_execlists_submission.c
drivers/gpu/drm/i915/gt/intel_gt_mcr.c
drivers/gpu/drm/i915/gt/intel_gt_regs.h
drivers/gpu/drm/i915/gt/intel_workarounds.c
drivers/gpu/drm/i915/gt/uc/intel_guc.c
drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c
drivers/gpu/drm/i915/intel_device_info.c

index 99c4b866adddfa124c5a810af133636034ff88d1..922f1bb22dc6854f8de965f06961303fb4b5dd6e 100644 (file)
@@ -1494,10 +1494,12 @@ static int __intel_engine_stop_cs(struct intel_engine_cs *engine,
        intel_uncore_write_fw(uncore, mode, _MASKED_BIT_ENABLE(STOP_RING));
 
        /*
-        * Wa_22011802037 : gen11, gen12, Prior to doing a reset, ensure CS is
+        * Wa_22011802037: Prior to doing a reset, ensure CS is
         * stopped, set ring stop bit and prefetch disable bit to halt CS
         */
-       if (IS_GRAPHICS_VER(engine->i915, 11, 12))
+       if (IS_MTL_GRAPHICS_STEP(engine->i915, M, STEP_A0, STEP_B0) ||
+           (GRAPHICS_VER(engine->i915) >= 11 &&
+           GRAPHICS_VER_FULL(engine->i915) < IP_VER(12, 70)))
                intel_uncore_write_fw(uncore, RING_MODE_GEN7(engine->mmio_base),
                                      _MASKED_BIT_ENABLE(GEN12_GFX_PREFETCH_DISABLE));
 
index 2daffa7c7dfd00ea31e57b2461946065113960ec..18ffe55282e594c38e5e7b90c4e78003ccfe72a7 100644 (file)
@@ -2989,10 +2989,12 @@ static void execlists_reset_prepare(struct intel_engine_cs *engine)
        intel_engine_stop_cs(engine);
 
        /*
-        * Wa_22011802037:gen11/gen12: In addition to stopping the cs, we need
+        * Wa_22011802037: In addition to stopping the cs, we need
         * to wait for any pending mi force wakeups
         */
-       if (IS_GRAPHICS_VER(engine->i915, 11, 12))
+       if (IS_MTL_GRAPHICS_STEP(engine->i915, M, STEP_A0, STEP_B0) ||
+           (GRAPHICS_VER(engine->i915) >= 11 &&
+           GRAPHICS_VER_FULL(engine->i915) < IP_VER(12, 70)))
                intel_engine_wait_for_pending_mi_fw(engine);
 
        engine->execlists.reset_ccid = active_ccid(engine);
index 41a237509dcfdab48a370e7d8e7c15a9dfaac9c3..4127830c33ca308885be1aca9069ac98a8bbb62a 100644 (file)
@@ -164,8 +164,15 @@ void intel_gt_mcr_init(struct intel_gt *gt)
        if (MEDIA_VER(i915) >= 13 && gt->type == GT_MEDIA) {
                gt->steering_table[OADDRM] = xelpmp_oaddrm_steering_table;
        } else if (GRAPHICS_VER_FULL(i915) >= IP_VER(12, 70)) {
-               fuse = REG_FIELD_GET(GT_L3_EXC_MASK,
-                                    intel_uncore_read(gt->uncore, XEHP_FUSE4));
+               /* Wa_14016747170 */
+               if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+                   IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0))
+                       fuse = REG_FIELD_GET(MTL_GT_L3_EXC_MASK,
+                                            intel_uncore_read(gt->uncore,
+                                                              MTL_GT_ACTIVITY_FACTOR));
+               else
+                       fuse = REG_FIELD_GET(GT_L3_EXC_MASK,
+                                            intel_uncore_read(gt->uncore, XEHP_FUSE4));
 
                /*
                 * Despite the register field being named "exclude mask" the
index f8eb807b56f9de765257822b01d8ff5f3225c145..d3357853be1245607a5c6f360981b236a92b9e3c 100644 (file)
 #define   TBIMR_FAST_CLIP                      REG_BIT(5)
 
 #define VFLSKPD                                        MCR_REG(0x62a8)
+#define   VF_PREFETCH_TLB_DIS                  REG_BIT(5)
 #define   DIS_OVER_FETCH_CACHE                 REG_BIT(1)
 #define   DIS_MULT_MISS_RD_SQUASH              REG_BIT(0)
 
 
 #define MTL_MEDIA_MC6                          _MMIO(0x138048)
 
+#define MTL_GT_ACTIVITY_FACTOR                 _MMIO(0x138010)
+#define   MTL_GT_L3_EXC_MASK                   REG_GENMASK(5, 3)
+
 #define GEN6_GT_THREAD_STATUS_REG              _MMIO(0x13805c)
 #define   GEN6_GT_THREAD_STATUS_CORE_MASK      0x7
 
index bf84efb3f15f7c89f9e0a4f326ba379a05a2d256..002ba7c2b1ed645fcbe877dc8329e203d7fbf206 100644 (file)
@@ -786,6 +786,32 @@ static void dg2_ctx_workarounds_init(struct intel_engine_cs *engine,
        wa_masked_en(wal, CACHE_MODE_1, MSAA_OPTIMIZATION_REDUC_DISABLE);
 }
 
+static void mtl_ctx_workarounds_init(struct intel_engine_cs *engine,
+                                    struct i915_wa_list *wal)
+{
+       struct drm_i915_private *i915 = engine->i915;
+
+       if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0)) {
+               /* Wa_14014947963 */
+               wa_masked_field_set(wal, VF_PREEMPTION,
+                                   PREEMPTION_VERTEX_COUNT, 0x4000);
+
+               /* Wa_16013271637 */
+               wa_mcr_masked_en(wal, XEHP_SLICE_COMMON_ECO_CHICKEN1,
+                                MSC_MSAA_REODER_BUF_BYPASS_DISABLE);
+
+               /* Wa_18019627453 */
+               wa_mcr_masked_en(wal, VFLSKPD, VF_PREFETCH_TLB_DIS);
+
+               /* Wa_18018764978 */
+               wa_masked_en(wal, PSS_MODE2, SCOREBOARD_STALL_FLUSH_CONTROL);
+       }
+
+       /* Wa_18019271663 */
+       wa_masked_en(wal, CACHE_MODE_1, MSAA_OPTIMIZATION_REDUC_DISABLE);
+}
+
 static void fakewa_disable_nestedbb_mode(struct intel_engine_cs *engine,
                                         struct i915_wa_list *wal)
 {
@@ -872,7 +898,9 @@ __intel_engine_init_ctx_wa(struct intel_engine_cs *engine,
        if (engine->class != RENDER_CLASS)
                goto done;
 
-       if (IS_PONTEVECCHIO(i915))
+       if (IS_METEORLAKE(i915))
+               mtl_ctx_workarounds_init(engine, wal);
+       else if (IS_PONTEVECCHIO(i915))
                ; /* noop; none at this time */
        else if (IS_DG2(i915))
                dg2_ctx_workarounds_init(engine, wal);
@@ -1628,7 +1656,10 @@ pvc_gt_workarounds_init(struct intel_gt *gt, struct i915_wa_list *wal)
 static void
 xelpg_gt_workarounds_init(struct intel_gt *gt, struct i915_wa_list *wal)
 {
-       /* FIXME: Actual workarounds will be added in future patch(es) */
+       /* Wa_14014830051 */
+       if (IS_MTL_GRAPHICS_STEP(gt->i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(gt->i915, P, STEP_A0, STEP_B0))
+               wa_mcr_write_clr(wal, SARB_CHICKEN1, COMP_CKN_IN);
 
        /*
         * Unlike older platforms, we no longer setup implicit steering here;
@@ -2168,7 +2199,9 @@ void intel_engine_init_whitelist(struct intel_engine_cs *engine)
 
        wa_init_start(w, engine->gt, "whitelist", engine->name);
 
-       if (IS_PONTEVECCHIO(i915))
+       if (IS_METEORLAKE(i915))
+               ; /* noop; none at this time */
+       else if (IS_PONTEVECCHIO(i915))
                pvc_whitelist_build(engine);
        else if (IS_DG2(i915))
                dg2_whitelist_build(engine);
@@ -2278,6 +2311,34 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, struct i915_wa_list *wal)
 {
        struct drm_i915_private *i915 = engine->i915;
 
+       if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0)) {
+               /* Wa_22014600077 */
+               wa_mcr_masked_en(wal, GEN10_CACHE_MODE_SS,
+                                ENABLE_EU_COUNT_FOR_TDL_FLUSH);
+       }
+
+       if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0) ||
+           IS_DG2_GRAPHICS_STEP(i915, G10, STEP_B0, STEP_FOREVER) ||
+           IS_DG2_G11(i915) || IS_DG2_G12(i915)) {
+               /* Wa_1509727124 */
+               wa_mcr_masked_en(wal, GEN10_SAMPLER_MODE,
+                                SC_DISABLE_POWER_OPTIMIZATION_EBB);
+
+               /* Wa_22013037850 */
+               wa_mcr_write_or(wal, LSC_CHICKEN_BIT_0_UDW,
+                               DISABLE_128B_EVICTION_COMMAND_UDW);
+       }
+
+       if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_B0, STEP_FOREVER) ||
+           IS_DG2_G11(i915) || IS_DG2_G12(i915) ||
+           IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0)) {
+               /* Wa_22012856258 */
+               wa_mcr_masked_en(wal, GEN8_ROW_CHICKEN2,
+                                GEN12_DISABLE_READ_SUPPRESSION);
+       }
+
        if (IS_DG2(i915)) {
                /* Wa_1509235366:dg2 */
                wa_write_or(wal, GEN12_GAMCNTRL_CTRL, INVALIDATION_BROADCAST_MODE_DIS |
@@ -2289,13 +2350,6 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, struct i915_wa_list *wal)
                wa_mcr_masked_en(wal, GEN8_ROW_CHICKEN2, GEN12_ENABLE_LARGE_GRF_MODE);
        }
 
-       if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_B0, STEP_FOREVER) ||
-           IS_DG2_G11(i915) || IS_DG2_G12(i915)) {
-               /* Wa_1509727124:dg2 */
-               wa_mcr_masked_en(wal, GEN10_SAMPLER_MODE,
-                                SC_DISABLE_POWER_OPTIMIZATION_EBB);
-       }
-
        if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_A0, STEP_B0) ||
            IS_DG2_GRAPHICS_STEP(i915, G11, STEP_A0, STEP_B0)) {
                /* Wa_14012419201:dg2 */
@@ -2327,14 +2381,6 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, struct i915_wa_list *wal)
 
        if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_B0, STEP_FOREVER) ||
            IS_DG2_G11(i915) || IS_DG2_G12(i915)) {
-               /* Wa_22013037850:dg2 */
-               wa_mcr_write_or(wal, LSC_CHICKEN_BIT_0_UDW,
-                               DISABLE_128B_EVICTION_COMMAND_UDW);
-
-               /* Wa_22012856258:dg2 */
-               wa_mcr_masked_en(wal, GEN8_ROW_CHICKEN2,
-                                GEN12_DISABLE_READ_SUPPRESSION);
-
                /*
                 * Wa_22010960976:dg2
                 * Wa_14013347512:dg2
@@ -2944,6 +2990,27 @@ general_render_compute_wa_init(struct intel_engine_cs *engine, struct i915_wa_li
 
        add_render_compute_tuning_settings(i915, wal);
 
+       if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0) ||
+           IS_PONTEVECCHIO(i915) ||
+           IS_DG2(i915)) {
+               /* Wa_18018781329 */
+               wa_mcr_write_or(wal, RENDER_MOD_CTRL, FORCE_MISS_FTLB);
+               wa_mcr_write_or(wal, COMP_MOD_CTRL, FORCE_MISS_FTLB);
+               wa_mcr_write_or(wal, VDBX_MOD_CTRL, FORCE_MISS_FTLB);
+               wa_mcr_write_or(wal, VEBX_MOD_CTRL, FORCE_MISS_FTLB);
+
+               /* Wa_22014226127 */
+               wa_mcr_write_or(wal, LSC_CHICKEN_BIT_0, DISABLE_D8_D16_COASLESCE);
+       }
+
+       if (IS_MTL_GRAPHICS_STEP(i915, M, STEP_A0, STEP_B0) ||
+           IS_MTL_GRAPHICS_STEP(i915, P, STEP_A0, STEP_B0) ||
+           IS_DG2(i915)) {
+               /* Wa_18017747507 */
+               wa_masked_en(wal, VFG_PREEMPTION_CHICKEN, POLYGON_TRIFAN_LINELOOP_DISABLE);
+       }
+
        if (IS_PONTEVECCHIO(i915)) {
                /* Wa_16016694945 */
                wa_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_OVRLSCCC);
@@ -2985,17 +3052,8 @@ general_render_compute_wa_init(struct intel_engine_cs *engine, struct i915_wa_li
                /* Wa_14015227452:dg2,pvc */
                wa_mcr_masked_en(wal, GEN9_ROW_CHICKEN4, XEHP_DIS_BBL_SYSPIPE);
 
-               /* Wa_22014226127:dg2,pvc */
-               wa_mcr_write_or(wal, LSC_CHICKEN_BIT_0, DISABLE_D8_D16_COASLESCE);
-
                /* Wa_16015675438:dg2,pvc */
                wa_masked_en(wal, FF_SLICE_CS_CHICKEN2, GEN12_PERF_FIX_BALANCING_CFE_DISABLE);
-
-               /* Wa_18018781329:dg2,pvc */
-               wa_mcr_write_or(wal, RENDER_MOD_CTRL, FORCE_MISS_FTLB);
-               wa_mcr_write_or(wal, COMP_MOD_CTRL, FORCE_MISS_FTLB);
-               wa_mcr_write_or(wal, VDBX_MOD_CTRL, FORCE_MISS_FTLB);
-               wa_mcr_write_or(wal, VEBX_MOD_CTRL, FORCE_MISS_FTLB);
        }
 
        if (IS_DG2(i915)) {
@@ -3004,9 +3062,6 @@ general_render_compute_wa_init(struct intel_engine_cs *engine, struct i915_wa_li
                 * Wa_22015475538:dg2
                 */
                wa_mcr_write_or(wal, LSC_CHICKEN_BIT_0_UDW, DIS_CHAIN_2XSIMD8);
-
-               /* Wa_18017747507:dg2 */
-               wa_masked_en(wal, VFG_PREEMPTION_CHICKEN, POLYGON_TRIFAN_LINELOOP_DISABLE);
        }
 
        if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_A0, STEP_C0) || IS_DG2_G11(i915))
index c0b5aa6fde26033f5eb580d1701f5841a32e6b5b..1bccc175f9e6bdcb57abccc8719b996ae2f6aa8d 100644 (file)
@@ -274,8 +274,9 @@ static u32 guc_ctl_wa_flags(struct intel_guc *guc)
        if (IS_DG2_GRAPHICS_STEP(gt->i915, G10, STEP_A0, STEP_B0))
                flags |= GUC_WA_GAM_CREDITS;
 
-       /* Wa_14014475959:dg2 */
-       if (IS_DG2(gt->i915))
+       /* Wa_14014475959 */
+       if (IS_MTL_GRAPHICS_STEP(gt->i915, M, STEP_A0, STEP_B0) ||
+           IS_DG2(gt->i915))
                flags |= GUC_WA_HOLD_CCS_SWITCHOUT;
 
        /*
@@ -289,7 +290,9 @@ static u32 guc_ctl_wa_flags(struct intel_guc *guc)
                flags |= GUC_WA_DUAL_QUEUE;
 
        /* Wa_22011802037: graphics version 11/12 */
-       if (IS_GRAPHICS_VER(gt->i915, 11, 12))
+       if (IS_MTL_GRAPHICS_STEP(gt->i915, M, STEP_A0, STEP_B0) ||
+           (GRAPHICS_VER(gt->i915) >= 11 &&
+           GRAPHICS_VER_FULL(gt->i915) < IP_VER(12, 70)))
                flags |= GUC_WA_PRE_PARSER;
 
        /* Wa_16011777198:dg2 */
index fe06c93cf6e3c0afdb7ea6e930dcfda18642ddd1..b436dd7f12e426fa00c98f36b8443790fed8d193 100644 (file)
@@ -1621,7 +1621,7 @@ static void guc_engine_reset_prepare(struct intel_engine_cs *engine)
        intel_engine_stop_cs(engine);
 
        /*
-        * Wa_22011802037:gen11/gen12: In addition to stopping the cs, we need
+        * Wa_22011802037: In addition to stopping the cs, we need
         * to wait for any pending mi force wakeups
         */
        intel_engine_wait_for_pending_mi_fw(engine);
@@ -4203,8 +4203,10 @@ static void guc_default_vfuncs(struct intel_engine_cs *engine)
        engine->flags |= I915_ENGINE_HAS_TIMESLICES;
 
        /* Wa_14014475959:dg2 */
-       if (IS_DG2(engine->i915) && engine->class == COMPUTE_CLASS)
-               engine->flags |= I915_ENGINE_USES_WA_HOLD_CCS_SWITCHOUT;
+       if (engine->class == COMPUTE_CLASS)
+               if (IS_MTL_GRAPHICS_STEP(engine->i915, M, STEP_A0, STEP_B0) ||
+                   IS_DG2(engine->i915))
+                       engine->flags |= I915_ENGINE_USES_WA_HOLD_CCS_SWITCHOUT;
 
        /*
         * TODO: GuC supports timeslicing and semaphores as well, but they're
index 849baf6c3b3c6dc418e33fa0192c338fb6a4b76d..05e90d09b2081c66c1a62f844de3854bf2a743b5 100644 (file)
@@ -343,6 +343,12 @@ static void intel_ipver_early_init(struct drm_i915_private *i915)
 
        ip_ver_read(i915, i915_mmio_reg_offset(GMD_ID_GRAPHICS),
                    &runtime->graphics.ip);
+       /* Wa_22012778468 */
+       if (runtime->graphics.ip.ver == 0x0 &&
+           INTEL_INFO(i915)->platform == INTEL_METEORLAKE) {
+               RUNTIME_INFO(i915)->graphics.ip.ver = 12;
+               RUNTIME_INFO(i915)->graphics.ip.rel = 70;
+       }
        ip_ver_read(i915, i915_mmio_reg_offset(GMD_ID_DISPLAY),
                    &runtime->display.ip);
        ip_ver_read(i915, i915_mmio_reg_offset(GMD_ID_MEDIA),