drm/amdgpu/vcn2.5: fix VCN stop logic
authorAlex Deucher <alexander.deucher@amd.com>
Mon, 24 Feb 2025 16:13:27 +0000 (11:13 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Thu, 27 Feb 2025 20:52:11 +0000 (15:52 -0500)
Need to make sure we call amdgpu_dpm_enable_vcn()
in vcn_v2_5_stop() at the end if there are errors
or DPG is enabled.

Fixes: ebc25499de12 ("drm/amdgpu/vcn2.5: split code along instances")
Reviewed-by: Boyuan Zhang <Boyuan.Zhang@amd.com>
Suggested-by: Boyuan Zhang <boyuan.zhang@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/vcn_v2_5.c

index a6726afcf89cb8b01f88f5f89d0db1b7731a18e7..e36e2a5676df9aa284c49eaa98f40d13afb1ba74 100644 (file)
@@ -1414,13 +1414,15 @@ static int vcn_v2_5_stop(struct amdgpu_device *adev, int i)
 
        if (adev->vcn.harvest_config & (1 << i))
                return 0;
-       if (adev->pg_flags & AMD_PG_SUPPORT_VCN_DPG)
-               return vcn_v2_5_stop_dpg_mode(adev, i);
+       if (adev->pg_flags & AMD_PG_SUPPORT_VCN_DPG) {
+               r = vcn_v2_5_stop_dpg_mode(adev, i);
+               goto done;
+       }
 
        /* wait for vcn idle */
        r = SOC15_WAIT_ON_RREG(VCN, i, mmUVD_STATUS, UVD_STATUS__IDLE, 0x7);
        if (r)
-               return r;
+               goto done;
 
        tmp = UVD_LMI_STATUS__VCPU_LMI_WRITE_CLEAN_MASK |
                UVD_LMI_STATUS__READ_CLEAN_MASK |
@@ -1428,7 +1430,7 @@ static int vcn_v2_5_stop(struct amdgpu_device *adev, int i)
                UVD_LMI_STATUS__WRITE_CLEAN_RAW_MASK;
        r = SOC15_WAIT_ON_RREG(VCN, i, mmUVD_LMI_STATUS, tmp, tmp);
        if (r)
-               return r;
+               goto done;
 
        /* block LMI UMC channel */
        tmp = RREG32_SOC15(VCN, i, mmUVD_LMI_CTRL2);
@@ -1439,7 +1441,7 @@ static int vcn_v2_5_stop(struct amdgpu_device *adev, int i)
                UVD_LMI_STATUS__UMC_WRITE_CLEAN_RAW_MASK;
        r = SOC15_WAIT_ON_RREG(VCN, i, mmUVD_LMI_STATUS, tmp, tmp);
        if (r)
-               return r;
+               goto done;
 
        /* block VCPU register access */
        WREG32_P(SOC15_REG_OFFSET(VCN, i, mmUVD_RB_ARB_CTRL),
@@ -1465,10 +1467,11 @@ static int vcn_v2_5_stop(struct amdgpu_device *adev, int i)
                 UVD_POWER_STATUS__UVD_POWER_STATUS_MASK,
                 ~UVD_POWER_STATUS__UVD_POWER_STATUS_MASK);
 
+done:
        if (adev->pm.dpm_enabled)
                amdgpu_dpm_enable_vcn(adev, false, i);
 
-       return 0;
+       return r;
 }
 
 static int vcn_v2_5_pause_dpg_mode(struct amdgpu_device *adev,