Commit 10bce710 authored by Joseph Gravenor's avatar Joseph Gravenor Committed by Alex Deucher

drm/amd/display: have two different sr and pstate latency tables for renoir

[Why]
new sr and pstate latencies are optimized for the case when we are not
using lpddr4 memory

[How]
have two different wm tables, one for the lpddr case and one for
non lpddr case
Signed-off-by: default avatarJoseph Gravenor <joseph.gravenor@amd.com>
Reviewed-by: default avatarEric Yang <eric.yang2@amd.com>
Acked-by: default avatarLeo Li <sunpeng.li@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent a51d9f8f
...@@ -518,44 +518,83 @@ struct clk_bw_params rn_bw_params = { ...@@ -518,44 +518,83 @@ struct clk_bw_params rn_bw_params = {
.num_entries = 4, .num_entries = 4,
}, },
.wm_table = { };
.entries = {
{ struct wm_table ddr4_wm_table = {
.wm_inst = WM_A, .entries = {
.wm_type = WM_TYPE_PSTATE_CHG, {
.pstate_latency_us = 11.72, .wm_inst = WM_A,
.sr_exit_time_us = 6.09, .wm_type = WM_TYPE_PSTATE_CHG,
.sr_enter_plus_exit_time_us = 7.14, .pstate_latency_us = 11.72,
.valid = true, .sr_exit_time_us = 6.09,
}, .sr_enter_plus_exit_time_us = 7.14,
{ .valid = true,
.wm_inst = WM_B, },
.wm_type = WM_TYPE_PSTATE_CHG, {
.pstate_latency_us = 11.72, .wm_inst = WM_B,
.sr_exit_time_us = 10.12, .wm_type = WM_TYPE_PSTATE_CHG,
.sr_enter_plus_exit_time_us = 11.48, .pstate_latency_us = 11.72,
.valid = true, .sr_exit_time_us = 10.12,
}, .sr_enter_plus_exit_time_us = 11.48,
{ .valid = true,
.wm_inst = WM_C, },
.wm_type = WM_TYPE_PSTATE_CHG, {
.pstate_latency_us = 11.72, .wm_inst = WM_C,
.sr_exit_time_us = 10.12, .wm_type = WM_TYPE_PSTATE_CHG,
.sr_enter_plus_exit_time_us = 11.48, .pstate_latency_us = 11.72,
.valid = true, .sr_exit_time_us = 10.12,
}, .sr_enter_plus_exit_time_us = 11.48,
{ .valid = true,
.wm_inst = WM_D, },
.wm_type = WM_TYPE_PSTATE_CHG, {
.pstate_latency_us = 11.72, .wm_inst = WM_D,
.sr_exit_time_us = 10.12, .wm_type = WM_TYPE_PSTATE_CHG,
.sr_enter_plus_exit_time_us = 11.48, .pstate_latency_us = 11.72,
.valid = true, .sr_exit_time_us = 10.12,
}, .sr_enter_plus_exit_time_us = 11.48,
.valid = true,
}, },
} }
}; };
struct wm_table lpddr4_wm_table = {
.entries = {
{
.wm_inst = WM_A,
.wm_type = WM_TYPE_PSTATE_CHG,
.pstate_latency_us = 23.84,
.sr_exit_time_us = 12.5,
.sr_enter_plus_exit_time_us = 17.0,
.valid = true,
},
{
.wm_inst = WM_B,
.wm_type = WM_TYPE_PSTATE_CHG,
.pstate_latency_us = 23.84,
.sr_exit_time_us = 12.5,
.sr_enter_plus_exit_time_us = 17.0,
.valid = true,
},
{
.wm_inst = WM_C,
.wm_type = WM_TYPE_PSTATE_CHG,
.pstate_latency_us = 23.84,
.sr_exit_time_us = 12.5,
.sr_enter_plus_exit_time_us = 17.0,
.valid = true,
},
{
.wm_inst = WM_D,
.wm_type = WM_TYPE_PSTATE_CHG,
.pstate_latency_us = 23.84,
.sr_exit_time_us = 12.5,
.sr_enter_plus_exit_time_us = 17.0,
.valid = true,
},
}
};
static unsigned int find_dcfclk_for_voltage(struct dpm_clocks *clock_table, unsigned int voltage) static unsigned int find_dcfclk_for_voltage(struct dpm_clocks *clock_table, unsigned int voltage)
{ {
int i; int i;
...@@ -677,10 +716,17 @@ void rn_clk_mgr_construct( ...@@ -677,10 +716,17 @@ void rn_clk_mgr_construct(
ASSERT(clk_mgr->base.dprefclk_khz == 600000); ASSERT(clk_mgr->base.dprefclk_khz == 600000);
clk_mgr->base.dprefclk_khz = 600000; clk_mgr->base.dprefclk_khz = 600000;
} }
if (ctx->dc_bios->integrated_info->memory_type == LpDdr4MemType) {
rn_bw_params.wm_table = lpddr4_wm_table;
} else {
rn_bw_params.wm_table = ddr4_wm_table;
}
} }
dce_clock_read_ss_info(clk_mgr); dce_clock_read_ss_info(clk_mgr);
clk_mgr->base.bw_params = &rn_bw_params; clk_mgr->base.bw_params = &rn_bw_params;
if (pp_smu && pp_smu->rn_funcs.get_dpm_clock_table) { if (pp_smu && pp_smu->rn_funcs.get_dpm_clock_table) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment