From: Likun Gao <[email protected]>

Revision doorbell range on muti-XCC mode for gfx v12_1.
Clean up doorbell range set for graphics engine.
V2: Remove doorbell range set from gfx_v12_1_xcc_kiq_init_register.

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 | 22 ++++++----------------
 1 file changed, 6 insertions(+), 16 deletions(-)

diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c 
b/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
index 2ef0fce100676..b6932073ff721 100644
--- a/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
+++ b/drivers/gpu/drm/amd/amdgpu/gfx_v12_1.c
@@ -1998,17 +1998,15 @@ static void gfx_v12_1_xcc_kiq_setting(struct 
amdgpu_ring *ring,
 static void gfx_v12_1_xcc_cp_set_doorbell_range(struct amdgpu_device *adev,
                                                int xcc_id)
 {
-       /* set graphics engine doorbell range */
-       WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_RB_DOORBELL_RANGE_LOWER,
-                    (adev->doorbell_index.gfx_ring0 * 2) << 2);
-       WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_RB_DOORBELL_RANGE_UPPER,
-                    (adev->doorbell_index.gfx_userqueue_end * 2) << 2);
-
        /* set compute engine doorbell range */
        WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_MEC_DOORBELL_RANGE_LOWER,
-                    (adev->doorbell_index.kiq * 2) << 2);
+                    ((adev->doorbell_index.kiq +
+                      xcc_id * adev->doorbell_index.xcc_doorbell_range) *
+                     2) << 2);
        WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_MEC_DOORBELL_RANGE_UPPER,
-                    (adev->doorbell_index.userqueue_end * 2) << 2);
+                    ((adev->doorbell_index.userqueue_end +
+                      xcc_id * adev->doorbell_index.xcc_doorbell_range) *
+                     2) << 2);
 }
 
 static int gfx_v12_1_compute_mqd_init(struct amdgpu_device *adev, void *m,
@@ -2218,14 +2216,6 @@ static int gfx_v12_1_xcc_kiq_init_register(struct 
amdgpu_ring *ring,
        WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_HQD_PQ_WPTR_POLL_ADDR_HI,
               mqd->cp_hqd_pq_wptr_poll_addr_hi);
 
-       /* enable the doorbell if requested */
-       if (ring->use_doorbell) {
-               WREG32_SOC15(GC, GET_INST(GC, xcc_id), 
regCP_MEC_DOORBELL_RANGE_LOWER,
-                       (adev->doorbell_index.kiq * 2) << 2);
-               WREG32_SOC15(GC, GET_INST(GC, xcc_id), 
regCP_MEC_DOORBELL_RANGE_UPPER,
-                       (adev->doorbell_index.userqueue_end * 2) << 2);
-       }
-
        WREG32_SOC15(GC, GET_INST(GC, xcc_id), regCP_HQD_PQ_DOORBELL_CONTROL,
               mqd->cp_hqd_pq_doorbell_control);
 
-- 
2.51.1

Reply via email to