drm/amd/display: Fix potential integer wraparound resulting in a hang
authorAric Cyr <aric.cyr@amd.com>
Tue, 12 May 2020 15:48:48 +0000 (11:48 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Wed, 27 May 2020 22:42:10 +0000 (18:42 -0400)
[Why]
If VUPDATE_END is before VUPDATE_START the delay calculated can become
very large, causing a soft hang.

[How]
Take the absolute value of the difference between START and END.

Signed-off-by: Aric Cyr <aric.cyr@amd.com>
Reviewed-by: Nicholas Kazlauskas <Nicholas.Kazlauskas@amd.com>
Acked-by: Qingqing Zhuo <qingqing.zhuo@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hw_sequencer.c

index f59cf60fb78a9c67479ab81a5ec0f6978d8de53a..77f16921e7f0acbf965ccd81ac5c08b1761efcd5 100644 (file)
@@ -1742,6 +1742,8 @@ static void delay_cursor_until_vupdate(struct dc *dc, struct pipe_ctx *pipe_ctx)
                return;
 
        /* Stall out until the cursor update completes. */
+       if (vupdate_end < vupdate_start)
+               vupdate_end += stream->timing.v_total;
        us_vupdate = (vupdate_end - vupdate_start + 1) * us_per_line;
        udelay(us_to_vupdate + us_vupdate);
 }