drm/xe/pvc: Fix WA 18020744125
authorLucas De Marchi <lucas.demarchi@intel.com>
Wed, 6 Mar 2024 19:21:28 +0000 (11:21 -0800)
committerLucas De Marchi <lucas.demarchi@intel.com>
Fri, 8 Mar 2024 18:19:26 +0000 (10:19 -0800)
With the current state GUC_WA_RCS_REGS_IN_CCS_REGS_LIST could in theory
be removed since there is no render register being added to the list of
compute WAs. However the real issue is that 18020744125 is incomplete
and not setting the RING_HWSTAM on render as it should.

Writing this in RTP is a little more tricky as we want to write to
another's engine base when the match happens: first compute engine and
no render present. So use RING_HWSTAM(RENDER_RING_BASE) instead of the
usual XE_RTP_ACTION_FLAG(ENGINE_BASE).

Reviewed-by: Matt Roper <matthew.d.roper@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20240306192128.1895603-2-lucas.demarchi@intel.com
Signed-off-by: Lucas De Marchi <lucas.demarchi@intel.com>
drivers/gpu/drm/xe/xe_wa.c

index 2460c570e6287032a7ba2f3277a4192b8d21d3b7..54740d2463106e7240e71c192c94d3b38613fad8 100644 (file)
@@ -377,6 +377,11 @@ static const struct xe_rtp_entry_sr engine_was[] = {
          XE_RTP_RULES(PLATFORM(PVC), FUNC(xe_rtp_match_first_render_or_compute)),
          XE_RTP_ACTIONS(SET(ROW_CHICKEN4, XEHP_DIS_BBL_SYSPIPE))
        },
+       { XE_RTP_NAME("18020744125"),
+         XE_RTP_RULES(PLATFORM(PVC), FUNC(xe_rtp_match_first_render_or_compute),
+                      ENGINE_CLASS(COMPUTE)),
+         XE_RTP_ACTIONS(SET(RING_HWSTAM(RENDER_RING_BASE), ~0))
+       },
        { XE_RTP_NAME("14014999345"),
          XE_RTP_RULES(PLATFORM(PVC), ENGINE_CLASS(COMPUTE),
                       GRAPHICS_STEP(B0, C0)),