mirror of https://gitee.com/openkylin/linux.git
drm/amd/pp: Refine the interface exported to display
use void * as function parameter type in order for extension. Acked-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Rex Zhu <Rex.Zhu@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
d4d5eace21
commit
99c5e27d33
|
@ -192,7 +192,6 @@ struct amd_pp_simple_clock_info;
|
|||
struct amd_pp_display_configuration;
|
||||
struct amd_pp_clock_info;
|
||||
struct pp_display_clock_request;
|
||||
struct pp_wm_sets_with_clock_ranges_soc15;
|
||||
struct pp_clock_levels_with_voltage;
|
||||
struct pp_clock_levels_with_latency;
|
||||
struct amd_pp_clocks;
|
||||
|
@ -261,7 +260,7 @@ struct amd_pm_funcs {
|
|||
enum amd_pp_clock_type type,
|
||||
struct pp_clock_levels_with_voltage *clocks);
|
||||
int (*set_watermarks_for_clocks_ranges)(void *handle,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges);
|
||||
void *clock_ranges);
|
||||
int (*display_clock_voltage_request)(void *handle,
|
||||
struct pp_display_clock_request *clock);
|
||||
int (*get_display_mode_validation_clocks)(void *handle,
|
||||
|
|
|
@ -1096,17 +1096,17 @@ static int pp_get_clock_by_type_with_voltage(void *handle,
|
|||
}
|
||||
|
||||
static int pp_set_watermarks_for_clocks_ranges(void *handle,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||
void *clock_ranges)
|
||||
{
|
||||
struct pp_hwmgr *hwmgr = handle;
|
||||
int ret = 0;
|
||||
|
||||
if (!hwmgr || !hwmgr->pm_en ||!wm_with_clock_ranges)
|
||||
if (!hwmgr || !hwmgr->pm_en || !clock_ranges)
|
||||
return -EINVAL;
|
||||
|
||||
mutex_lock(&hwmgr->smu_lock);
|
||||
ret = phm_set_watermarks_for_clocks_ranges(hwmgr,
|
||||
wm_with_clock_ranges);
|
||||
clock_ranges);
|
||||
mutex_unlock(&hwmgr->smu_lock);
|
||||
|
||||
return ret;
|
||||
|
|
|
@ -435,7 +435,7 @@ int phm_get_clock_by_type_with_voltage(struct pp_hwmgr *hwmgr,
|
|||
}
|
||||
|
||||
int phm_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||
void *clock_ranges)
|
||||
{
|
||||
PHM_FUNC_CHECK(hwmgr);
|
||||
|
||||
|
@ -443,7 +443,7 @@ int phm_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
|||
return -EINVAL;
|
||||
|
||||
return hwmgr->hwmgr_func->set_watermarks_for_clocks_ranges(hwmgr,
|
||||
wm_with_clock_ranges);
|
||||
clock_ranges);
|
||||
}
|
||||
|
||||
int phm_display_clock_voltage_request(struct pp_hwmgr *hwmgr,
|
||||
|
|
|
@ -1108,9 +1108,10 @@ static int smu10_read_sensor(struct pp_hwmgr *hwmgr, int idx,
|
|||
}
|
||||
|
||||
static int smu10_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||
void *clock_ranges)
|
||||
{
|
||||
struct smu10_hwmgr *data = hwmgr->backend;
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
||||
Watermarks_t *table = &(data->water_marks_table);
|
||||
int result = 0;
|
||||
|
||||
|
|
|
@ -4194,9 +4194,10 @@ static int vega10_get_clock_by_type_with_voltage(struct pp_hwmgr *hwmgr,
|
|||
}
|
||||
|
||||
static int vega10_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||
void *clock_range)
|
||||
{
|
||||
struct vega10_hwmgr *data = hwmgr->backend;
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_range;
|
||||
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
||||
int result = 0;
|
||||
|
||||
|
|
|
@ -1781,10 +1781,11 @@ static int vega12_get_clock_by_type_with_voltage(struct pp_hwmgr *hwmgr,
|
|||
}
|
||||
|
||||
static int vega12_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||
void *clock_ranges)
|
||||
{
|
||||
struct vega12_hwmgr *data = (struct vega12_hwmgr *)(hwmgr->backend);
|
||||
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
||||
uint32_t i;
|
||||
|
||||
if (!data->registry_data.disable_water_mark &&
|
||||
|
|
|
@ -455,7 +455,7 @@ extern int phm_get_clock_by_type_with_voltage(struct pp_hwmgr *hwmgr,
|
|||
enum amd_pp_clock_type type,
|
||||
struct pp_clock_levels_with_voltage *clocks);
|
||||
extern int phm_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges);
|
||||
void *clock_ranges);
|
||||
extern int phm_display_clock_voltage_request(struct pp_hwmgr *hwmgr,
|
||||
struct pp_display_clock_request *clock);
|
||||
|
||||
|
|
|
@ -293,8 +293,7 @@ struct pp_hwmgr_func {
|
|||
int (*get_clock_by_type_with_voltage)(struct pp_hwmgr *hwmgr,
|
||||
enum amd_pp_clock_type type,
|
||||
struct pp_clock_levels_with_voltage *clocks);
|
||||
int (*set_watermarks_for_clocks_ranges)(struct pp_hwmgr *hwmgr,
|
||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges);
|
||||
int (*set_watermarks_for_clocks_ranges)(struct pp_hwmgr *hwmgr, void *clock_ranges);
|
||||
int (*display_clock_voltage_request)(struct pp_hwmgr *hwmgr,
|
||||
struct pp_display_clock_request *clock);
|
||||
int (*get_max_high_clocks)(struct pp_hwmgr *hwmgr, struct amd_pp_simple_clock_info *clocks);
|
||||
|
|
Loading…
Reference in New Issue