On Mon, Mar 17, 2025 at 2:08 AM Alexandre Demers <alexandre.f.demers@xxxxxxxxx> wrote: > > By replacing VGA_VSTATUS_CNTL by VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL_MASK, > we also need to fix its usage in GMC6. > > Note: VGA_VSTATUS_CNTL's binary value was inverted in dce_6_0_sh_mask.h, > so we need to invert its value where it was used. > > Signed-off-by: Alexandre Demers <alexandre.f.demers@xxxxxxxxx> > --- > drivers/gpu/drm/amd/amdgpu/dce_v6_0.c | 18 ++++++++--------- > drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c | 2 +- > drivers/gpu/drm/amd/amdgpu/si_enums.h | 5 ----- > drivers/gpu/drm/amd/amdgpu/sid.h | 20 ------------------- > .../include/asic_reg/dce/dce_6_0_sh_mask.h | 4 +++- > 5 files changed, 13 insertions(+), 36 deletions(-) > > diff --git a/drivers/gpu/drm/amd/amdgpu/dce_v6_0.c b/drivers/gpu/drm/amd/amdgpu/dce_v6_0.c > index e1b0779e835f..a9a087a841ea 100644 > --- a/drivers/gpu/drm/amd/amdgpu/dce_v6_0.c > +++ b/drivers/gpu/drm/amd/amdgpu/dce_v6_0.c > @@ -383,7 +383,7 @@ static void dce_v6_0_set_vga_render_state(struct amdgpu_device *adev, > { > if (!render) > WREG32(mmVGA_RENDER_CONTROL, > - RREG32(mmVGA_RENDER_CONTROL) & VGA_VSTATUS_CNTL); > + RREG32(mmVGA_RENDER_CONTROL) & ~VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL_MASK); > > } > > @@ -2078,7 +2078,7 @@ static void dce_v6_0_set_interleave(struct drm_crtc *crtc, > > if (mode->flags & DRM_MODE_FLAG_INTERLACE) > WREG32(mmDATA_FORMAT + amdgpu_crtc->crtc_offset, > - INTERLEAVE_EN); > + DATA_FORMAT__INTERLEAVE_EN_MASK); > else > WREG32(mmDATA_FORMAT + amdgpu_crtc->crtc_offset, 0); > } > @@ -2132,7 +2132,7 @@ static void dce_v6_0_crtc_load_lut(struct drm_crtc *crtc) > WREG32(mmDEGAMMA_CONTROL + amdgpu_crtc->crtc_offset, > ((0 << DEGAMMA_CONTROL__GRPH_DEGAMMA_MODE__SHIFT) | > (0 << DEGAMMA_CONTROL__OVL_DEGAMMA_MODE__SHIFT) | > - ICON_DEGAMMA_MODE(0) | > + (0 << DEGAMMA_CONTROL__ICON_DEGAMMA_MODE__SHIFT) | > (0 << DEGAMMA_CONTROL__CURSOR_DEGAMMA_MODE__SHIFT))); > WREG32(mmGAMUT_REMAP_CONTROL + amdgpu_crtc->crtc_offset, > ((0 << GAMUT_REMAP_CONTROL__GRPH_GAMUT_REMAP_MODE__SHIFT) | > @@ -2908,12 +2908,12 @@ static void dce_v6_0_set_crtc_vblank_interrupt_state(struct amdgpu_device *adev, > switch (state) { > case AMDGPU_IRQ_STATE_DISABLE: > interrupt_mask = RREG32(mmINT_MASK + reg_block); > - interrupt_mask &= ~VBLANK_INT_MASK; > + interrupt_mask &= ~INT_MASK__VBLANK_INT_MASK; > WREG32(mmINT_MASK + reg_block, interrupt_mask); > break; > case AMDGPU_IRQ_STATE_ENABLE: > interrupt_mask = RREG32(mmINT_MASK + reg_block); > - interrupt_mask |= VBLANK_INT_MASK; > + interrupt_mask |= INT_MASK__VBLANK_INT_MASK; > WREG32(mmINT_MASK + reg_block, interrupt_mask); > break; > default: > @@ -2943,12 +2943,12 @@ static int dce_v6_0_set_hpd_interrupt_state(struct amdgpu_device *adev, > switch (state) { > case AMDGPU_IRQ_STATE_DISABLE: > dc_hpd_int_cntl = RREG32(mmDC_HPD1_INT_CONTROL + hpd_offsets[type]); > - dc_hpd_int_cntl &= ~DC_HPDx_INT_EN; > + dc_hpd_int_cntl &= ~DC_HPD1_INT_CONTROL__DC_HPD1_INT_EN_MASK; > WREG32(mmDC_HPD1_INT_CONTROL + hpd_offsets[type], dc_hpd_int_cntl); > break; > case AMDGPU_IRQ_STATE_ENABLE: > dc_hpd_int_cntl = RREG32(mmDC_HPD1_INT_CONTROL + hpd_offsets[type]); > - dc_hpd_int_cntl |= DC_HPDx_INT_EN; > + dc_hpd_int_cntl |= DC_HPD1_INT_CONTROL__DC_HPD1_INT_EN_MASK; > WREG32(mmDC_HPD1_INT_CONTROL + hpd_offsets[type], dc_hpd_int_cntl); > break; > default: > @@ -3018,7 +3018,7 @@ static int dce_v6_0_crtc_irq(struct amdgpu_device *adev, > switch (entry->src_data[0]) { > case 0: /* vblank */ > if (disp_int & interrupt_status_offsets[crtc].vblank) > - WREG32(mmVBLANK_STATUS + crtc_offsets[crtc], VBLANK_ACK); > + WREG32(mmVBLANK_STATUS + crtc_offsets[crtc], VBLANK_STATUS__VBLANK_ACK_MASK); > else > DRM_DEBUG("IH: IH event w/o asserted irq bit?\n"); > > @@ -3029,7 +3029,7 @@ static int dce_v6_0_crtc_irq(struct amdgpu_device *adev, > break; > case 1: /* vline */ > if (disp_int & interrupt_status_offsets[crtc].vline) > - WREG32(mmVLINE_STATUS + crtc_offsets[crtc], VLINE_ACK); > + WREG32(mmVLINE_STATUS + crtc_offsets[crtc], VLINE_STATUS__VLINE_ACK_MASK); > else > DRM_DEBUG("IH: IH event w/o asserted irq bit?\n"); > > diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c > index ca000b3d1afc..2942fe8f80ec 100644 > --- a/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c > +++ b/drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c > @@ -248,7 +248,7 @@ static void gmc_v6_0_mc_program(struct amdgpu_device *adev) > > /* disable VGA render */ > tmp = RREG32(mmVGA_RENDER_CONTROL); > - tmp &= ~VGA_VSTATUS_CNTL; > + tmp &= VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL_MASK; > WREG32(mmVGA_RENDER_CONTROL, tmp); > } > /* Update configuration */ > diff --git a/drivers/gpu/drm/amd/amdgpu/si_enums.h b/drivers/gpu/drm/amd/amdgpu/si_enums.h > index b44a32bacd5c..f6804c9b7a27 100644 > --- a/drivers/gpu/drm/amd/amdgpu/si_enums.h > +++ b/drivers/gpu/drm/amd/amdgpu/si_enums.h > @@ -23,23 +23,18 @@ > #ifndef SI_ENUMS_H > #define SI_ENUMS_H > > -#define VBLANK_INT_MASK (1 << 0) > -#define DC_HPDx_INT_EN (1 << 16) > #define VBLANK_ACK (1 << 4) > #define VLINE_ACK (1 << 4) > > #define CURSOR_WIDTH 64 > #define CURSOR_HEIGHT 64 > > -#define VGA_VSTATUS_CNTL 0xFFFCFFFF > #define PRIORITY_MARK_MASK 0x7fff > #define PRIORITY_OFF (1 << 16) > #define PRIORITY_ALWAYS_ON (1 << 20) > -#define INTERLEAVE_EN (1 << 0) > > #define LATENCY_WATERMARK_MASK(x) ((x) << 16) > #define DC_LB_MEMORY_CONFIG(x) ((x) << 20) > -#define ICON_DEGAMMA_MODE(x) (((x) & 0x3) << 8) > > #define GRPH_ENDIAN_SWAP(x) (((x) & 0x3) << 0) > #define GRPH_ENDIAN_NONE 0 > diff --git a/drivers/gpu/drm/amd/amdgpu/sid.h b/drivers/gpu/drm/amd/amdgpu/sid.h > index cbf232f5235b..00eb40d4c1a2 100644 > --- a/drivers/gpu/drm/amd/amdgpu/sid.h > +++ b/drivers/gpu/drm/amd/amdgpu/sid.h > @@ -787,26 +787,6 @@ > # define LATENCY_LOW_WATERMARK(x) ((x) << 0) > # define LATENCY_HIGH_WATERMARK(x) ((x) << 16) > > -/* 0x6bb8, 0x77b8, 0x103b8, 0x10fb8, 0x11bb8, 0x127b8 */ > -#define VLINE_STATUS 0x1AEE > -# define VLINE_OCCURRED (1 << 0) > -# define VLINE_ACK (1 << 4) > -# define VLINE_STAT (1 << 12) > -# define VLINE_INTERRUPT (1 << 16) > -# define VLINE_INTERRUPT_TYPE (1 << 17) > -/* 0x6bbc, 0x77bc, 0x103bc, 0x10fbc, 0x11bbc, 0x127bc */ > -#define VBLANK_STATUS 0x1AEF > -# define VBLANK_OCCURRED (1 << 0) > -# define VBLANK_ACK (1 << 4) > -# define VBLANK_STAT (1 << 12) > -# define VBLANK_INTERRUPT (1 << 16) > -# define VBLANK_INTERRUPT_TYPE (1 << 17) > - > -/* 0x6b40, 0x7740, 0x10340, 0x10f40, 0x11b40, 0x12740 */ > -#define INT_MASK 0x1AD0 > -# define VBLANK_INT_MASK (1 << 0) > -# define VLINE_INT_MASK (1 << 4) > - > #define DISP_INTERRUPT_STATUS 0x183D > # define LB_D1_VLINE_INTERRUPT (1 << 2) > # define LB_D1_VBLANK_INTERRUPT (1 << 3) > diff --git a/drivers/gpu/drm/amd/include/asic_reg/dce/dce_6_0_sh_mask.h b/drivers/gpu/drm/amd/include/asic_reg/dce/dce_6_0_sh_mask.h > index bd8085ec54ed..942098af5655 100644 > --- a/drivers/gpu/drm/amd/include/asic_reg/dce/dce_6_0_sh_mask.h > +++ b/drivers/gpu/drm/amd/include/asic_reg/dce/dce_6_0_sh_mask.h > @@ -5242,6 +5242,8 @@ > #define DEGAMMA_CONTROL__CURSOR_DEGAMMA_MODE__SHIFT 0x0000000c > #define DEGAMMA_CONTROL__GRPH_DEGAMMA_MODE_MASK 0x00000003L > #define DEGAMMA_CONTROL__GRPH_DEGAMMA_MODE__SHIFT 0x00000000 > +#define DEGAMMA_CONTROL__ICON_DEGAMMA_MODE_MASK 0x00000300L // (((x) & 0x3) << 8) You can drop the comment here. > +#define DEGAMMA_CONTROL__ICON_DEGAMMA_MODE__SHIFT 0x00000008 > #define DEGAMMA_CONTROL__OVL_DEGAMMA_MODE_MASK 0x00000030L > #define DEGAMMA_CONTROL__OVL_DEGAMMA_MODE__SHIFT 0x00000004 > #define DENORM_CONTROL__DENORM_MODE_MASK 0x00000007L > @@ -9554,7 +9556,7 @@ > #define VGA_RENDER_CONTROL__VGA_LOCK_8DOT__SHIFT 0x00000018 > #define VGA_RENDER_CONTROL__VGAREG_LINECMP_COMPATIBILITY_SEL_MASK 0x02000000L > #define VGA_RENDER_CONTROL__VGAREG_LINECMP_COMPATIBILITY_SEL__SHIFT 0x00000019 > -#define VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL_MASK 0x00030000L > +#define VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL_MASK 0x00030000L // Interestingly, it was flipped from 0xFFFCFFFF Same here. > #define VGA_RENDER_CONTROL__VGA_VSTATUS_CNTL__SHIFT 0x00000010 > #define VGA_SEQUENCER_RESET_CONTROL__D1_BLANK_DISPLAY_WHEN_SEQUENCER_RESET_MASK 0x00000001L > #define VGA_SEQUENCER_RESET_CONTROL__D1_BLANK_DISPLAY_WHEN_SEQUENCER_RESET__SHIFT 0x00000000 > -- > 2.48.1 >