]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
drm/amdgpu: VCN v5_0_1 to prevent FW checking RB during DPG pause
authorSonny Jiang <sonny.jiang@amd.com>
Thu, 12 Jun 2025 15:01:08 +0000 (11:01 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 18 Jun 2025 17:13:13 +0000 (13:13 -0400)
Add a protection to ensure programming are all complete prior VCPU
starting. This is a WA for an unintended VCPU running.

Signed-off-by: Sonny Jiang <sonny.jiang@amd.com>
Acked-by: Leo Liu <leo.liu@amd.com>
Reviewed-by: Ruijing Dong <ruijing.dong@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
(cherry picked from commit c29521b529fa5e225feaf709d863a636ca0cbbfa)
Cc: stable@vger.kernel.org
drivers/gpu/drm/amd/amdgpu/vcn_v5_0_1.c

index 338cf43c45fe7ad6e8cbf3888712932553e477fb..cdefd7fcb0da607d36e947c1eefe01c5dc71abdb 100644 (file)
@@ -669,6 +669,9 @@ static int vcn_v5_0_1_start_dpg_mode(struct amdgpu_vcn_inst *vinst,
        if (indirect)
                amdgpu_vcn_psp_update_sram(adev, inst_idx, AMDGPU_UCODE_ID_VCN0_RAM);
 
+       /* resetting ring, fw should not check RB ring */
+       fw_shared->sq.queue_mode |= FW_QUEUE_RING_RESET;
+
        /* Pause dpg */
        vcn_v5_0_1_pause_dpg_mode(vinst, &state);
 
@@ -681,7 +684,7 @@ static int vcn_v5_0_1_start_dpg_mode(struct amdgpu_vcn_inst *vinst,
        tmp = RREG32_SOC15(VCN, vcn_inst, regVCN_RB_ENABLE);
        tmp &= ~(VCN_RB_ENABLE__RB1_EN_MASK);
        WREG32_SOC15(VCN, vcn_inst, regVCN_RB_ENABLE, tmp);
-       fw_shared->sq.queue_mode |= FW_QUEUE_RING_RESET;
+
        WREG32_SOC15(VCN, vcn_inst, regUVD_RB_RPTR, 0);
        WREG32_SOC15(VCN, vcn_inst, regUVD_RB_WPTR, 0);
 
@@ -692,6 +695,7 @@ static int vcn_v5_0_1_start_dpg_mode(struct amdgpu_vcn_inst *vinst,
        tmp = RREG32_SOC15(VCN, vcn_inst, regVCN_RB_ENABLE);
        tmp |= VCN_RB_ENABLE__RB1_EN_MASK;
        WREG32_SOC15(VCN, vcn_inst, regVCN_RB_ENABLE, tmp);
+       /* resetting done, fw can check RB ring */
        fw_shared->sq.queue_mode &= ~(FW_QUEUE_RING_RESET | FW_QUEUE_DPG_HOLD_OFF);
 
        WREG32_SOC15(VCN, vcn_inst, regVCN_RB1_DB_CTRL,