mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-22 13:54:57 +08:00
drm/amd/display: Intermittent DCN2 pipe hang on mode change
[Why] GSL is being used to synchronize pipes when vsync is off but on transition to vsync on during a mode change GSL is not being reset correctly. [How] Disable GSL on any plane that is disabled. Signed-off-by: Aric Cyr <aric.cyr@amd.com> Reviewed-by: Krunoslav Kovac <Krunoslav.Kovac@amd.com> Acked-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com> Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
This commit is contained in:
parent
f446489adc
commit
6bd8d7d3f7
@ -467,6 +467,14 @@ static void dcn20_plane_atomic_disable(struct dc *dc, struct pipe_ctx *pipe_ctx)
|
||||
|
||||
dc->hwss.wait_for_mpcc_disconnect(dc, dc->res_pool, pipe_ctx);
|
||||
|
||||
/* In flip immediate with pipe splitting case GSL is used for
|
||||
* synchronization so we must disable it when the plane is disabled.
|
||||
*/
|
||||
if (pipe_ctx->stream_res.gsl_group != 0)
|
||||
dcn20_setup_gsl_group_as_lock(dc, pipe_ctx, false);
|
||||
|
||||
dc->hwss.set_flip_control_gsl(pipe_ctx, false);
|
||||
|
||||
hubp->funcs->hubp_clk_cntl(hubp, false);
|
||||
|
||||
dpp->funcs->dpp_dppclk_control(dpp, false, false);
|
||||
@ -1900,14 +1908,14 @@ static int find_free_gsl_group(const struct dc *dc)
|
||||
void dcn20_setup_gsl_group_as_lock(
|
||||
const struct dc *dc,
|
||||
struct pipe_ctx *pipe_ctx,
|
||||
bool flip_immediate)
|
||||
bool enable)
|
||||
{
|
||||
struct gsl_params gsl;
|
||||
int group_idx;
|
||||
|
||||
memset(&gsl, 0, sizeof(struct gsl_params));
|
||||
|
||||
if (flip_immediate) {
|
||||
if (enable) {
|
||||
/* return if group already assigned since GSL was set up
|
||||
* for vsync flip, we would unassign so it can't be "left over"
|
||||
*/
|
||||
@ -1973,8 +1981,7 @@ void dcn20_setup_gsl_group_as_lock(
|
||||
&gsl);
|
||||
|
||||
pipe_ctx->stream_res.tg->funcs->set_gsl_source_select(
|
||||
pipe_ctx->stream_res.tg, group_idx,
|
||||
flip_immediate ? 4 : 0);
|
||||
pipe_ctx->stream_res.tg, group_idx, enable ? 4 : 0);
|
||||
} else
|
||||
BREAK_TO_DEBUGGER();
|
||||
}
|
||||
|
@ -86,6 +86,6 @@ void dcn20_setup_vupdate_interrupt(struct pipe_ctx *pipe_ctx);
|
||||
|
||||
void dcn20_setup_gsl_group_as_lock(const struct dc *dc,
|
||||
struct pipe_ctx *pipe_ctx,
|
||||
bool flip_immediate);
|
||||
bool enable);
|
||||
|
||||
#endif /* __DC_HWSS_DCN20_H__ */
|
||||
|
Loading…
Reference in New Issue
Block a user