提交 aa5a5777 编写于 作者: S SivapiriyanKumarasamy 提交者: Alex Deucher

drm/amd/display: Vari-bright looks disabled near end of MM14

Avoid hanging DMCU by setting abm level only when OTG unblanked
Signed-off-by: NSivapiriyanKumarasamy <sivapiriyan.kumarasamy@amd.com>
Reviewed-by: NTony Cheng <Tony.Cheng@amd.com>
Acked-by: NHarry Wentland <harry.wentland@amd.com>
Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
上级 d5400aab
...@@ -42,6 +42,7 @@ ...@@ -42,6 +42,7 @@
#include "dmcu.h" #include "dmcu.h"
#include "dpp.h" #include "dpp.h"
#include "timing_generator.h" #include "timing_generator.h"
#include "abm.h"
#include "virtual/virtual_link_encoder.h" #include "virtual/virtual_link_encoder.h"
#include "link_hwss.h" #include "link_hwss.h"
...@@ -1361,6 +1362,13 @@ static void commit_planes_for_stream(struct dc *dc, ...@@ -1361,6 +1362,13 @@ static void commit_planes_for_stream(struct dc *dc,
dc->hwss.apply_ctx_for_surface( dc->hwss.apply_ctx_for_surface(
dc, pipe_ctx->stream, stream_status->plane_count, context); dc, pipe_ctx->stream, stream_status->plane_count, context);
if (stream_update->abm_setting.stream_update) {
if (dc->res_pool->abm)
dc->res_pool->abm->funcs->set_abm_level(
dc->res_pool->abm, stream->abm_settings.abm_level);
stream->abm_settings.stream_update = 0;
}
} }
} }
......
...@@ -60,6 +60,11 @@ struct dc_versions { ...@@ -60,6 +60,11 @@ struct dc_versions {
struct dmcu_version dmcu_version; struct dmcu_version dmcu_version;
}; };
struct abm_setting {
bool stream_update;
unsigned int abm_level;
};
struct dc_caps { struct dc_caps {
uint32_t max_streams; uint32_t max_streams;
uint32_t max_links; uint32_t max_links;
......
...@@ -74,6 +74,9 @@ struct dc_stream_state { ...@@ -74,6 +74,9 @@ struct dc_stream_state {
unsigned char psr_version; unsigned char psr_version;
/* TODO: CEA VIC */ /* TODO: CEA VIC */
/* DMCU info */
struct abm_setting abm_settings;
/* from core_stream struct */ /* from core_stream struct */
struct dc_context *ctx; struct dc_context *ctx;
...@@ -106,6 +109,7 @@ struct dc_stream_update { ...@@ -106,6 +109,7 @@ struct dc_stream_update {
struct dc_transfer_func *out_transfer_func; struct dc_transfer_func *out_transfer_func;
struct dc_hdr_static_metadata *hdr_static_metadata; struct dc_hdr_static_metadata *hdr_static_metadata;
enum color_transfer_func color_output_tf; enum color_transfer_func color_output_tf;
struct abm_setting abm_setting;
}; };
bool dc_is_stream_unchanged( bool dc_is_stream_unchanged(
......
...@@ -1780,14 +1780,33 @@ static void update_dchubp_dpp( ...@@ -1780,14 +1780,33 @@ static void update_dchubp_dpp(
hubp->funcs->set_blank(hubp, false); hubp->funcs->set_blank(hubp, false);
} }
static void dcn10_otg_blank(
struct stream_resource stream_res,
struct abm *abm,
struct dc_stream_state *stream,
bool blank)
{
if (!blank) {
if (stream_res.tg->funcs->set_blank)
stream_res.tg->funcs->set_blank(stream_res.tg, blank);
if (abm)
abm->funcs->set_abm_level(abm, stream->abm_settings.abm_level);
} else if (blank) {
if (abm)
abm->funcs->set_abm_immediate_disable(abm);
if (stream_res.tg->funcs->set_blank)
stream_res.tg->funcs->set_blank(stream_res.tg, blank);
}
}
static void program_all_pipe_in_tree( static void program_all_pipe_in_tree(
struct dc *dc, struct dc *dc,
struct pipe_ctx *pipe_ctx, struct pipe_ctx *pipe_ctx,
struct dc_state *context) struct dc_state *context)
{ {
if (pipe_ctx->top_pipe == NULL) { if (pipe_ctx->top_pipe == NULL) {
bool blank = !is_pipe_tree_visible(pipe_ctx);
pipe_ctx->stream_res.tg->dlg_otg_param.vready_offset = pipe_ctx->pipe_dlg_param.vready_offset; pipe_ctx->stream_res.tg->dlg_otg_param.vready_offset = pipe_ctx->pipe_dlg_param.vready_offset;
pipe_ctx->stream_res.tg->dlg_otg_param.vstartup_start = pipe_ctx->pipe_dlg_param.vstartup_start; pipe_ctx->stream_res.tg->dlg_otg_param.vstartup_start = pipe_ctx->pipe_dlg_param.vstartup_start;
...@@ -1798,10 +1817,8 @@ static void program_all_pipe_in_tree( ...@@ -1798,10 +1817,8 @@ static void program_all_pipe_in_tree(
pipe_ctx->stream_res.tg->funcs->program_global_sync( pipe_ctx->stream_res.tg->funcs->program_global_sync(
pipe_ctx->stream_res.tg); pipe_ctx->stream_res.tg);
if (pipe_ctx->stream_res.tg->funcs->set_blank) dcn10_otg_blank(pipe_ctx->stream_res, dc->res_pool->abm,
pipe_ctx->stream_res.tg->funcs->set_blank( pipe_ctx->stream, blank);
pipe_ctx->stream_res.tg,
!is_pipe_tree_visible(pipe_ctx));
} }
if (pipe_ctx->plane_state != NULL) { if (pipe_ctx->plane_state != NULL) {
...@@ -1908,29 +1925,23 @@ static void dcn10_apply_ctx_for_surface( ...@@ -1908,29 +1925,23 @@ static void dcn10_apply_ctx_for_surface(
{ {
int i; int i;
struct timing_generator *tg; struct timing_generator *tg;
struct output_pixel_processor *opp;
bool removed_pipe[4] = { false }; bool removed_pipe[4] = { false };
unsigned int ref_clk_mhz = dc->res_pool->ref_clock_inKhz/1000; unsigned int ref_clk_mhz = dc->res_pool->ref_clock_inKhz/1000;
bool program_water_mark = false; bool program_water_mark = false;
struct dc_context *ctx = dc->ctx; struct dc_context *ctx = dc->ctx;
struct pipe_ctx *top_pipe_to_program = struct pipe_ctx *top_pipe_to_program =
find_top_pipe_for_stream(dc, context, stream); find_top_pipe_for_stream(dc, context, stream);
if (!top_pipe_to_program) if (!top_pipe_to_program)
return; return;
opp = top_pipe_to_program->stream_res.opp;
tg = top_pipe_to_program->stream_res.tg; tg = top_pipe_to_program->stream_res.tg;
dcn10_pipe_control_lock(dc, top_pipe_to_program, true); dcn10_pipe_control_lock(dc, top_pipe_to_program, true);
if (num_planes == 0) { if (num_planes == 0) {
/* OTG blank before remove all front end */ /* OTG blank before remove all front end */
if (tg->funcs->set_blank) dcn10_otg_blank(top_pipe_to_program->stream_res, dc->res_pool->abm, top_pipe_to_program->stream, true);
tg->funcs->set_blank(tg, true);
} }
/* Disconnect unused mpcc */ /* Disconnect unused mpcc */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册