]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
drm/amdgpu: use proper defines, shifts and masks in DCE6 code
authorAlexandre Demers <alexandre.f.demers@gmail.com>
Sat, 22 Mar 2025 01:46:45 +0000 (21:46 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 7 Apr 2025 19:18:32 +0000 (15:18 -0400)
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@gmail.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/dce_v6_0.c
drivers/gpu/drm/amd/amdgpu/gmc_v6_0.c
drivers/gpu/drm/amd/amdgpu/si_enums.h
drivers/gpu/drm/amd/amdgpu/sid.h
drivers/gpu/drm/amd/include/asic_reg/dce/dce_6_0_sh_mask.h

index 255c7095934339a8af1c5a33f12480807dde12a0..98d6ffcfefe3d7619ecaf2ab6ad2993eecebec47 100644 (file)
@@ -412,7 +412,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);
 }
 
 static int dce_v6_0_get_num_crtc(struct amdgpu_device *adev)
@@ -2108,7 +2108,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);
 }
@@ -2162,7 +2162,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) |
@@ -2986,12 +2986,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:
@@ -3021,12 +3021,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:
@@ -3096,7 +3096,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");
 
@@ -3107,7 +3107,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");
 
index a992e79d9581bcd6b2c70b3383808c99106579de..b4567d619d098934219bff863147fd59270a9d27 100644 (file)
@@ -249,7 +249,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 */
index b44a32bacd5c035dceffe27132473f83390d8566..f6804c9b7a27350fbb73e5bbc0cfed0d99f34e3f 100644 (file)
 #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
index cbf232f5235b73822300f07377f5b4301154a52b..00eb40d4c1a2f7f35f431d18a7838507c1770ff9 100644 (file)
 #       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)
index bd8085ec54ed57f8086ba8d035f08976377180b7..2d6a598a6c25cd12a9fea124d14718f4aaf7c50b 100644 (file)
 #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
+#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