On Mon, 2022-05-02 at 09:34 -0700, Matt Roper wrote:
> From: Lucas De Marchi <lucas.demar...@intel.com>
> 
> The new Link Copy engines in PVC may be fused off according to the
> mslice_mask. Each bit of the MEML3_EN_MASK we read from the
> GEN10_MIRROR_FUSE3 register disables a pair of link copy engines.

Reviewed-by: José Roberto de Souza <jose.so...@intel.com>

> 
> Bspec: 44483
> Cc: Matt Roper <matthew.d.ro...@intel.com>
> Signed-off-by: Lucas De Marchi <lucas.demar...@intel.com>
> Signed-off-by: Matt Roper <matthew.d.ro...@intel.com>
> ---
>  drivers/gpu/drm/i915/gt/intel_engine_cs.c | 28 +++++++++++++++++++++++
>  1 file changed, 28 insertions(+)
> 
> diff --git a/drivers/gpu/drm/i915/gt/intel_engine_cs.c 
> b/drivers/gpu/drm/i915/gt/intel_engine_cs.c
> index c6e93db134b1..d10cdeff5072 100644
> --- a/drivers/gpu/drm/i915/gt/intel_engine_cs.c
> +++ b/drivers/gpu/drm/i915/gt/intel_engine_cs.c
> @@ -686,6 +686,33 @@ static void engine_mask_apply_compute_fuses(struct 
> intel_gt *gt)
>       }
>  }
>  
> +static void engine_mask_apply_copy_fuses(struct intel_gt *gt)
> +{
> +     struct drm_i915_private *i915 = gt->i915;
> +     struct intel_gt_info *info = &gt->info;
> +     unsigned long meml3_mask;
> +     u8 quad;
> +
> +     meml3_mask = intel_uncore_read(gt->uncore, GEN10_MIRROR_FUSE3);
> +     meml3_mask = REG_FIELD_GET(GEN12_MEML3_EN_MASK, meml3_mask);
> +
> +     /*
> +      * Link Copy engines may be fused off according to meml3_mask. Each
> +      * bit is a quad that houses 2 Link Copy and two Sub Copy engines.
> +      */
> +     for_each_clear_bit(quad, &meml3_mask, GEN12_MAX_MSLICES) {
> +             intel_engine_mask_t mask = GENMASK(BCS1 + quad * 2 + 1,
> +                                                BCS1 + quad * 2);
> +
> +             if (mask & info->engine_mask) {
> +                     drm_dbg(&i915->drm, "bcs%u fused off\n", quad * 2 + 1);
> +                     drm_dbg(&i915->drm, "bcs%u fused off\n", quad * 2 + 2);
> +
> +                     info->engine_mask &= ~mask;
> +             }
> +     }
> +}
> +
>  /*
>   * Determine which engines are fused off in our particular hardware.
>   * Note that we have a catch-22 situation where we need to be able to access
> @@ -768,6 +795,7 @@ static intel_engine_mask_t init_engine_mask(struct 
> intel_gt *gt)
>       GEM_BUG_ON(vebox_mask != VEBOX_MASK(gt));
>  
>       engine_mask_apply_compute_fuses(gt);
> +     engine_mask_apply_copy_fuses(gt);
>  
>       return info->engine_mask;
>  }

Reply via email to