|
@@ -785,12 +785,27 @@ static int vcn_v1_0_start_spg_mode(struct amdgpu_device *adev)
|
|
|
#endif
|
|
|
WREG32_SOC15(UVD, 0, mmUVD_LMI_SWAP_CNTL, lmi_swap_cntl);
|
|
|
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXA0, 0x40c2040);
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXA1, 0x0);
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXB0, 0x40c2040);
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXB1, 0x0);
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_ALU, 0);
|
|
|
- WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUX, 0x88);
|
|
|
+ tmp = RREG32_SOC15(UVD, 0, mmUVD_MPC_CNTL);
|
|
|
+ tmp &= ~UVD_MPC_CNTL__REPLACEMENT_MODE_MASK;
|
|
|
+ tmp |= 0x2 << UVD_MPC_CNTL__REPLACEMENT_MODE__SHIFT;
|
|
|
+ WREG32_SOC15(UVD, 0, mmUVD_MPC_CNTL, tmp);
|
|
|
+
|
|
|
+ WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXA0,
|
|
|
+ ((0x1 << UVD_MPC_SET_MUXA0__VARA_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUXA0__VARA_2__SHIFT) |
|
|
|
+ (0x3 << UVD_MPC_SET_MUXA0__VARA_3__SHIFT) |
|
|
|
+ (0x4 << UVD_MPC_SET_MUXA0__VARA_4__SHIFT)));
|
|
|
+
|
|
|
+ WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUXB0,
|
|
|
+ ((0x1 << UVD_MPC_SET_MUXB0__VARB_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUXB0__VARB_2__SHIFT) |
|
|
|
+ (0x3 << UVD_MPC_SET_MUXB0__VARB_3__SHIFT) |
|
|
|
+ (0x4 << UVD_MPC_SET_MUXB0__VARB_4__SHIFT)));
|
|
|
+
|
|
|
+ WREG32_SOC15(UVD, 0, mmUVD_MPC_SET_MUX,
|
|
|
+ ((0x0 << UVD_MPC_SET_MUX__SET_0__SHIFT) |
|
|
|
+ (0x1 << UVD_MPC_SET_MUX__SET_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUX__SET_2__SHIFT)));
|
|
|
|
|
|
/* take all subblocks out of reset, except VCPU */
|
|
|
WREG32_SOC15(UVD, 0, mmUVD_SOFT_RESET,
|
|
@@ -981,12 +996,25 @@ static int vcn_v1_0_start_dpg_mode(struct amdgpu_device *adev)
|
|
|
#endif
|
|
|
WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_LMI_SWAP_CNTL, lmi_swap_cntl, 0xFFFFFFFF, 0);
|
|
|
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXA0, 0x40c2040, 0xFFFFFFFF, 0);
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXA1, 0x0, 0xFFFFFFFF, 0);
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXB0, 0x40c2040, 0xFFFFFFFF, 0);
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXB1, 0x0, 0xFFFFFFFF, 0);
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_ALU, 0, 0xFFFFFFFF, 0);
|
|
|
- WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUX, 0x88, 0xFFFFFFFF, 0);
|
|
|
+ WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_CNTL,
|
|
|
+ 0x2 << UVD_MPC_CNTL__REPLACEMENT_MODE__SHIFT, 0xFFFFFFFF, 0);
|
|
|
+
|
|
|
+ WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXA0,
|
|
|
+ ((0x1 << UVD_MPC_SET_MUXA0__VARA_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUXA0__VARA_2__SHIFT) |
|
|
|
+ (0x3 << UVD_MPC_SET_MUXA0__VARA_3__SHIFT) |
|
|
|
+ (0x4 << UVD_MPC_SET_MUXA0__VARA_4__SHIFT)), 0xFFFFFFFF, 0);
|
|
|
+
|
|
|
+ WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUXB0,
|
|
|
+ ((0x1 << UVD_MPC_SET_MUXB0__VARB_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUXB0__VARB_2__SHIFT) |
|
|
|
+ (0x3 << UVD_MPC_SET_MUXB0__VARB_3__SHIFT) |
|
|
|
+ (0x4 << UVD_MPC_SET_MUXB0__VARB_4__SHIFT)), 0xFFFFFFFF, 0);
|
|
|
+
|
|
|
+ WREG32_SOC15_DPG_MODE(UVD, 0, mmUVD_MPC_SET_MUX,
|
|
|
+ ((0x0 << UVD_MPC_SET_MUX__SET_0__SHIFT) |
|
|
|
+ (0x1 << UVD_MPC_SET_MUX__SET_1__SHIFT) |
|
|
|
+ (0x2 << UVD_MPC_SET_MUX__SET_2__SHIFT)), 0xFFFFFFFF, 0);
|
|
|
|
|
|
vcn_v1_0_mc_resume_dpg_mode(adev);
|
|
|
|