drm/amdgpu: Add clock gating support for aldebaran
authorLijo Lazar <lijo.lazar@amd.com>
Fri, 5 Mar 2021 20:58:04 +0000 (15:58 -0500)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 24 Mar 2021 02:57:22 +0000 (22:57 -0400)
Aldebaran clock gating support for GFX,SDMA,IH blocks
VCN/JPEG blocks are excluded in this patch, to be enabled later

Signed-off-by: Lijo Lazar <lijo.lazar@amd.com>
Acked-by: Feifei Xu <Feifei.Xu@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
drivers/gpu/drm/amd/amdgpu/soc15.c

index a1fba18..82c7d04 100644 (file)
@@ -4895,7 +4895,7 @@ static void gfx_v9_0_update_3d_clock_gating(struct amdgpu_device *adev,
 {
        uint32_t data, def;
 
-       if (adev->asic_type == CHIP_ARCTURUS)
+       if (!adev->gfx.num_gfx_rings)
                return;
 
        amdgpu_gfx_rlc_enter_safe_mode(adev);
@@ -5142,6 +5142,7 @@ static int gfx_v9_0_set_clockgating_state(void *handle,
        case CHIP_RAVEN:
        case CHIP_ARCTURUS:
        case CHIP_RENOIR:
+       case CHIP_ALDEBARAN:
                gfx_v9_0_update_gfx_clock_gating(adev,
                                                 state == AMD_CG_STATE_GATE);
                break;
index b47cdee..3808402 100644 (file)
@@ -1487,7 +1487,16 @@ static int soc15_common_early_init(void *handle)
                break;
        case CHIP_ALDEBARAN:
                adev->asic_funcs = &vega20_asic_funcs;
-               adev->cg_flags = 0;
+               adev->cg_flags = AMD_CG_SUPPORT_GFX_MGCG |
+                       AMD_CG_SUPPORT_GFX_MGLS |
+                       AMD_CG_SUPPORT_GFX_CGCG |
+                       AMD_CG_SUPPORT_GFX_CGLS |
+                       AMD_CG_SUPPORT_GFX_CP_LS |
+                       AMD_CG_SUPPORT_HDP_LS |
+                       AMD_CG_SUPPORT_SDMA_MGCG |
+                       AMD_CG_SUPPORT_SDMA_LS |
+                       AMD_CG_SUPPORT_IH_CG;
+                       /*AMD_CG_SUPPORT_VCN_MGCG |AMD_CG_SUPPORT_JPEG_MGCG;*/
                adev->pg_flags = AMD_PG_SUPPORT_VCN_DPG;
                adev->external_rev_id = adev->rev_id + 0x3c;
                break;
@@ -1724,6 +1733,7 @@ static int soc15_common_set_clockgating_state(void *handle,
                                state == AMD_CG_STATE_GATE);
                break;
        case CHIP_ARCTURUS:
+       case CHIP_ALDEBARAN:
                adev->hdp.funcs->update_clock_gating(adev,
                                state == AMD_CG_STATE_GATE);
                break;
@@ -1745,15 +1755,18 @@ static void soc15_common_get_clockgating_state(void *handle, u32 *flags)
 
        adev->hdp.funcs->get_clock_gating_state(adev, flags);
 
-       /* AMD_CG_SUPPORT_DRM_MGCG */
-       data = RREG32(SOC15_REG_OFFSET(MP0, 0, mmMP0_MISC_CGTT_CTRL0));
-       if (!(data & 0x01000000))
-               *flags |= AMD_CG_SUPPORT_DRM_MGCG;
+       if (adev->asic_type != CHIP_ALDEBARAN) {
 
-       /* AMD_CG_SUPPORT_DRM_LS */
-       data = RREG32(SOC15_REG_OFFSET(MP0, 0, mmMP0_MISC_LIGHT_SLEEP_CTRL));
-       if (data & 0x1)
-               *flags |= AMD_CG_SUPPORT_DRM_LS;
+               /* AMD_CG_SUPPORT_DRM_MGCG */
+               data = RREG32(SOC15_REG_OFFSET(MP0, 0, mmMP0_MISC_CGTT_CTRL0));
+               if (!(data & 0x01000000))
+                       *flags |= AMD_CG_SUPPORT_DRM_MGCG;
+
+               /* AMD_CG_SUPPORT_DRM_LS */
+               data = RREG32(SOC15_REG_OFFSET(MP0, 0, mmMP0_MISC_LIGHT_SLEEP_CTRL));
+               if (data & 0x1)
+                       *flags |= AMD_CG_SUPPORT_DRM_LS;
+       }
 
        /* AMD_CG_SUPPORT_ROM_MGCG */
        adev->smuio.funcs->get_clock_gating_state(adev, flags);