From: Ausef Yousof <[email protected]>

[why&how]
primary planes for external displays getting incorrect clip
values, detect such a scenario and pass correct parameters

Reviewed-by: Ovidiu (Ovi) Bunea <[email protected]>
Signed-off-by: Ausef Yousof <[email protected]>
Signed-off-by: Matthew Stewart <[email protected]>
---
 drivers/gpu/drm/amd/display/dc/dc_hw_types.h            | 6 ++++++
 drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_hwseq.c | 6 +++++-
 2 files changed, 11 insertions(+), 1 deletion(-)

diff --git a/drivers/gpu/drm/amd/display/dc/dc_hw_types.h 
b/drivers/gpu/drm/amd/display/dc/dc_hw_types.h
index 667852517246..cfa569a7bff1 100644
--- a/drivers/gpu/drm/amd/display/dc/dc_hw_types.h
+++ b/drivers/gpu/drm/amd/display/dc/dc_hw_types.h
@@ -491,6 +491,12 @@ struct dc_cursor_position {
         * for each plane.
         */
        bool translate_by_source;
+
+       /**
+        * @use_viewport_for_clip: Use viewport position for clip_x calculation
+        * instead of clip_rect. Required to protect against clip being 
overwritten
+        */
+       bool use_viewport_for_clip;
 };
 
 struct dc_cursor_mi_param {
diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_hwseq.c 
b/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_hwseq.c
index fa62e40a9858..8a23763ca98e 100644
--- a/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_hwseq.c
+++ b/drivers/gpu/drm/amd/display/dc/hwss/dcn10/dcn10_hwseq.c
@@ -3666,7 +3666,11 @@ void dcn10_set_cursor_position(struct pipe_ctx *pipe_ctx)
        int y_plane = pipe_ctx->plane_state->dst_rect.y;
        int x_pos = pos_cpy.x;
        int y_pos = pos_cpy.y;
-       int clip_x = pipe_ctx->plane_state->clip_rect.x;
+       bool is_primary_plane = (pipe_ctx->plane_state->layer_index == 0);
+
+       int clip_x = (pos_cpy.use_viewport_for_clip && is_primary_plane &&
+               !odm_combine_on && !pipe_split_on && param.viewport.x != 0)
+               ? param.viewport.x : pipe_ctx->plane_state->clip_rect.x;
        int clip_width = pipe_ctx->plane_state->clip_rect.width;
 
        if ((pipe_ctx->top_pipe != NULL) || (pipe_ctx->bottom_pipe != NULL)) {
-- 
2.52.0

Reply via email to