diff options
Diffstat (limited to 'meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3135-drm-amdgpu-Update-MMHUB-power-gating-register-settin.patch')
-rw-r--r-- | meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3135-drm-amdgpu-Update-MMHUB-power-gating-register-settin.patch | 126 |
1 files changed, 126 insertions, 0 deletions
diff --git a/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3135-drm-amdgpu-Update-MMHUB-power-gating-register-settin.patch b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3135-drm-amdgpu-Update-MMHUB-power-gating-register-settin.patch new file mode 100644 index 00000000..bdf0d57a --- /dev/null +++ b/meta-amd-bsp/recipes-kernel/linux/linux-yocto-4.14.71/3135-drm-amdgpu-Update-MMHUB-power-gating-register-settin.patch @@ -0,0 +1,126 @@ +From ac2d9a9d78b5497413ae552788d3edf5c314fe24 Mon Sep 17 00:00:00 2001 +From: Yong Zhao <yong.zhao@amd.com> +Date: Thu, 21 Dec 2017 16:19:03 -0500 +Subject: [PATCH 3135/4131] drm/amdgpu: Update MMHUB power gating register + settings + +The new register settings are needed to fix a tlb invalidation issue +when MMHUB power gating is turned on for Raven. + +Change-Id: If91d224b075f9e3be85ebef5d55e2bd680d293cf +Signed-off-by: Yong Zhao <yong.zhao@amd.com> +Acked-by: Alex Deucher <alexander.deucher@amd.com> +Acked-by: Felix Kuehling <Felix.Kuehling@amd.com> +Acked-by: Eric Huang <JinhuiEric.Huang@amd.com> +Reviewed-by: Eric Huang <JinhuiEric.Huang@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c | 61 ++++++++++++++++++--------------- + 1 file changed, 33 insertions(+), 28 deletions(-) + +diff --git a/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c b/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c +index ffd5b7e..bdf94c6 100644 +--- a/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c ++++ b/drivers/gpu/drm/amd/amdgpu/mmhub_v1_0.c +@@ -272,21 +272,21 @@ static const struct pctl_data pctl0_data[] = { + {0x11, 0x6a684}, + {0x19, 0xea68e}, + {0x29, 0xa69e}, +- {0x2b, 0x34a6c0}, +- {0x61, 0x83a707}, +- {0xe6, 0x8a7a4}, +- {0xf0, 0x1a7b8}, +- {0xf3, 0xfa7cc}, +- {0x104, 0x17a7dd}, +- {0x11d, 0xa7dc}, +- {0x11f, 0x12a7f5}, +- {0x133, 0xa808}, +- {0x135, 0x12a810}, +- {0x149, 0x7a82c} ++ {0x2b, 0x0010a6c0}, ++ {0x3d, 0x83a707}, ++ {0xc2, 0x8a7a4}, ++ {0xcc, 0x1a7b8}, ++ {0xcf, 0xfa7cc}, ++ {0xe0, 0x17a7dd}, ++ {0xf9, 0xa7dc}, ++ {0xfb, 0x12a7f5}, ++ {0x10f, 0xa808}, ++ {0x111, 0x12a810}, ++ {0x125, 0x7a82c} + }; + #define PCTL0_DATA_LEN (ARRAY_SIZE(pctl0_data)) + +-#define PCTL0_RENG_EXEC_END_PTR 0x151 ++#define PCTL0_RENG_EXEC_END_PTR 0x12d + #define PCTL0_STCTRL_REG_SAVE_RANGE0_BASE 0xa640 + #define PCTL0_STCTRL_REG_SAVE_RANGE0_LIMIT 0xa833 + +@@ -385,10 +385,9 @@ void mmhub_v1_0_initialize_power_gating(struct amdgpu_device *adev) + if (amdgpu_sriov_vf(adev)) + return; + ++ /****************** pctl0 **********************/ + pctl0_misc = RREG32_SOC15(MMHUB, 0, mmPCTL0_MISC); + pctl0_reng_execute = RREG32_SOC15(MMHUB, 0, mmPCTL0_RENG_EXECUTE); +- pctl1_misc = RREG32_SOC15(MMHUB, 0, mmPCTL1_MISC); +- pctl1_reng_execute = RREG32_SOC15(MMHUB, 0, mmPCTL1_RENG_EXECUTE); + + /* Light sleep must be disabled before writing to pctl0 registers */ + pctl0_misc &= ~PCTL0_MISC__RENG_MEM_LS_ENABLE_MASK; +@@ -402,12 +401,13 @@ void mmhub_v1_0_initialize_power_gating(struct amdgpu_device *adev) + pctl0_data[i].data); + } + +- /* Set the reng execute end ptr for pctl0 */ +- pctl0_reng_execute = REG_SET_FIELD(pctl0_reng_execute, +- PCTL0_RENG_EXECUTE, +- RENG_EXECUTE_END_PTR, +- PCTL0_RENG_EXEC_END_PTR); +- WREG32_SOC15(MMHUB, 0, mmPCTL0_RENG_EXECUTE, pctl0_reng_execute); ++ /* Re-enable light sleep */ ++ pctl0_misc |= PCTL0_MISC__RENG_MEM_LS_ENABLE_MASK; ++ WREG32_SOC15(MMHUB, 0, mmPCTL0_MISC, pctl0_misc); ++ ++ /****************** pctl1 **********************/ ++ pctl1_misc = RREG32_SOC15(MMHUB, 0, mmPCTL1_MISC); ++ pctl1_reng_execute = RREG32_SOC15(MMHUB, 0, mmPCTL1_RENG_EXECUTE); + + /* Light sleep must be disabled before writing to pctl1 registers */ + pctl1_misc &= ~PCTL1_MISC__RENG_MEM_LS_ENABLE_MASK; +@@ -421,20 +421,25 @@ void mmhub_v1_0_initialize_power_gating(struct amdgpu_device *adev) + pctl1_data[i].data); + } + ++ /* Re-enable light sleep */ ++ pctl1_misc |= PCTL1_MISC__RENG_MEM_LS_ENABLE_MASK; ++ WREG32_SOC15(MMHUB, 0, mmPCTL1_MISC, pctl1_misc); ++ ++ mmhub_v1_0_power_gating_write_save_ranges(adev); ++ ++ /* Set the reng execute end ptr for pctl0 */ ++ pctl0_reng_execute = REG_SET_FIELD(pctl0_reng_execute, ++ PCTL0_RENG_EXECUTE, ++ RENG_EXECUTE_END_PTR, ++ PCTL0_RENG_EXEC_END_PTR); ++ WREG32_SOC15(MMHUB, 0, mmPCTL0_RENG_EXECUTE, pctl0_reng_execute); ++ + /* Set the reng execute end ptr for pctl1 */ + pctl1_reng_execute = REG_SET_FIELD(pctl1_reng_execute, + PCTL1_RENG_EXECUTE, + RENG_EXECUTE_END_PTR, + PCTL1_RENG_EXEC_END_PTR); + WREG32_SOC15(MMHUB, 0, mmPCTL1_RENG_EXECUTE, pctl1_reng_execute); +- +- mmhub_v1_0_power_gating_write_save_ranges(adev); +- +- /* Re-enable light sleep */ +- pctl0_misc |= PCTL0_MISC__RENG_MEM_LS_ENABLE_MASK; +- WREG32_SOC15(MMHUB, 0, mmPCTL0_MISC, pctl0_misc); +- pctl1_misc |= PCTL1_MISC__RENG_MEM_LS_ENABLE_MASK; +- WREG32_SOC15(MMHUB, 0, mmPCTL1_MISC, pctl1_misc); + } + + void mmhub_v1_0_update_power_gating(struct amdgpu_device *adev, +-- +2.7.4 + |