[PATCH 3/6] drm/amd/powerplay: fix bug that get wrong polaris evv voltage.

Zhu, Rex Rex.Zhu at amd.com
Thu Jul 7 15:17:29 UTC 2016


Hi  Alexandre,


I have applied this patch, I  will generate a new patch to fix the typos as you mentioned.


Thanks for your review.


Best Regards

Rex

________________________________
From: Alexandre Demers <alexandre.f.demers at gmail.com>
Sent: Thursday, July 7, 2016 12:49:53 PM
To: Zhu, Rex
Cc: amd-gfx at lists.freedesktop.org
Subject: Re: [PATCH 3/6] drm/amd/powerplay: fix bug that get wrong polaris evv voltage.

Small suggestion below while at it if it was not applied yet.

Alexandre Demers

On 2016-07-05 05:48, Rex Zhu wrote:
> Change-Id: Ied43d26e1b90d8d9cd6ab5ea4ab432791b48bd84
> Signed-off-by: Rex Zhu <Rex.Zhu at amd.com>
> Reviewed-by: Ken Wang <Qingqing.Wang at amd.com>
> ---
>   drivers/gpu/drm/amd/powerplay/hwmgr/polaris10_hwmgr.c | 7 ++++---
>   drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.c      | 4 ++--
>   drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.h      | 2 +-
>   3 files changed, 7 insertions(+), 6 deletions(-)
>
> diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/polaris10_hwmgr.c b/drivers/gpu/drm/amd/powerplay/hwmgr/polaris10_hwmgr.c
> index baa371f..a42610ee 100644
> --- a/drivers/gpu/drm/amd/powerplay/hwmgr/polaris10_hwmgr.c
> +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/polaris10_hwmgr.c
> @@ -2878,7 +2878,7 @@ static int polaris10_get_evv_voltages(struct pp_hwmgr *hwmgr)
>   {
>        struct polaris10_hwmgr *data = (struct polaris10_hwmgr *)(hwmgr->backend);
>        uint16_t vv_id;
> -     uint16_t vddc = 0;
> +     uint32_t vddc = 0;
>        uint16_t i, j;
>        uint32_t sclk = 0;
>        struct phm_ppt_v1_information *table_info =
> @@ -2909,8 +2909,9 @@ static int polaris10_get_evv_voltages(struct pp_hwmgr *hwmgr)
>                                                continue);
>
>
> -                     /* need to make sure vddc is less than 2v or else, it could burn the ASIC. */
> -                     PP_ASSERT_WITH_CODE((vddc < 2000 && vddc != 0),
> +                     /* need to make sure vddc is less than 2v or else, it could burn the ASIC.
> +                      * real voltage level in unit of 0.01mv */
Could you fix the volt and millivolt symbols here while you're at it?
They should be "V" and "mV" respectively. Thanks.

> +                     PP_ASSERT_WITH_CODE((vddc < 200000 && vddc != 0),
>                                        "Invalid VDDC value", result = -EINVAL;);
>
>                        /* the voltage should not be zero nor equal to leakage ID */
> diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.c b/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.c
> index 5d70e2c..a64db7b 100644
> --- a/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.c
> +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.c
> @@ -1256,7 +1256,7 @@ int atomctrl_set_ac_timing_ai(struct pp_hwmgr *hwmgr, uint32_t memory_clock,
>   }
>
>   int atomctrl_get_voltage_evv_on_sclk_ai(struct pp_hwmgr *hwmgr, uint8_t voltage_type,
> -                             uint32_t sclk, uint16_t virtual_voltage_Id, uint16_t *voltage)
> +                             uint32_t sclk, uint16_t virtual_voltage_Id, uint32_t *voltage)
>   {
>
>        int result;
> @@ -1274,7 +1274,7 @@ int atomctrl_get_voltage_evv_on_sclk_ai(struct pp_hwmgr *hwmgr, uint8_t voltage_
>        if (0 != result)
>                return result;
>
> -     *voltage = get_voltage_info_param_space.usVoltageLevel;
> +     *voltage = ((GET_EVV_VOLTAGE_INFO_OUTPUT_PARAMETER_V1_3 *)(&get_voltage_info_param_space))->ulVoltageLevel;
>
>        return result;
>   }
> diff --git a/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.h b/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.h
> index 248c5db..1e35a96 100644
> --- a/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.h
> +++ b/drivers/gpu/drm/amd/powerplay/hwmgr/ppatomctrl.h
> @@ -305,7 +305,7 @@ extern int atomctrl_get_engine_pll_dividers_ai(struct pp_hwmgr *hwmgr, uint32_t
>   extern int atomctrl_set_ac_timing_ai(struct pp_hwmgr *hwmgr, uint32_t memory_clock,
>                                                                uint8_t level);
>   extern int atomctrl_get_voltage_evv_on_sclk_ai(struct pp_hwmgr *hwmgr, uint8_t voltage_type,
> -                             uint32_t sclk, uint16_t virtual_voltage_Id, uint16_t *voltage);
> +                             uint32_t sclk, uint16_t virtual_voltage_Id, uint32_t *voltage);
>   extern int atomctrl_get_smc_sclk_range_table(struct pp_hwmgr *hwmgr, struct pp_atom_ctrl_sclk_range_table *table);
>
>   extern int atomctrl_get_avfs_information(struct pp_hwmgr *hwmgr, struct pp_atom_ctrl__avfs_parameters *param);

-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://lists.freedesktop.org/archives/amd-gfx/attachments/20160707/3b893cd8/attachment-0001.html>


More information about the amd-gfx mailing list