On Thu, Feb 09, 2023 at 03:22:28PM -0800, Matt Roper wrote:
> Although registers in the L3 bank/node configuration ranges are marked
> as having "DEV" reset characteristics in the bspec, this appears to be a
> hold-over from pre-Xe_HP platforms.  In reality, these registers
> maintain their values across engine resets, meaning that workarounds
> and tuning settings targetting them should be placed on the GT
> workaround list rather than an engine workaround list.
> 
> Note that an extra clue here is that these registers moved from the
> RENDER forcewake domain to the GT forcewake domain in Xe_HP; generally
> RCS/CCS engine resets should not lead to the reset of a register that
> lives outside the RENDER domain.
> 
> Re-applying these registers on engine resets wouldn't actually hurt
> anything, but is unnecessary and just makes it more confusing to anyone
> trying to decipher how these registers really work.
> 
> v2:
>  - Also move DG2's Wa_14010648519 to the GT list.  (Gustavo)
> 
> Cc: Gustavo Sousa <gustavo.so...@intel.com>
> Signed-off-by: Matt Roper <matthew.d.ro...@intel.com>

Reviewed-by: Gustavo Sousa <gustavo.so...@intel.com>

> ---
>  drivers/gpu/drm/i915/gt/intel_workarounds.c | 70 ++++++++++++---------
>  1 file changed, 42 insertions(+), 28 deletions(-)
> 
> diff --git a/drivers/gpu/drm/i915/gt/intel_workarounds.c 
> b/drivers/gpu/drm/i915/gt/intel_workarounds.c
> index 8859eb118510..989e9578e122 100644
> --- a/drivers/gpu/drm/i915/gt/intel_workarounds.c
> +++ b/drivers/gpu/drm/i915/gt/intel_workarounds.c
> @@ -1499,6 +1499,12 @@ xehpsdv_gt_workarounds_init(struct intel_gt *gt, 
> struct i915_wa_list *wal)
>       /* Wa_1409757795:xehpsdv */
>       wa_mcr_write_or(wal, SCCGCTL94DC, CG3DDISURB);
>  
> +     /* Wa_18011725039:xehpsdv */
> +     if (IS_XEHPSDV_GRAPHICS_STEP(i915, STEP_A1, STEP_B0)) {
> +             wa_mcr_masked_dis(wal, MLTICTXCTL, TDONRENDER);
> +             wa_mcr_write_or(wal, L3SQCREG1_CCS0, FLUSHALLNONCOH);
> +     }
> +
>       /* Wa_16011155590:xehpsdv */
>       if (IS_XEHPSDV_GRAPHICS_STEP(i915, STEP_A0, STEP_B0))
>               wa_write_or(wal, UNSLICE_UNIT_LEVEL_CLKGATE,
> @@ -1548,6 +1554,9 @@ xehpsdv_gt_workarounds_init(struct intel_gt *gt, struct 
> i915_wa_list *wal)
>       /* Wa_14014368820:xehpsdv */
>       wa_mcr_write_or(wal, XEHP_GAMCNTRL_CTRL,
>                       INVALIDATION_BROADCAST_MODE_DIS | 
> GLOBAL_INVALIDATION_MODE);
> +
> +     /* Wa_14010670810:xehpsdv */
> +     wa_mcr_write_or(wal, XEHP_L3NODEARBCFG, XEHP_LNESPARE);
>  }
>  
>  static void
> @@ -1669,6 +1678,9 @@ dg2_gt_workarounds_init(struct intel_gt *gt, struct 
> i915_wa_list *wal)
>       /* Wa_1509235366:dg2 */
>       wa_mcr_write_or(wal, XEHP_GAMCNTRL_CTRL,
>                       INVALIDATION_BROADCAST_MODE_DIS | 
> GLOBAL_INVALIDATION_MODE);
> +
> +     /* Wa_14010648519:dg2 */
> +     wa_mcr_write_or(wal, XEHP_L3NODEARBCFG, XEHP_LNESPARE);
>  }
>  
>  static void
> @@ -1684,6 +1696,9 @@ pvc_gt_workarounds_init(struct intel_gt *gt, struct 
> i915_wa_list *wal)
>       wa_mcr_write_or(wal, COMP_MOD_CTRL, FORCE_MISS_FTLB);
>       wa_mcr_write_or(wal, XEHP_VDBX_MOD_CTRL, FORCE_MISS_FTLB);
>       wa_mcr_write_or(wal, XEHP_VEBX_MOD_CTRL, FORCE_MISS_FTLB);
> +
> +     /* Wa_16016694945 */
> +     wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_OVRLSCCC);
>  }
>  
>  static void
> @@ -1724,11 +1739,36 @@ xelpmp_gt_workarounds_init(struct intel_gt *gt, 
> struct i915_wa_list *wal)
>       debug_dump_steering(gt);
>  }
>  
> +/*
> + * The bspec performance guide has recommended MMIO tuning settings.  These
> + * aren't truly "workarounds" but we want to program them through the
> + * workaround infrastructure to make sure they're (re)applied at the proper
> + * times.
> + *
> + * The settings in this function are for settings that persist through
> + * engine resets and also are not part of any engine's register state 
> context.
> + * I.e., settings that only need to be re-applied in the event of a full GT
> + * reset.
> + */
> +static void gt_tuning_settings(struct intel_gt *gt, struct i915_wa_list *wal)
> +{
> +     if (IS_PONTEVECCHIO(gt->i915)) {
> +             wa_mcr_write(wal, XEHPC_L3SCRUB,
> +                          SCRUB_CL_DWNGRADE_SHARED | SCRUB_RATE_4B_PER_CLK);
> +             wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_HOSTCACHEEN);
> +     }
> +
> +     if (IS_DG2(gt->i915))
> +             wa_mcr_write_or(wal, XEHP_L3SCQREG7, 
> BLEND_FILL_CACHING_OPT_DIS);
> +}
> +
>  static void
>  gt_init_workarounds(struct intel_gt *gt, struct i915_wa_list *wal)
>  {
>       struct drm_i915_private *i915 = gt->i915;
>  
> +     gt_tuning_settings(gt, wal);
> +
>       if (gt->type == GT_MEDIA) {
>               if (MEDIA_VER(i915) >= 13)
>                       xelpmp_gt_workarounds_init(gt, wal);
> @@ -2403,16 +2443,12 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, 
> struct i915_wa_list *wal)
>                                MDQ_ARBITRATION_MODE | UGM_BACKUP_MODE);
>       }
>  
> -     if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_A0, STEP_B0)) {
> +     if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_A0, STEP_B0))
>               /* Wa_22010430635:dg2 */
>               wa_mcr_masked_en(wal,
>                                GEN9_ROW_CHICKEN4,
>                                GEN12_DISABLE_GRF_CLEAR);
>  
> -             /* Wa_14010648519:dg2 */
> -             wa_mcr_write_or(wal, XEHP_L3NODEARBCFG, XEHP_LNESPARE);
> -     }
> -
>       /* Wa_14013202645:dg2 */
>       if (IS_DG2_GRAPHICS_STEP(i915, G10, STEP_B0, STEP_C0) ||
>           IS_DG2_GRAPHICS_STEP(i915, G11, STEP_A0, STEP_B0))
> @@ -2897,16 +2933,8 @@ static void
>  add_render_compute_tuning_settings(struct drm_i915_private *i915,
>                                  struct i915_wa_list *wal)
>  {
> -     if (IS_PONTEVECCHIO(i915)) {
> -             wa_mcr_write(wal, XEHPC_L3SCRUB,
> -                          SCRUB_CL_DWNGRADE_SHARED | SCRUB_RATE_4B_PER_CLK);
> -             wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_HOSTCACHEEN);
> -     }
> -
> -     if (IS_DG2(i915)) {
> -             wa_mcr_write_or(wal, XEHP_L3SCQREG7, 
> BLEND_FILL_CACHING_OPT_DIS);
> +     if (IS_DG2(i915))
>               wa_mcr_write_clr_set(wal, RT_CTRL, STACKID_CTRL, 
> STACKID_CTRL_512);
> -     }
>  
>       /*
>        * This tuning setting proves beneficial only on ATS-M designs; the
> @@ -2988,11 +3016,6 @@ general_render_compute_wa_init(struct intel_engine_cs 
> *engine, struct i915_wa_li
>                          0, false);
>       }
>  
> -     if (IS_PONTEVECCHIO(i915)) {
> -             /* Wa_16016694945 */
> -             wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_OVRLSCCC);
> -     }
> -
>       if (IS_XEHPSDV(i915)) {
>               /* Wa_1409954639 */
>               wa_mcr_masked_en(wal,
> @@ -3004,18 +3027,9 @@ general_render_compute_wa_init(struct intel_engine_cs 
> *engine, struct i915_wa_li
>                                GEN9_ROW_CHICKEN4,
>                                GEN12_DISABLE_GRF_CLEAR);
>  
> -             /* Wa_14010670810:xehpsdv */
> -             wa_mcr_write_or(wal, XEHP_L3NODEARBCFG, XEHP_LNESPARE);
> -
>               /* Wa_14010449647:xehpsdv */
>               wa_mcr_masked_en(wal, GEN8_HALF_SLICE_CHICKEN1,
>                                GEN7_PSD_SINGLE_PORT_DISPATCH_ENABLE);
> -
> -             /* Wa_18011725039:xehpsdv */
> -             if (IS_XEHPSDV_GRAPHICS_STEP(i915, STEP_A1, STEP_B0)) {
> -                     wa_mcr_masked_dis(wal, MLTICTXCTL, TDONRENDER);
> -                     wa_mcr_write_or(wal, L3SQCREG1_CCS0, FLUSHALLNONCOH);
> -             }
>       }
>  
>       if (IS_DG2(i915) || IS_PONTEVECCHIO(i915)) {
> -- 
> 2.39.1
> 

Reply via email to