From: Nevenko Stupar <nevenko.stu...@amd.com>

[WHY & HOW]
Adjust hot spot positions between ODM slices when cursor
magnification is used.

Reviewed-by: Sridevi Arvindekar <sridevi.arvinde...@amd.com>
Cc: Mario Limonciello <mario.limoncie...@amd.com>
Cc: Alex Deucher <alexander.deuc...@amd.com>
Cc: sta...@vger.kernel.org
Acked-by: Alex Hung <alex.h...@amd.com>
Signed-off-by: Nevenko Stupar <nevenko.stu...@amd.com>
---
 .../gpu/drm/amd/display/dc/hwss/dcn401/dcn401_hwseq.c    | 9 +++++++++
 1 file changed, 9 insertions(+)

diff --git a/drivers/gpu/drm/amd/display/dc/hwss/dcn401/dcn401_hwseq.c 
b/drivers/gpu/drm/amd/display/dc/hwss/dcn401/dcn401_hwseq.c
index 79a911e1a09a..5306c8c170c5 100644
--- a/drivers/gpu/drm/amd/display/dc/hwss/dcn401/dcn401_hwseq.c
+++ b/drivers/gpu/drm/amd/display/dc/hwss/dcn401/dcn401_hwseq.c
@@ -1177,6 +1177,15 @@ void dcn401_set_cursor_position(struct pipe_ctx 
*pipe_ctx)
 
        if (x_pos < 0) {
                pos_cpy.x_hotspot -= x_pos;
+               if ((odm_combine_on) && 
(hubp->curs_attr.attribute_flags.bits.ENABLE_MAGNIFICATION)) {
+                       if (hubp->curs_attr.width <= 128) {
+                               pos_cpy.x_hotspot /= 2;
+                               pos_cpy.x_hotspot += 1;
+                       } else {
+                               pos_cpy.x_hotspot /= 2;
+                               pos_cpy.x_hotspot += 2;
+                       }
+               }
                x_pos = 0;
        }
 
-- 
2.34.1

Reply via email to