[AMD Official Use Only - General]

Series is 

Reviewed-by: Hawking Zhang <[email protected]>

Regards,
Hawking
-----Original Message-----
From: amd-gfx <[email protected]> On Behalf Of Alex Deucher
Sent: Tuesday, July 12, 2022 23:14
To: [email protected]
Cc: Deucher, Alexander <[email protected]>
Subject: [PATCH 4/4] drm/amd/display: attempt to fix the logic in 
commit_planes_for_stream()

The indentation is screwed up.  I'm not sure quite how the logic should flow.  
Someone more familiar with this code should verify this.

Signed-off-by: Alex Deucher <[email protected]>
---
 drivers/gpu/drm/amd/display/dc/core/dc.c | 45 +++++++++++++-----------
 1 file changed, 24 insertions(+), 21 deletions(-)

diff --git a/drivers/gpu/drm/amd/display/dc/core/dc.c 
b/drivers/gpu/drm/amd/display/dc/core/dc.c
index 7453ec54420b..efc61a485561 100644
--- a/drivers/gpu/drm/amd/display/dc/core/dc.c
+++ b/drivers/gpu/drm/amd/display/dc/core/dc.c
@@ -3229,7 +3229,7 @@ static void commit_planes_for_stream(struct dc *dc,
                                odm_pipe->ttu_regs.min_ttu_vblank = MAX_TTU;
        }
 
-       if ((update_type != UPDATE_TYPE_FAST) && 
stream->update_flags.bits.dsc_changed)
+       if ((update_type != UPDATE_TYPE_FAST) && 
+stream->update_flags.bits.dsc_changed) {
                if (top_pipe_to_program &&
                        
top_pipe_to_program->stream_res.tg->funcs->lock_doublebuffer_enable) {
                        if (should_use_dmub_lock(stream->link)) { @@ -3247,6 
+3247,7 @@ static void commit_planes_for_stream(struct dc *dc,
                                
top_pipe_to_program->stream_res.tg->funcs->lock_doublebuffer_enable(
                                                
top_pipe_to_program->stream_res.tg);
                }
+       }
 
        if (should_lock_all_pipes && dc->hwss.interdependent_update_lock) {
                if (dc->hwss.subvp_pipe_control_lock)
@@ -3455,27 +3456,27 @@ static void commit_planes_for_stream(struct dc *dc,
 
        }
 
-               if (update_type != UPDATE_TYPE_FAST)
-                       if (dc->hwss.commit_subvp_config)
-                               dc->hwss.commit_subvp_config(dc, context);
+       if (update_type != UPDATE_TYPE_FAST)
+               if (dc->hwss.commit_subvp_config)
+                       dc->hwss.commit_subvp_config(dc, context);
 
-               if (should_lock_all_pipes && 
dc->hwss.interdependent_update_lock) {
-                       dc->hwss.interdependent_update_lock(dc, context, false);
-               } else {
-                       dc->hwss.pipe_control_lock(dc, top_pipe_to_program, 
false);
-               }
+       if (should_lock_all_pipes && dc->hwss.interdependent_update_lock) {
+               dc->hwss.interdependent_update_lock(dc, context, false);
+       } else {
+               dc->hwss.pipe_control_lock(dc, top_pipe_to_program, false);
+       }
 
-               if ((update_type != UPDATE_TYPE_FAST) && 
stream->update_flags.bits.dsc_changed)
-                       if 
(top_pipe_to_program->stream_res.tg->funcs->lock_doublebuffer_enable) {
-                               
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
-                                       top_pipe_to_program->stream_res.tg,
-                                       CRTC_STATE_VACTIVE);
-                               
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
-                                       top_pipe_to_program->stream_res.tg,
-                                       CRTC_STATE_VBLANK);
-                               
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
-                                       top_pipe_to_program->stream_res.tg,
-                                       CRTC_STATE_VACTIVE);
+       if ((update_type != UPDATE_TYPE_FAST) && 
stream->update_flags.bits.dsc_changed) {
+               if 
(top_pipe_to_program->stream_res.tg->funcs->lock_doublebuffer_enable) {
+                       
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
+                               top_pipe_to_program->stream_res.tg,
+                               CRTC_STATE_VACTIVE);
+                       
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
+                               top_pipe_to_program->stream_res.tg,
+                               CRTC_STATE_VBLANK);
+                       
top_pipe_to_program->stream_res.tg->funcs->wait_for_state(
+                               top_pipe_to_program->stream_res.tg,
+                               CRTC_STATE_VACTIVE);
 
                        if (stream && should_use_dmub_lock(stream->link)) {
                                union dmub_hw_lock_flags hw_locks = { 0 }; @@ 
-3492,8 +3493,9 @@ static void commit_planes_for_stream(struct dc *dc,
                                
top_pipe_to_program->stream_res.tg->funcs->lock_doublebuffer_disable(
                                        top_pipe_to_program->stream_res.tg);
                }
+       }
 
-       if (update_type != UPDATE_TYPE_FAST)
+       if (update_type != UPDATE_TYPE_FAST) {
                dc->hwss.post_unlock_program_front_end(dc, context);
 
                /* Since phantom pipe programming is moved to 
post_unlock_program_front_end, @@ -3506,6 +3508,7 @@ static void 
commit_planes_for_stream(struct dc *dc,
                        if (dc->hwss.subvp_pipe_control_lock)
                                dc->hwss.subvp_pipe_control_lock(dc, context, 
false, should_lock_all_pipes, top_pipe_to_program, subvp_prev_use);
                }
+       }
 
        // Fire manual trigger only when bottom plane is flipped
        for (j = 0; j < dc->res_pool->pipe_count; j++) {
--
2.35.3

Reply via email to