On Wed, Apr 26, 2023 at 02:40:18PM -0700, Lucas De Marchi wrote: > On Wed, Apr 26, 2023 at 04:57:00PM -0400, Rodrigo Vivi wrote: > > On xe_hw_engine_print_state we were printing: > > value_of(0x510) + 4 instead of > > value_of(0x514) as desired. > > > > So, let's properly define a RING_EXECLIST_SQ_CONTENTS_HI > > register to fix the issue and also to avoid other issues > > like that. > > > > Signed-off-by: Rodrigo Vivi <rodrigo.vivi@xxxxxxxxx> > > --- > > drivers/gpu/drm/xe/regs/xe_engine_regs.h | 3 ++- > > drivers/gpu/drm/xe/xe_execlist.c | 4 ++-- > > drivers/gpu/drm/xe/xe_hw_engine.c | 4 ++-- > > 3 files changed, 6 insertions(+), 5 deletions(-) > > > > diff --git a/drivers/gpu/drm/xe/regs/xe_engine_regs.h b/drivers/gpu/drm/xe/regs/xe_engine_regs.h > > index 2aa67d001c34..a1e1d1c206fa 100644 > > --- a/drivers/gpu/drm/xe/regs/xe_engine_regs.h > > +++ b/drivers/gpu/drm/xe/regs/xe_engine_regs.h > > @@ -84,7 +84,8 @@ > > RING_FORCE_TO_NONPRIV_DENY) > > #define RING_MAX_NONPRIV_SLOTS 12 > > > > -#define RING_EXECLIST_SQ_CONTENTS(base) _MMIO((base) + 0x510) > > +#define RING_EXECLIST_SQ_CONTENTS_LO(base) _MMIO((base) + 0x510) > > +#define RING_EXECLIST_SQ_CONTENTS_HI(base) _MMIO((base) + 0x510 + 4) > > > > #define RING_EXECLIST_CONTROL(base) _MMIO((base) + 0x550) > > #define EL_CTRL_LOAD REG_BIT(0) > > diff --git a/drivers/gpu/drm/xe/xe_execlist.c b/drivers/gpu/drm/xe/xe_execlist.c > > index 02021457b1f0..37ac6473195e 100644 > > --- a/drivers/gpu/drm/xe/xe_execlist.c > > +++ b/drivers/gpu/drm/xe/xe_execlist.c > > @@ -84,9 +84,9 @@ static void __start_lrc(struct xe_hw_engine *hwe, struct xe_lrc *lrc, > > xe_mmio_write32(gt, RING_MODE_GEN7(hwe->mmio_base).reg, > > _MASKED_BIT_ENABLE(GEN11_GFX_DISABLE_LEGACY_MODE)); > > > > - xe_mmio_write32(gt, RING_EXECLIST_SQ_CONTENTS(hwe->mmio_base).reg + 0, > > + xe_mmio_write32(gt, RING_EXECLIST_SQ_CONTENTS_LO(hwe->mmio_base).reg, > > lower_32_bits(lrc_desc)); > > - xe_mmio_write32(gt, RING_EXECLIST_SQ_CONTENTS(hwe->mmio_base).reg + 4, > > + xe_mmio_write32(gt, RING_EXECLIST_SQ_CONTENTS_HI(hwe->mmio_base).reg, > > upper_32_bits(lrc_desc)); > > xe_mmio_write32(gt, RING_EXECLIST_CONTROL(hwe->mmio_base).reg, > > EL_CTRL_LOAD); > > diff --git a/drivers/gpu/drm/xe/xe_hw_engine.c b/drivers/gpu/drm/xe/xe_hw_engine.c > > index 4b56c35b988d..23b9f120c258 100644 > > --- a/drivers/gpu/drm/xe/xe_hw_engine.c > > +++ b/drivers/gpu/drm/xe/xe_hw_engine.c > > @@ -528,10 +528,10 @@ void xe_hw_engine_print_state(struct xe_hw_engine *hwe, struct drm_printer *p) > > hw_engine_mmio_read32(hwe, RING_EXECLIST_STATUS_HI(0).reg)); > > drm_printf(p, "\tRING_EXECLIST_SQ_CONTENTS_LO: 0x%08x\n", > > hw_engine_mmio_read32(hwe, > > after this series and mine about register refactor we should probably go > and fix the coding style in this function. indeed > > ... thankfully it was just this print that was wrong and the rest was > correct. > > Reviewed-by: Lucas De Marchi <lucas.demarchi@xxxxxxxxx> Thank you! Since this was a small but needed fix I went already and merged this patch individually already. > > thanks > Lucas De Marchi > > > - RING_EXECLIST_SQ_CONTENTS(0).reg)); > > + RING_EXECLIST_SQ_CONTENTS_LO(0).reg)); > > drm_printf(p, "\tRING_EXECLIST_SQ_CONTENTS_HI: 0x%08x\n", > > hw_engine_mmio_read32(hwe, > > - RING_EXECLIST_SQ_CONTENTS(0).reg) + 4); > > + RING_EXECLIST_SQ_CONTENTS_HI(0).reg)); > > drm_printf(p, "\tRING_EXECLIST_CONTROL: 0x%08x\n", > > hw_engine_mmio_read32(hwe, RING_EXECLIST_CONTROL(0).reg)); > > > > -- > > 2.39.2 > >