Commit 498563cf authored by JinZe.Xu's avatar JinZe.Xu Committed by Alex Deucher

drm/amd/display: Detect plane change when detect pipe change.

[Why]
If plane has changed, dcn20_detect_pipe_changes doesn't update dc_plane_state->update_flags, and the following dcn20_program_pipe can't reprogram hubp correctly.

[How]
Add a new flags bit "plane_changed" in pipe_ctx->update_flags.If old plane isn’t identical to new plane, this bit will be set and guide “dcn20_program_pipe” to programing HUBP correctly.
Signed-off-by: default avatarJinZe.Xu <JinZe.Xu@amd.com>
Acked-by: default avatarAurabindo Pillai <aurabindo.pillai@amd.com>
Signed-off-by: default avatarAlex Deucher <alexander.deucher@amd.com>
parent a861736d
...@@ -1251,6 +1251,11 @@ static void dcn20_detect_pipe_changes(struct pipe_ctx *old_pipe, struct pipe_ctx ...@@ -1251,6 +1251,11 @@ static void dcn20_detect_pipe_changes(struct pipe_ctx *old_pipe, struct pipe_ctx
return; return;
} }
/* Detect plane change */
if (old_pipe->plane_state != new_pipe->plane_state) {
new_pipe->update_flags.bits.plane_changed = true;
}
/* Detect top pipe only changes */ /* Detect top pipe only changes */
if (!new_pipe->top_pipe && !new_pipe->prev_odm_pipe) { if (!new_pipe->top_pipe && !new_pipe->prev_odm_pipe) {
/* Detect odm changes */ /* Detect odm changes */
...@@ -1392,6 +1397,7 @@ static void dcn20_update_dchubp_dpp( ...@@ -1392,6 +1397,7 @@ static void dcn20_update_dchubp_dpp(
&pipe_ctx->ttu_regs); &pipe_ctx->ttu_regs);
if (pipe_ctx->update_flags.bits.enable || if (pipe_ctx->update_flags.bits.enable ||
pipe_ctx->update_flags.bits.plane_changed ||
plane_state->update_flags.bits.bpp_change || plane_state->update_flags.bits.bpp_change ||
plane_state->update_flags.bits.input_csc_change || plane_state->update_flags.bits.input_csc_change ||
plane_state->update_flags.bits.color_space_change || plane_state->update_flags.bits.color_space_change ||
...@@ -1414,6 +1420,7 @@ static void dcn20_update_dchubp_dpp( ...@@ -1414,6 +1420,7 @@ static void dcn20_update_dchubp_dpp(
} }
if (pipe_ctx->update_flags.bits.mpcc if (pipe_ctx->update_flags.bits.mpcc
|| pipe_ctx->update_flags.bits.plane_changed
|| plane_state->update_flags.bits.global_alpha_change || plane_state->update_flags.bits.global_alpha_change
|| plane_state->update_flags.bits.per_pixel_alpha_change) { || plane_state->update_flags.bits.per_pixel_alpha_change) {
// MPCC inst is equal to pipe index in practice // MPCC inst is equal to pipe index in practice
...@@ -1515,6 +1522,7 @@ static void dcn20_update_dchubp_dpp( ...@@ -1515,6 +1522,7 @@ static void dcn20_update_dchubp_dpp(
} }
if (pipe_ctx->update_flags.bits.enable || if (pipe_ctx->update_flags.bits.enable ||
pipe_ctx->update_flags.bits.plane_changed ||
pipe_ctx->update_flags.bits.opp_changed || pipe_ctx->update_flags.bits.opp_changed ||
plane_state->update_flags.bits.pixel_format_change || plane_state->update_flags.bits.pixel_format_change ||
plane_state->update_flags.bits.horizontal_mirror_change || plane_state->update_flags.bits.horizontal_mirror_change ||
...@@ -1539,7 +1547,9 @@ static void dcn20_update_dchubp_dpp( ...@@ -1539,7 +1547,9 @@ static void dcn20_update_dchubp_dpp(
hubp->power_gated = false; hubp->power_gated = false;
} }
if (pipe_ctx->update_flags.bits.enable || plane_state->update_flags.bits.addr_update) if (pipe_ctx->update_flags.bits.enable ||
pipe_ctx->update_flags.bits.plane_changed ||
plane_state->update_flags.bits.addr_update)
hws->funcs.update_plane_addr(dc, pipe_ctx); hws->funcs.update_plane_addr(dc, pipe_ctx);
......
...@@ -300,6 +300,7 @@ union pipe_update_flags { ...@@ -300,6 +300,7 @@ union pipe_update_flags {
uint32_t gamut_remap : 1; uint32_t gamut_remap : 1;
uint32_t scaler : 1; uint32_t scaler : 1;
uint32_t viewport : 1; uint32_t viewport : 1;
uint32_t plane_changed : 1;
} bits; } bits;
uint32_t raw; uint32_t raw;
}; };
......
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