From: Likun Gao <[email protected]>

Support for partition mode to program MCM_ADDR_LUT.

v2: clean up (Alex)

Signed-off-by: Likun Gao <[email protected]>
Reviewed-by: Hawking Zhang <[email protected]>
Signed-off-by: Alex Deucher <[email protected]>
---
 drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c |  5 -----
 drivers/gpu/drm/amd/amdgpu/soc_v1_0.c  | 11 +++++++++--
 2 files changed, 9 insertions(+), 7 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c 
b/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
index 73ca4921ae5a6..c2c4cb6154fb7 100644
--- a/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
+++ b/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
@@ -2666,11 +2666,6 @@ static void gfx_v12_1_init_golden_registers(struct 
amdgpu_device *adev)
                gfx_v12_1_xcc_enable_atomics(adev, i);
                gfx_v12_1_xcc_setup_tcp_thrashing_ctrl(adev, i);
        }
-
-       if (adev->gfx.imu.funcs &&
-           adev->gfx.imu.funcs->init_mcm_addr_lut &&
-           amdgpu_emu_mode)
-               adev->gfx.imu.funcs->init_mcm_addr_lut(adev);
 }
 
 static int gfx_v12_1_hw_init(struct amdgpu_ip_block *ip_block)
diff --git a/drivers/gpu/drm/amd/amdgpu/soc_v1_0.c 
b/drivers/gpu/drm/amd/amdgpu/soc_v1_0.c
index baa353ee7d1c1..628abd25ac091 100644
--- a/drivers/gpu/drm/amd/amdgpu/soc_v1_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/soc_v1_0.c
@@ -658,8 +658,15 @@ static int soc_v1_0_switch_partition_mode(struct 
amdgpu_xcp_mgr *xcp_mgr,
 
        num_xcc_per_xcp = __soc_v1_0_get_xcc_per_xcp(xcp_mgr, mode);
        if (adev->gfx.imu.funcs &&
-           adev->gfx.imu.funcs->switch_compute_partition)
-               adev->gfx.imu.funcs->switch_compute_partition(xcp_mgr->adev, 
num_xcc_per_xcp, mode);
+           adev->gfx.imu.funcs->switch_compute_partition) {
+               ret = 
adev->gfx.imu.funcs->switch_compute_partition(xcp_mgr->adev, num_xcc_per_xcp, 
mode);
+               if (ret)
+                       goto out;
+       }
+       if (adev->gfx.imu.funcs &&
+           adev->gfx.imu.funcs->init_mcm_addr_lut &&
+           amdgpu_emu_mode)
+               adev->gfx.imu.funcs->init_mcm_addr_lut(adev);
 
        /* Init info about new xcps */
        *num_xcps = num_xcc / num_xcc_per_xcp;
-- 
2.52.0

Reply via email to