mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-04-29 07:02:29 -04:00
drm/amd/display: Update Interface to Check UCLK DPM
[Why] Videos using YUV420 format may result in high power being used. Disabling MPO may result in lower power usage. Update interface that can be used to check power profile of a dc_state. [How] Allow pstate switching in VBlank as last entry in strategy candidates. Add helper functions that can be used to determine power level: -get power profile after a dc_state has undergone full validation Reviewed-by: Aric Cyr <aric.cyr@amd.com> Signed-off-by: Austin Zheng <Austin.Zheng@amd.com> Signed-off-by: Aurabindo Pillai <aurabindo.pillai@amd.com> Tested-by: Daniel Wheeler <daniel.wheeler@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
committed by
Alex Deucher
parent
83e0a4a946
commit
b8d046985c
@@ -6018,8 +6018,15 @@ void dc_set_edp_power(const struct dc *dc, struct dc_link *edp_link,
|
||||
struct dc_power_profile dc_get_power_profile_for_dc_state(const struct dc_state *context)
|
||||
{
|
||||
struct dc_power_profile profile = { 0 };
|
||||
struct dc *dc = NULL;
|
||||
|
||||
profile.power_level += !context->bw_ctx.bw.dcn.clk.p_state_change_support;
|
||||
if (!context || !context->clk_mgr || !context->clk_mgr->ctx || !context->clk_mgr->ctx->dc)
|
||||
return profile;
|
||||
|
||||
dc = context->clk_mgr->ctx->dc;
|
||||
|
||||
if (dc->res_pool->funcs->get_power_profile)
|
||||
profile.power_level = dc->res_pool->funcs->get_power_profile(context);
|
||||
|
||||
return profile;
|
||||
}
|
||||
|
||||
@@ -1798,6 +1798,7 @@ bool pmo_dcn4_fams2_init_for_pstate_support(struct dml2_pmo_init_for_pstate_supp
|
||||
}
|
||||
|
||||
if (s->pmo_dcn4.num_pstate_candidates > 0) {
|
||||
s->pmo_dcn4.pstate_strategy_candidates[s->pmo_dcn4.num_pstate_candidates-1].allow_state_increase = true;
|
||||
s->pmo_dcn4.cur_pstate_candidate = -1;
|
||||
return true;
|
||||
} else {
|
||||
|
||||
@@ -215,6 +215,10 @@ struct resource_funcs {
|
||||
|
||||
void (*get_panel_config_defaults)(struct dc_panel_config *panel_config);
|
||||
void (*build_pipe_pix_clk_params)(struct pipe_ctx *pipe_ctx);
|
||||
/*
|
||||
* Get indicator of power from a context that went through full validation
|
||||
*/
|
||||
int (*get_power_profile)(const struct dc_state *context);
|
||||
};
|
||||
|
||||
struct audio_support{
|
||||
|
||||
@@ -1812,6 +1812,11 @@ static void dcn315_get_panel_config_defaults(struct dc_panel_config *panel_confi
|
||||
*panel_config = panel_config_defaults;
|
||||
}
|
||||
|
||||
static int dcn315_get_power_profile(const struct dc_state *context)
|
||||
{
|
||||
return !context->bw_ctx.bw.dcn.clk.p_state_change_support;
|
||||
}
|
||||
|
||||
static struct dc_cap_funcs cap_funcs = {
|
||||
.get_dcc_compression_cap = dcn20_get_dcc_compression_cap
|
||||
};
|
||||
@@ -1840,6 +1845,7 @@ static struct resource_funcs dcn315_res_pool_funcs = {
|
||||
.update_bw_bounding_box = dcn315_update_bw_bounding_box,
|
||||
.patch_unknown_plane_state = dcn20_patch_unknown_plane_state,
|
||||
.get_panel_config_defaults = dcn315_get_panel_config_defaults,
|
||||
.get_power_profile = dcn315_get_power_profile,
|
||||
};
|
||||
|
||||
static bool dcn315_resource_construct(
|
||||
|
||||
@@ -1688,6 +1688,22 @@ static void dcn401_build_pipe_pix_clk_params(struct pipe_ctx *pipe_ctx)
|
||||
}
|
||||
}
|
||||
|
||||
static int dcn401_get_power_profile(const struct dc_state *context)
|
||||
{
|
||||
int uclk_mhz = context->bw_ctx.bw.dcn.clk.dramclk_khz / 1000;
|
||||
int dpm_level = 0;
|
||||
|
||||
for (int i = 0; i < context->clk_mgr->bw_params->clk_table.num_entries_per_clk.num_memclk_levels; i++) {
|
||||
if (context->clk_mgr->bw_params->clk_table.entries[i].memclk_mhz == 0 ||
|
||||
uclk_mhz < context->clk_mgr->bw_params->clk_table.entries[i].memclk_mhz)
|
||||
break;
|
||||
if (uclk_mhz > context->clk_mgr->bw_params->clk_table.entries[i].memclk_mhz)
|
||||
dpm_level++;
|
||||
}
|
||||
|
||||
return dpm_level;
|
||||
}
|
||||
|
||||
static struct resource_funcs dcn401_res_pool_funcs = {
|
||||
.destroy = dcn401_destroy_resource_pool,
|
||||
.link_enc_create = dcn401_link_encoder_create,
|
||||
@@ -1714,6 +1730,7 @@ static struct resource_funcs dcn401_res_pool_funcs = {
|
||||
.prepare_mcache_programming = dcn401_prepare_mcache_programming,
|
||||
.build_pipe_pix_clk_params = dcn401_build_pipe_pix_clk_params,
|
||||
.calculate_mall_ways_from_bytes = dcn32_calculate_mall_ways_from_bytes,
|
||||
.get_power_profile = dcn401_get_power_profile,
|
||||
};
|
||||
|
||||
static uint32_t read_pipe_fuses(struct dc_context *ctx)
|
||||
|
||||
Reference in New Issue
Block a user