mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
drm/amd/pp: Remove the same struct define in powerplay
delete the same struct define in powerplay, share the struct with display. 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
70b63170c3
commit
20582319bc
@ -23,6 +23,8 @@
|
|||||||
#ifndef _DM_PP_INTERFACE_
|
#ifndef _DM_PP_INTERFACE_
|
||||||
#define _DM_PP_INTERFACE_
|
#define _DM_PP_INTERFACE_
|
||||||
|
|
||||||
|
#include "dm_services_types.h"
|
||||||
|
|
||||||
#define PP_MAX_CLOCK_LEVELS 16
|
#define PP_MAX_CLOCK_LEVELS 16
|
||||||
|
|
||||||
enum amd_pp_display_config_type{
|
enum amd_pp_display_config_type{
|
||||||
@ -189,39 +191,4 @@ struct pp_display_clock_request {
|
|||||||
uint32_t clock_freq_in_khz;
|
uint32_t clock_freq_in_khz;
|
||||||
};
|
};
|
||||||
|
|
||||||
#define PP_MAX_WM_SETS 4
|
|
||||||
|
|
||||||
enum pp_wm_set_id {
|
|
||||||
DC_WM_SET_A = 0,
|
|
||||||
DC_WM_SET_B,
|
|
||||||
DC_WM_SET_C,
|
|
||||||
DC_WM_SET_D,
|
|
||||||
DC_WM_SET_INVALID = 0xffff,
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pp_wm_set_with_dmif_clock_range_soc15 {
|
|
||||||
enum pp_wm_set_id wm_set_id;
|
|
||||||
uint32_t wm_min_dcefclk_in_khz;
|
|
||||||
uint32_t wm_max_dcefclk_in_khz;
|
|
||||||
uint32_t wm_min_memclk_in_khz;
|
|
||||||
uint32_t wm_max_memclk_in_khz;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pp_wm_set_with_mcif_clock_range_soc15 {
|
|
||||||
enum pp_wm_set_id wm_set_id;
|
|
||||||
uint32_t wm_min_socclk_in_khz;
|
|
||||||
uint32_t wm_max_socclk_in_khz;
|
|
||||||
uint32_t wm_min_memclk_in_khz;
|
|
||||||
uint32_t wm_max_memclk_in_khz;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 {
|
|
||||||
uint32_t num_wm_sets_dmif;
|
|
||||||
uint32_t num_wm_sets_mcif;
|
|
||||||
struct pp_wm_set_with_dmif_clock_range_soc15
|
|
||||||
wm_sets_dmif[PP_MAX_WM_SETS];
|
|
||||||
struct pp_wm_set_with_mcif_clock_range_soc15
|
|
||||||
wm_sets_mcif[PP_MAX_WM_SETS];
|
|
||||||
};
|
|
||||||
|
|
||||||
#endif /* _DM_PP_INTERFACE_ */
|
#endif /* _DM_PP_INTERFACE_ */
|
||||||
|
@ -1111,7 +1111,7 @@ static int smu10_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
|||||||
void *clock_ranges)
|
void *clock_ranges)
|
||||||
{
|
{
|
||||||
struct smu10_hwmgr *data = hwmgr->backend;
|
struct smu10_hwmgr *data = hwmgr->backend;
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
struct dm_pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
||||||
Watermarks_t *table = &(data->water_marks_table);
|
Watermarks_t *table = &(data->water_marks_table);
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
|
@ -652,7 +652,7 @@ int smu_get_voltage_dependency_table_ppt_v1(
|
|||||||
}
|
}
|
||||||
|
|
||||||
int smu_set_watermarks_for_clocks_ranges(void *wt_table,
|
int smu_set_watermarks_for_clocks_ranges(void *wt_table,
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
struct dm_pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges)
|
||||||
{
|
{
|
||||||
uint32_t i;
|
uint32_t i;
|
||||||
struct watermarks *table = wt_table;
|
struct watermarks *table = wt_table;
|
||||||
@ -660,49 +660,49 @@ int smu_set_watermarks_for_clocks_ranges(void *wt_table,
|
|||||||
if (!table || !wm_with_clock_ranges)
|
if (!table || !wm_with_clock_ranges)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
if (wm_with_clock_ranges->num_wm_sets_dmif > 4 || wm_with_clock_ranges->num_wm_sets_mcif > 4)
|
if (wm_with_clock_ranges->num_wm_dmif_sets > 4 || wm_with_clock_ranges->num_wm_mcif_sets > 4)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
for (i = 0; i < wm_with_clock_ranges->num_wm_sets_dmif; i++) {
|
for (i = 0; i < wm_with_clock_ranges->num_wm_dmif_sets; i++) {
|
||||||
table->WatermarkRow[1][i].MinClock =
|
table->WatermarkRow[1][i].MinClock =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_dmif[i].wm_min_dcefclk_in_khz) /
|
(wm_with_clock_ranges->wm_dmif_clocks_ranges[i].wm_min_dcfclk_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[1][i].MaxClock =
|
table->WatermarkRow[1][i].MaxClock =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_dmif[i].wm_max_dcefclk_in_khz) /
|
(wm_with_clock_ranges->wm_dmif_clocks_ranges[i].wm_max_dcfclk_clk_in_khz) /
|
||||||
100);
|
100);
|
||||||
table->WatermarkRow[1][i].MinUclk =
|
table->WatermarkRow[1][i].MinUclk =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_dmif[i].wm_min_memclk_in_khz) /
|
(wm_with_clock_ranges->wm_dmif_clocks_ranges[i].wm_min_mem_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[1][i].MaxUclk =
|
table->WatermarkRow[1][i].MaxUclk =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_dmif[i].wm_max_memclk_in_khz) /
|
(wm_with_clock_ranges->wm_dmif_clocks_ranges[i].wm_max_mem_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[1][i].WmSetting = (uint8_t)
|
table->WatermarkRow[1][i].WmSetting = (uint8_t)
|
||||||
wm_with_clock_ranges->wm_sets_dmif[i].wm_set_id;
|
wm_with_clock_ranges->wm_dmif_clocks_ranges[i].wm_set_id;
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < wm_with_clock_ranges->num_wm_sets_mcif; i++) {
|
for (i = 0; i < wm_with_clock_ranges->num_wm_mcif_sets; i++) {
|
||||||
table->WatermarkRow[0][i].MinClock =
|
table->WatermarkRow[0][i].MinClock =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_mcif[i].wm_min_socclk_in_khz) /
|
(wm_with_clock_ranges->wm_mcif_clocks_ranges[i].wm_min_socclk_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[0][i].MaxClock =
|
table->WatermarkRow[0][i].MaxClock =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_mcif[i].wm_max_socclk_in_khz) /
|
(wm_with_clock_ranges->wm_mcif_clocks_ranges[i].wm_max_socclk_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[0][i].MinUclk =
|
table->WatermarkRow[0][i].MinUclk =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_mcif[i].wm_min_memclk_in_khz) /
|
(wm_with_clock_ranges->wm_mcif_clocks_ranges[i].wm_min_mem_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[0][i].MaxUclk =
|
table->WatermarkRow[0][i].MaxUclk =
|
||||||
cpu_to_le16((uint16_t)
|
cpu_to_le16((uint16_t)
|
||||||
(wm_with_clock_ranges->wm_sets_mcif[i].wm_max_memclk_in_khz) /
|
(wm_with_clock_ranges->wm_mcif_clocks_ranges[i].wm_max_mem_clk_in_khz) /
|
||||||
100);
|
1000);
|
||||||
table->WatermarkRow[0][i].WmSetting = (uint8_t)
|
table->WatermarkRow[0][i].WmSetting = (uint8_t)
|
||||||
wm_with_clock_ranges->wm_sets_mcif[i].wm_set_id;
|
wm_with_clock_ranges->wm_mcif_clocks_ranges[i].wm_set_id;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -107,7 +107,7 @@ int smu_get_voltage_dependency_table_ppt_v1(
|
|||||||
struct phm_ppt_v1_clock_voltage_dependency_table *dep_table);
|
struct phm_ppt_v1_clock_voltage_dependency_table *dep_table);
|
||||||
|
|
||||||
int smu_set_watermarks_for_clocks_ranges(void *wt_table,
|
int smu_set_watermarks_for_clocks_ranges(void *wt_table,
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges);
|
struct dm_pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges);
|
||||||
|
|
||||||
#define PHM_FIELD_SHIFT(reg, field) reg##__##field##__SHIFT
|
#define PHM_FIELD_SHIFT(reg, field) reg##__##field##__SHIFT
|
||||||
#define PHM_FIELD_MASK(reg, field) reg##__##field##_MASK
|
#define PHM_FIELD_MASK(reg, field) reg##__##field##_MASK
|
||||||
|
@ -4197,7 +4197,7 @@ static int vega10_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
|||||||
void *clock_range)
|
void *clock_range)
|
||||||
{
|
{
|
||||||
struct vega10_hwmgr *data = hwmgr->backend;
|
struct vega10_hwmgr *data = hwmgr->backend;
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_range;
|
struct dm_pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_range;
|
||||||
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
||||||
int result = 0;
|
int result = 0;
|
||||||
|
|
||||||
|
@ -1785,7 +1785,7 @@ static int vega12_set_watermarks_for_clocks_ranges(struct pp_hwmgr *hwmgr,
|
|||||||
{
|
{
|
||||||
struct vega12_hwmgr *data = (struct vega12_hwmgr *)(hwmgr->backend);
|
struct vega12_hwmgr *data = (struct vega12_hwmgr *)(hwmgr->backend);
|
||||||
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
Watermarks_t *table = &(data->smc_state_table.water_marks_table);
|
||||||
struct pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
struct dm_pp_wm_sets_with_clock_ranges_soc15 *wm_with_clock_ranges = clock_ranges;
|
||||||
|
|
||||||
if (!data->registry_data.disable_water_mark &&
|
if (!data->registry_data.disable_water_mark &&
|
||||||
data->smu_features[GNLD_DPM_DCEFCLK].supported &&
|
data->smu_features[GNLD_DPM_DCEFCLK].supported &&
|
||||||
|
Loading…
Reference in New Issue
Block a user