drm/amd/display: Unblank hubp based on plane visibility
[WHY] DCN10 uses plane visibility to determine when to unblank HUBP; there is no reason DCN20+ should not do the same. [HOW] In addition to changing the check in HWSEQ, we must change is_pipe_tree_visible so that it checks ODM pipe topologies as well as MPC. Since we're now checking both ODM and MPC topologies, the helper function names have been changed to reference "parent" and "child" instead of "top" and "bottom". Tested-by: Daniel Wheeler <daniel.wheeler@amd.com> Signed-off-by: Wesley Chalmers <Wesley.Chalmers@amd.com> Reviewed-by: Aric Cyr <Aric.Cyr@amd.com> Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
4a93aa6f96
commit
fd1c85d3ac
@ -49,20 +49,24 @@ bool is_rgb_cspace(enum dc_color_space output_color_space)
|
||||
}
|
||||
}
|
||||
|
||||
bool is_lower_pipe_tree_visible(struct pipe_ctx *pipe_ctx)
|
||||
bool is_child_pipe_tree_visible(struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
if (pipe_ctx->plane_state && pipe_ctx->plane_state->visible)
|
||||
return true;
|
||||
if (pipe_ctx->bottom_pipe && is_lower_pipe_tree_visible(pipe_ctx->bottom_pipe))
|
||||
if (pipe_ctx->bottom_pipe && is_child_pipe_tree_visible(pipe_ctx->bottom_pipe))
|
||||
return true;
|
||||
if (pipe_ctx->next_odm_pipe && is_child_pipe_tree_visible(pipe_ctx->next_odm_pipe))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
bool is_upper_pipe_tree_visible(struct pipe_ctx *pipe_ctx)
|
||||
bool is_parent_pipe_tree_visible(struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
if (pipe_ctx->plane_state && pipe_ctx->plane_state->visible)
|
||||
return true;
|
||||
if (pipe_ctx->top_pipe && is_upper_pipe_tree_visible(pipe_ctx->top_pipe))
|
||||
if (pipe_ctx->top_pipe && is_parent_pipe_tree_visible(pipe_ctx->top_pipe))
|
||||
return true;
|
||||
if (pipe_ctx->prev_odm_pipe && is_parent_pipe_tree_visible(pipe_ctx->prev_odm_pipe))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
@ -71,9 +75,13 @@ bool is_pipe_tree_visible(struct pipe_ctx *pipe_ctx)
|
||||
{
|
||||
if (pipe_ctx->plane_state && pipe_ctx->plane_state->visible)
|
||||
return true;
|
||||
if (pipe_ctx->top_pipe && is_upper_pipe_tree_visible(pipe_ctx->top_pipe))
|
||||
if (pipe_ctx->top_pipe && is_parent_pipe_tree_visible(pipe_ctx->top_pipe))
|
||||
return true;
|
||||
if (pipe_ctx->bottom_pipe && is_lower_pipe_tree_visible(pipe_ctx->bottom_pipe))
|
||||
if (pipe_ctx->bottom_pipe && is_child_pipe_tree_visible(pipe_ctx->bottom_pipe))
|
||||
return true;
|
||||
if (pipe_ctx->prev_odm_pipe && is_parent_pipe_tree_visible(pipe_ctx->prev_odm_pipe))
|
||||
return true;
|
||||
if (pipe_ctx->next_odm_pipe && is_child_pipe_tree_visible(pipe_ctx->next_odm_pipe))
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
@ -30,9 +30,9 @@
|
||||
|
||||
bool is_rgb_cspace(enum dc_color_space output_color_space);
|
||||
|
||||
bool is_lower_pipe_tree_visible(struct pipe_ctx *pipe_ctx);
|
||||
bool is_child_pipe_tree_visible(struct pipe_ctx *pipe_ctx);
|
||||
|
||||
bool is_upper_pipe_tree_visible(struct pipe_ctx *pipe_ctx);
|
||||
bool is_parent_pipe_tree_visible(struct pipe_ctx *pipe_ctx);
|
||||
|
||||
bool is_pipe_tree_visible(struct pipe_ctx *pipe_ctx);
|
||||
|
||||
|
@ -1570,7 +1570,7 @@ static void dcn20_update_dchubp_dpp(
|
||||
|
||||
|
||||
|
||||
if (pipe_ctx->update_flags.bits.enable)
|
||||
if (is_pipe_tree_visible(pipe_ctx))
|
||||
hubp->funcs->set_blank(hubp, false);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user