[PATCH 1/2] drm/amd/powerplay: export a function to read fan rpm
Grazvydas Ignotas
notasas at gmail.com
Sun Oct 30 15:49:35 UTC 2016
Hi,
On Sun, Oct 30, 2016 at 7:10 AM, Edward O'Callaghan
<funfunctor at folklore1984.net> wrote:
> Howdy,
>
> On 10/30/2016 07:28 AM, Grazvydas Ignotas wrote:
>> Powerplay hwmgr already has an implementation, all we need to do is to call it.
>>
>> Signed-off-by: Grazvydas Ignotas <notasas at gmail.com>
>> ---
>> drivers/gpu/drm/amd/powerplay/amd_powerplay.c | 18 ++++++++++++++++++
>> drivers/gpu/drm/amd/powerplay/inc/amd_powerplay.h | 1 +
>> 2 files changed, 19 insertions(+)
>>
>> diff --git a/drivers/gpu/drm/amd/powerplay/amd_powerplay.c b/drivers/gpu/drm/amd/powerplay/amd_powerplay.c
>> index 0b1f220..1f49764 100644
>> --- a/drivers/gpu/drm/amd/powerplay/amd_powerplay.c
>> +++ b/drivers/gpu/drm/amd/powerplay/amd_powerplay.c
>> @@ -582,6 +582,23 @@ static int pp_dpm_get_fan_speed_percent(void *handle, uint32_t *speed)
>> return hwmgr->hwmgr_func->get_fan_speed_percent(hwmgr, speed);
>> }
>>
>> +static int pp_dpm_get_fan_speed_rpm(void *handle, uint32_t *rpm)
>
> why not type the handle rather than have 'void *' and a coercion (I
> didn't check the call site yet..)
Well the rest of this file is written in such a style, as well as all
the other function pointers having void * handles in the powerplay
table, so it would be an odd one standing out from the others. Same
thing for the NULL checks.
>
>> +{
>> + struct pp_hwmgr *hwmgr;
>> +
>> + if (handle == NULL)
>
> if (!handle)
>
>> + return -EINVAL;
>> +
>> + hwmgr = ((struct pp_instance *)handle)->hwmgr;
>> +
>> + PP_CHECK_HW(hwmgr);
>> +
>> + if (hwmgr->hwmgr_func->get_fan_speed_rpm == NULL)
>
> if (!hwmgr->hwmgr_func->get_fan_speed_rpm)
>
>> + return -EINVAL;
>> +
>> + return hwmgr->hwmgr_func->get_fan_speed_rpm(hwmgr, rpm);
>> +}
>> +
>> static int pp_dpm_get_temperature(void *handle)
>> {
>> struct pp_hwmgr *hwmgr;
>> @@ -852,6 +869,7 @@ const struct amd_powerplay_funcs pp_dpm_funcs = {
>> .get_fan_control_mode = pp_dpm_get_fan_control_mode,
>> .set_fan_speed_percent = pp_dpm_set_fan_speed_percent,
>> .get_fan_speed_percent = pp_dpm_get_fan_speed_percent,
>> + .get_fan_speed_rpm = pp_dpm_get_fan_speed_rpm,
>> .get_pp_num_states = pp_dpm_get_pp_num_states,
>> .get_pp_table = pp_dpm_get_pp_table,
>> .set_pp_table = pp_dpm_set_pp_table,
>> diff --git a/drivers/gpu/drm/amd/powerplay/inc/amd_powerplay.h b/drivers/gpu/drm/amd/powerplay/inc/amd_powerplay.h
>> index eb3e83d..2892b4e 100644
>> --- a/drivers/gpu/drm/amd/powerplay/inc/amd_powerplay.h
>> +++ b/drivers/gpu/drm/amd/powerplay/inc/amd_powerplay.h
>> @@ -349,6 +349,7 @@ struct amd_powerplay_funcs {
>> int (*get_fan_control_mode)(void *handle);
>> int (*set_fan_speed_percent)(void *handle, uint32_t percent);
>> int (*get_fan_speed_percent)(void *handle, uint32_t *speed);
>> + int (*get_fan_speed_rpm)(void *handle, uint32_t *rpm);
>> int (*get_pp_num_states)(void *handle, struct pp_states_info *data);
>> int (*get_pp_table)(void *handle, char **table);
>> int (*set_pp_table)(void *handle, const char *buf, size_t size);
>>
>
More information about the amd-gfx
mailing list