[PATCH] drm/amdgpu: reduce RLC safe mode request for gfx clock gating

Liang, Prike Prike.Liang at amd.com
Thu Jan 2 08:45:02 UTC 2025


[AMD Official Use Only - AMD Internal Distribution Only]

Ping...

Regards,
      Prike

> -----Original Message-----
> From: Liang, Prike <Prike.Liang at amd.com>
> Sent: Tuesday, December 24, 2024 2:16 PM
> To: amd-gfx at lists.freedesktop.org
> Cc: Deucher, Alexander <Alexander.Deucher at amd.com>; Lazar, Lijo
> <Lijo.Lazar at amd.com>; Liang, Prike <Prike.Liang at amd.com>
> Subject: [PATCH] drm/amdgpu: reduce RLC safe mode request for gfx clock gating
>
> The driver can only request one time for the power safe mode instead of polling and
> disabling the power feature each time prior to program the GFX clock gating control
> registers. This update will reduce the latency on the GFX clock gating entry.
>
> Signed-off-by: Prike Liang <Prike.Liang at amd.com>
> ---
>  drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c | 12 ++++--------
> drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c | 14 ++------------
>  2 files changed, 6 insertions(+), 20 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> b/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> index af73f85527b7..6a025438f9d0 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v8_0.c
> @@ -5639,8 +5639,6 @@ static void
> gfx_v8_0_update_medium_grain_clock_gating(struct amdgpu_device *adev  {
>       uint32_t temp, data;
>
> -     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> -
>       /* It is disabled by HW by default */
>       if (enable && (adev->cg_flags & AMD_CG_SUPPORT_GFX_MGCG)) {
>               if (adev->cg_flags & AMD_CG_SUPPORT_GFX_MGLS) { @@ -
> 5734,8 +5732,6 @@ static void
> gfx_v8_0_update_medium_grain_clock_gating(struct amdgpu_device *adev
>               /* 7- wait for RLC_SERDES_CU_MASTER &
> RLC_SERDES_NONCU_MASTER idle */
>               gfx_v8_0_wait_for_rlc_serdes(adev);
>       }
> -
> -     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>  }
>
>  static void gfx_v8_0_update_coarse_grain_clock_gating(struct amdgpu_device
> *adev, @@ -5745,8 +5741,6 @@ static void
> gfx_v8_0_update_coarse_grain_clock_gating(struct amdgpu_device *adev
>
>       temp = data = RREG32(mmRLC_CGCG_CGLS_CTRL);
>
> -     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> -
>       if (enable && (adev->cg_flags & AMD_CG_SUPPORT_GFX_CGCG)) {
>               temp1 = data1 =
>       RREG32(mmRLC_CGTT_MGCG_OVERRIDE);
>               data1 &= ~RLC_CGTT_MGCG_OVERRIDE__CGCG_MASK;
> @@ -5827,12 +5821,12 @@ static void
> gfx_v8_0_update_coarse_grain_clock_gating(struct amdgpu_device *adev
>       }
>
>       gfx_v8_0_wait_for_rlc_serdes(adev);
> -
> -     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>  }
>  static int gfx_v8_0_update_gfx_clock_gating(struct amdgpu_device *adev,
>                                           bool enable)
>  {
> +     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> +
>       if (enable) {
>               /* CGCG/CGLS should be enabled after MGCG/MGLS/TS(CG/LS)
>                * ===  MGCG + MGLS + TS(CG/LS) ===
> @@ -5846,6 +5840,8 @@ static int gfx_v8_0_update_gfx_clock_gating(struct
> amdgpu_device *adev,
>               gfx_v8_0_update_coarse_grain_clock_gating(adev, enable);
>               gfx_v8_0_update_medium_grain_clock_gating(adev, enable);
>       }
> +
> +     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>       return 0;
>  }
>
> diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> index 4b5006dc3d34..fa572b40989e 100644
> --- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> +++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
> @@ -4964,8 +4964,6 @@ static void
> gfx_v9_0_update_medium_grain_clock_gating(struct amdgpu_device *adev  {
>       uint32_t data, def;
>
> -     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> -
>       /* It is disabled by HW by default */
>       if (enable && (adev->cg_flags & AMD_CG_SUPPORT_GFX_MGCG)) {
>               /* 1 - RLC_CGTT_MGCG_OVERRIDE */
> @@ -5030,8 +5028,6 @@ static void
> gfx_v9_0_update_medium_grain_clock_gating(struct amdgpu_device *adev
>                       WREG32_SOC15(GC, 0, mmCP_MEM_SLP_CNTL, data);
>               }
>       }
> -
> -     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>  }
>
>  static void gfx_v9_0_update_3d_clock_gating(struct amdgpu_device *adev, @@ -
> 5042,8 +5038,6 @@ static void gfx_v9_0_update_3d_clock_gating(struct
> amdgpu_device *adev,
>       if (!adev->gfx.num_gfx_rings)
>               return;
>
> -     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> -
>       /* Enable 3D CGCG/CGLS */
>       if (enable) {
>               /* write cmd to clear cgcg/cgls ov */ @@ -5085,8 +5079,6 @@ static
> void gfx_v9_0_update_3d_clock_gating(struct amdgpu_device *adev,
>               if (def != data)
>                       WREG32_SOC15(GC, 0, mmRLC_CGCG_CGLS_CTRL_3D,
> data);
>       }
> -
> -     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>  }
>
>  static void gfx_v9_0_update_coarse_grain_clock_gating(struct amdgpu_device
> *adev, @@ -5094,8 +5086,6 @@ static void
> gfx_v9_0_update_coarse_grain_clock_gating(struct amdgpu_device *adev  {
>       uint32_t def, data;
>
> -     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
> -
>       if (enable && (adev->cg_flags & AMD_CG_SUPPORT_GFX_CGCG)) {
>               def = data = RREG32_SOC15(GC, 0,
> mmRLC_CGTT_MGCG_OVERRIDE);
>               /* unset CGCG override */
> @@ -5137,13 +5127,12 @@ static void
> gfx_v9_0_update_coarse_grain_clock_gating(struct amdgpu_device *adev
>               if (def != data)
>                       WREG32_SOC15(GC, 0, mmRLC_CGCG_CGLS_CTRL,
> data);
>       }
> -
> -     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>  }
>
>  static int gfx_v9_0_update_gfx_clock_gating(struct amdgpu_device *adev,
>                                           bool enable)
>  {
> +     amdgpu_gfx_rlc_enter_safe_mode(adev, 0);
>       if (enable) {
>               /* CGCG/CGLS should be enabled after MGCG/MGLS
>                * ===  MGCG + MGLS ===
> @@ -5163,6 +5152,7 @@ static int gfx_v9_0_update_gfx_clock_gating(struct
> amdgpu_device *adev,
>               /* ===  MGCG + MGLS === */
>               gfx_v9_0_update_medium_grain_clock_gating(adev, enable);
>       }
> +     amdgpu_gfx_rlc_exit_safe_mode(adev, 0);
>       return 0;
>  }
>
> --
> 2.34.1



More information about the amd-gfx mailing list