Commit 98ce59e9 authored by Lucas De Marchi's avatar Lucas De Marchi Committed by Rodrigo Vivi

drm/xe/guc: Handle RCU_MODE as masked from definition

guc_mmio_regset_write() had a flags for the registers to be added to the
GuC's regset list. The only register actually using that was RCU_MODE,
but it was setting the flags to a bogus value. From
struct xe_guc_fwif.h,

	#define GUC_REGSET_MASKED               BIT(0)
	#define GUC_REGSET_MASKED_WITH_VALUE    BIT(2)
	#define GUC_REGSET_RESTORE_ONLY         BIT(3)

Cross checking with i915, the only flag to set in RCU_MODE is
GUC_REGSET_MASKED. That can be done automatically from the register, as
long as the definition is correct.

Add the XE_REG_OPTION_MASKED annotation to RCU_MODE and kill the "flags"
field in guc_mmio_regset_write(): guc_mmio_regset_write_one() can decide
that based on the register being passed.
Reviewed-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://lore.kernel.org/r/20230429062332.354139-3-lucas.demarchi@intel.comSigned-off-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent a31153fc
...@@ -325,7 +325,7 @@ ...@@ -325,7 +325,7 @@
#define SARB_CHICKEN1 XE_REG_MCR(0xe90c) #define SARB_CHICKEN1 XE_REG_MCR(0xe90c)
#define COMP_CKN_IN REG_GENMASK(30, 29) #define COMP_CKN_IN REG_GENMASK(30, 29)
#define RCU_MODE XE_REG(0x14800) #define RCU_MODE XE_REG(0x14800, XE_REG_OPTION_MASKED)
#define RCU_MODE_CCS_ENABLE REG_BIT(0) #define RCU_MODE_CCS_ENABLE REG_BIT(0)
#define FORCEWAKE_ACK_GT XE_REG(0x130044) #define FORCEWAKE_ACK_GT XE_REG(0x130044)
......
...@@ -422,12 +422,12 @@ static void guc_capture_list_init(struct xe_guc_ads *ads) ...@@ -422,12 +422,12 @@ static void guc_capture_list_init(struct xe_guc_ads *ads)
static void guc_mmio_regset_write_one(struct xe_guc_ads *ads, static void guc_mmio_regset_write_one(struct xe_guc_ads *ads,
struct iosys_map *regset_map, struct iosys_map *regset_map,
u32 reg, u32 flags, struct xe_reg reg,
unsigned int n_entry) unsigned int n_entry)
{ {
struct guc_mmio_reg entry = { struct guc_mmio_reg entry = {
.offset = reg, .offset = reg.reg,
.flags = flags, .flags = reg.masked ? GUC_REGSET_MASKED : 0,
/* TODO: steering */ /* TODO: steering */
}; };
...@@ -446,40 +446,33 @@ static unsigned int guc_mmio_regset_write(struct xe_guc_ads *ads, ...@@ -446,40 +446,33 @@ static unsigned int guc_mmio_regset_write(struct xe_guc_ads *ads,
unsigned long idx; unsigned long idx;
unsigned count = 0; unsigned count = 0;
const struct { const struct {
u32 reg; struct xe_reg reg;
u32 flags;
bool skip; bool skip;
} *e, extra_regs[] = { } *e, extra_regs[] = {
{ .reg = RING_MODE(hwe->mmio_base).reg, }, { .reg = RING_MODE(hwe->mmio_base), },
{ .reg = RING_HWS_PGA(hwe->mmio_base).reg, }, { .reg = RING_HWS_PGA(hwe->mmio_base), },
{ .reg = RING_IMR(hwe->mmio_base).reg, }, { .reg = RING_IMR(hwe->mmio_base), },
{ .reg = RCU_MODE.reg, .flags = 0x3, { .reg = RCU_MODE, .skip = hwe != hwe_rcs_reset_domain },
.skip = hwe != hwe_rcs_reset_domain },
}; };
u32 i; u32 i;
BUILD_BUG_ON(ARRAY_SIZE(extra_regs) > ADS_REGSET_EXTRA_MAX); BUILD_BUG_ON(ARRAY_SIZE(extra_regs) > ADS_REGSET_EXTRA_MAX);
xa_for_each(&hwe->reg_sr.xa, idx, entry) { xa_for_each(&hwe->reg_sr.xa, idx, entry)
u32 flags = entry->reg.masked ? GUC_REGSET_MASKED : 0; guc_mmio_regset_write_one(ads, regset_map, entry->reg, count++);
guc_mmio_regset_write_one(ads, regset_map, idx, flags, count++);
}
for (e = extra_regs; e < extra_regs + ARRAY_SIZE(extra_regs); e++) { for (e = extra_regs; e < extra_regs + ARRAY_SIZE(extra_regs); e++) {
if (e->skip) if (e->skip)
continue; continue;
guc_mmio_regset_write_one(ads, regset_map, guc_mmio_regset_write_one(ads, regset_map, e->reg, count++);
e->reg, e->flags, count++);
} }
/* Wa_1607983814 */ /* Wa_1607983814 */
if (needs_wa_1607983814(xe) && hwe->class == XE_ENGINE_CLASS_RENDER) { if (needs_wa_1607983814(xe) && hwe->class == XE_ENGINE_CLASS_RENDER) {
for (i = 0; i < LNCFCMOCS_REG_COUNT; i++) { for (i = 0; i < LNCFCMOCS_REG_COUNT; i++) {
guc_mmio_regset_write_one(ads, regset_map, guc_mmio_regset_write_one(ads, regset_map,
LNCFCMOCS(i).reg, 0, LNCFCMOCS(i), count++);
count++);
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment