Skip to content

Commit 4039e44

Browse files
committed
drm/i915/pvc: Annotate two more workaround/tuning registers as MCR
XEHPC_LNCFMISCCFGREG0 and XEHPC_L3SCRUB are both in MCR register ranges on PVC (with HALFBSLICE and L3BANK replication respectively), so they should be explicitly declared as MCR registers and use MCR-aware workaround handlers. The workarounds/tuning settings should still be applied properly on PVC even without the MCR annotation, but readback verification on CONFIG_DRM_I915_DEBUG_GEM builds could potentitally give false positive "workaround lost on load" warnings on parts fused such that a unicast read targets a terminated register instance. Fixes: a9e6942 ("drm/i915: Define MCR registers explicitly") Signed-off-by: Matt Roper <[email protected]> Reviewed-by: Gustavo Sousa <[email protected]> Link: https://patchwork.freedesktop.org/patch/msgid/[email protected]
1 parent 9310dba commit 4039e44

File tree

2 files changed

+12
-6
lines changed

2 files changed

+12
-6
lines changed

drivers/gpu/drm/i915/gt/intel_gt_regs.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -979,7 +979,7 @@
979979
#define GEN7_WA_FOR_GEN7_L3_CONTROL 0x3C47FF8C
980980
#define GEN7_L3AGDIS (1 << 19)
981981

982-
#define XEHPC_LNCFMISCCFGREG0 _MMIO(0xb01c)
982+
#define XEHPC_LNCFMISCCFGREG0 MCR_REG(0xb01c)
983983
#define XEHPC_HOSTCACHEEN REG_BIT(1)
984984
#define XEHPC_OVRLSCCC REG_BIT(0)
985985

@@ -1042,7 +1042,7 @@
10421042
#define XEHP_L3SCQREG7 MCR_REG(0xb188)
10431043
#define BLEND_FILL_CACHING_OPT_DIS REG_BIT(3)
10441044

1045-
#define XEHPC_L3SCRUB _MMIO(0xb18c)
1045+
#define XEHPC_L3SCRUB MCR_REG(0xb18c)
10461046
#define SCRUB_CL_DWNGRADE_SHARED REG_BIT(12)
10471047
#define SCRUB_RATE_PER_BANK_MASK REG_GENMASK(2, 0)
10481048
#define SCRUB_RATE_4B_PER_CLK REG_FIELD_PREP(SCRUB_RATE_PER_BANK_MASK, 0x6)

drivers/gpu/drm/i915/gt/intel_workarounds.c

Lines changed: 10 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -240,6 +240,12 @@ wa_write(struct i915_wa_list *wal, i915_reg_t reg, u32 set)
240240
wa_write_clr_set(wal, reg, ~0, set);
241241
}
242242

243+
static void
244+
wa_mcr_write(struct i915_wa_list *wal, i915_mcr_reg_t reg, u32 set)
245+
{
246+
wa_mcr_write_clr_set(wal, reg, ~0, set);
247+
}
248+
243249
static void
244250
wa_write_or(struct i915_wa_list *wal, i915_reg_t reg, u32 set)
245251
{
@@ -2970,9 +2976,9 @@ add_render_compute_tuning_settings(struct drm_i915_private *i915,
29702976
struct i915_wa_list *wal)
29712977
{
29722978
if (IS_PONTEVECCHIO(i915)) {
2973-
wa_write(wal, XEHPC_L3SCRUB,
2974-
SCRUB_CL_DWNGRADE_SHARED | SCRUB_RATE_4B_PER_CLK);
2975-
wa_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_HOSTCACHEEN);
2979+
wa_mcr_write(wal, XEHPC_L3SCRUB,
2980+
SCRUB_CL_DWNGRADE_SHARED | SCRUB_RATE_4B_PER_CLK);
2981+
wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_HOSTCACHEEN);
29762982
}
29772983

29782984
if (IS_DG2(i915)) {
@@ -3062,7 +3068,7 @@ general_render_compute_wa_init(struct intel_engine_cs *engine, struct i915_wa_li
30623068

30633069
if (IS_PONTEVECCHIO(i915)) {
30643070
/* Wa_16016694945 */
3065-
wa_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_OVRLSCCC);
3071+
wa_mcr_masked_en(wal, XEHPC_LNCFMISCCFGREG0, XEHPC_OVRLSCCC);
30663072
}
30673073

30683074
if (IS_XEHPSDV(i915)) {

0 commit comments

Comments
 (0)