drm/amd/display: Intermittent DCN2 pipe hang on mode change
authorAric Cyr <aric.cyr@amd.com>
Mon, 22 Apr 2019 21:45:11 +0000 (17:45 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Sat, 22 Jun 2019 14:34:11 +0000 (09:34 -0500)
[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>
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.h

index f9eae47..c7ae538 100644 (file)
@@ -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();
 }
index 37699df..b7892e8 100644 (file)
@@ -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__ */