[Intel-gfx] [PATCH 1/2] drm/i915/gen11: Moving WAs to rcs_engine_wa_init()
Matt Roper
matthew.d.roper at intel.com
Tue Mar 3 20:19:14 UTC 2020
On Mon, Mar 02, 2020 at 03:14:20PM -0800, José Roberto de Souza wrote:
> This are register of render engine, so after a render reset those
> would return to the default value and init_clock_gating() is not
> called for single engine reset.
> So here moving it rcs_engine_wa_init() that will guarantee that this
> WAs will not be lost.
>
> Cc: Matt Roper <matthew.d.roper at intel.com>
> Signed-off-by: José Roberto de Souza <jose.souza at intel.com>
Reviewed-by: Matt Roper <matthew.d.roper at intel.com>
rcs_engine_wa_init() is starting to get pretty long (and will get even
longer when new platforms show up). We may want to think about breaking
it into per-platform handlers at some point like we use for general
gt/ctx workarounds.
Matt
> ---
> drivers/gpu/drm/i915/gt/intel_workarounds.c | 15 +++++++++++++++
> drivers/gpu/drm/i915/intel_pm.c | 15 ---------------
> 2 files changed, 15 insertions(+), 15 deletions(-)
>
> diff --git a/drivers/gpu/drm/i915/gt/intel_workarounds.c b/drivers/gpu/drm/i915/gt/intel_workarounds.c
> index 3e375a3b7714..90e1c48dd6be 100644
> --- a/drivers/gpu/drm/i915/gt/intel_workarounds.c
> +++ b/drivers/gpu/drm/i915/gt/intel_workarounds.c
> @@ -1454,6 +1454,21 @@ rcs_engine_wa_init(struct intel_engine_cs *engine, struct i915_wa_list *wal)
> GEN11_SCRATCH2,
> GEN11_COHERENT_PARTIAL_WRITE_MERGE_ENABLE,
> 0);
> +
> + /* WaEnable32PlaneMode:icl */
> + wa_masked_en(wal, GEN9_CSFE_CHICKEN1_RCS,
> + GEN11_ENABLE_32_PLANE_MODE);
> +
> + /*
> + * Wa_1408615072:icl,ehl (vsunit)
> + * Wa_1407596294:icl,ehl (hsunit)
> + */
> + wa_masked_en(wal, UNSLICE_UNIT_LEVEL_CLKGATE,
> + VSUNIT_CLKGATE_DIS | HSUNIT_CLKGATE_DIS);
> +
> + /* Wa_1407352427:icl,ehl */
> + wa_masked_en(wal, UNSLICE_UNIT_LEVEL_CLKGATE2,
> + PSDUNIT_CLKGATE_DIS);
> }
>
> if (IS_GEN_RANGE(i915, 9, 11)) {
> diff --git a/drivers/gpu/drm/i915/intel_pm.c b/drivers/gpu/drm/i915/intel_pm.c
> index 831e53c137cf..d3df00445787 100644
> --- a/drivers/gpu/drm/i915/intel_pm.c
> +++ b/drivers/gpu/drm/i915/intel_pm.c
> @@ -6782,21 +6782,6 @@ static void icl_init_clock_gating(struct drm_i915_private *dev_priv)
> I915_WRITE(GEN10_DFR_RATIO_EN_AND_CHICKEN,
> I915_READ(GEN10_DFR_RATIO_EN_AND_CHICKEN) & ~DFR_DISABLE);
>
> - /* WaEnable32PlaneMode:icl */
> - I915_WRITE(GEN9_CSFE_CHICKEN1_RCS,
> - _MASKED_BIT_ENABLE(GEN11_ENABLE_32_PLANE_MODE));
> -
> - /*
> - * Wa_1408615072:icl,ehl (vsunit)
> - * Wa_1407596294:icl,ehl (hsunit)
> - */
> - intel_uncore_rmw(&dev_priv->uncore, UNSLICE_UNIT_LEVEL_CLKGATE,
> - 0, VSUNIT_CLKGATE_DIS | HSUNIT_CLKGATE_DIS);
> -
> - /* Wa_1407352427:icl,ehl */
> - intel_uncore_rmw(&dev_priv->uncore, UNSLICE_UNIT_LEVEL_CLKGATE2,
> - 0, PSDUNIT_CLKGATE_DIS);
> -
> /*Wa_14010594013:icl, ehl */
> intel_uncore_rmw(&dev_priv->uncore, GEN8_CHICKEN_DCPR_1,
> 0, CNL_DELAY_PMRSP);
> --
> 2.25.1
>
--
Matt Roper
Graphics Software Engineer
VTT-OSGC Platform Enablement
Intel Corporation
(916) 356-2795
More information about the Intel-gfx
mailing list