[PATCH] drm/amd/powerplay: ACG frequency added in PPTable

Deucher, Alexander Alexander.Deucher at amd.com
Wed Aug 23 02:48:19 UTC 2017


> -----Original Message-----
> From: Evan Quan [mailto:evan.quan at amd.com]
> Sent: Tuesday, August 22, 2017 9:59 PM
> To: amd-gfx at lists.freedesktop.org
> Cc: Deucher, Alexander; Quan, Evan
> Subject: [PATCH] drm/amd/powerplay: ACG frequency added in PPTable
> 
> Change-Id: If1df87cf4a458d59ce2545a813c4594118fa4c3d
> Signed-off-by: Evan Quan <evan.quan at amd.com>

Reviewed-by: Alex Deucher <alexander.deucher at amd.com>

> ---
>  drivers/gpu/drm/amd/powerplay/hwmgr/vega10_hwmgr.c | 11 ++++++++-
> --
>  drivers/gpu/drm/amd/powerplay/inc/smu9_driver_if.h |  6 ++++--
>  2 files changed, 12 insertions(+), 5 deletions(-)
> 
> diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/vega10_hwmgr.c
> b/drivers/gpu/drm/amd/powerplay/hwmgr/vega10_hwmgr.c
> index 0e7be87..1e16f84 100644
> --- a/drivers/gpu/drm/amd/powerplay/hwmgr/vega10_hwmgr.c
> +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/vega10_hwmgr.c
> @@ -1557,7 +1557,8 @@ static int vega10_populate_smc_link_levels(struct
> pp_hwmgr *hwmgr)
>  */
> 
>  static int vega10_populate_single_gfx_level(struct pp_hwmgr *hwmgr,
> -		uint32_t gfx_clock, PllSetting_t *current_gfxclk_level)
> +		uint32_t gfx_clock, PllSetting_t *current_gfxclk_level,
> +		uint32_t *acg_freq)
>  {
>  	struct phm_ppt_v2_information *table_info =
>  			(struct phm_ppt_v2_information *)(hwmgr-
> >pptable);
> @@ -1608,6 +1609,8 @@ static int vega10_populate_single_gfx_level(struct
> pp_hwmgr *hwmgr,
>  			cpu_to_le16(dividers.usPll_ss_slew_frac);
>  	current_gfxclk_level->Did = (uint8_t)(dividers.ulDid);
> 
> +	*acg_freq = gfx_clock / 100; /* 100 Khz to Mhz conversion */
> +
>  	return 0;
>  }
> 
> @@ -1688,7 +1691,8 @@ static int
> vega10_populate_all_graphic_levels(struct pp_hwmgr *hwmgr)
>  	for (i = 0; i < dpm_table->count; i++) {
>  		result = vega10_populate_single_gfx_level(hwmgr,
>  				dpm_table->dpm_levels[i].value,
> -				&(pp_table->GfxclkLevel[i]));
> +				&(pp_table->GfxclkLevel[i]),
> +				&(pp_table->AcgFreqTable[i]));
>  		if (result)
>  			return result;
>  	}
> @@ -1697,7 +1701,8 @@ static int
> vega10_populate_all_graphic_levels(struct pp_hwmgr *hwmgr)
>  	while (i < NUM_GFXCLK_DPM_LEVELS) {
>  		result = vega10_populate_single_gfx_level(hwmgr,
>  				dpm_table->dpm_levels[j].value,
> -				&(pp_table->GfxclkLevel[i]));
> +				&(pp_table->GfxclkLevel[i]),
> +				&(pp_table->AcgFreqTable[i]));
>  		if (result)
>  			return result;
>  		i++;
> diff --git a/drivers/gpu/drm/amd/powerplay/inc/smu9_driver_if.h
> b/drivers/gpu/drm/amd/powerplay/inc/smu9_driver_if.h
> index f6d6c61..2818c98 100644
> --- a/drivers/gpu/drm/amd/powerplay/inc/smu9_driver_if.h
> +++ b/drivers/gpu/drm/amd/powerplay/inc/smu9_driver_if.h
> @@ -315,10 +315,12 @@ typedef struct {
>    uint8_t      AcgEnable[NUM_GFXCLK_DPM_LEVELS];
>    GbVdroopTable_t AcgBtcGbVdroopTable;
>    QuadraticInt_t  AcgAvfsGb;
> -  uint32_t     Reserved[4];
> +
> +  /* ACG Frequency Table, in Mhz */
> +  uint32_t     AcgFreqTable[NUM_GFXCLK_DPM_LEVELS];
> 
>    /* Padding - ignore */
> -  uint32_t     MmHubPadding[7]; /* SMU internal use */
> +  uint32_t     MmHubPadding[3]; /* SMU internal use */
> 
>  } PPTable_t;
> 
> --
> 2.7.4



More information about the amd-gfx mailing list