aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorMichel Dänzer <michel.daenzer@amd.com>2012-07-17 13:02:09 -0400
committerDave Airlie <airlied@redhat.com>2012-07-19 21:54:32 -0400
commitf60ec4c7df043df81e62891ac45383d012afe0da (patch)
tree6c40ca18ce2ff7b524d3e0cc95e90b4f442a6832 /drivers
parente811f5ae19043b2ac2c28e147a4274038e655598 (diff)
drm/radeon: Try harder to avoid HW cursor ending on a multiple of 128 columns.
This could previously fail if either of the enabled displays was using a horizontal resolution that is a multiple of 128, and only the leftmost column of the cursor was (supposed to be) visible at the right edge of that display. The solution is to move the cursor one pixel to the left in that case. Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=33183 Cc: stable@vger.kernel.org Signed-off-by: Michel Dänzer <michel.daenzer@amd.com> Reviewed-by: Alex Deucher <alexander.deucher@amd.com> Signed-off-by: Dave Airlie <airlied@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/gpu/drm/radeon/radeon_cursor.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/gpu/drm/radeon/radeon_cursor.c b/drivers/gpu/drm/radeon/radeon_cursor.c
index 42acc6449dd6..711e95ad39bf 100644
--- a/drivers/gpu/drm/radeon/radeon_cursor.c
+++ b/drivers/gpu/drm/radeon/radeon_cursor.c
@@ -262,8 +262,14 @@ int radeon_crtc_cursor_move(struct drm_crtc *crtc,
262 if (!(cursor_end & 0x7f)) 262 if (!(cursor_end & 0x7f))
263 w--; 263 w--;
264 } 264 }
265 if (w <= 0) 265 if (w <= 0) {
266 w = 1; 266 w = 1;
267 cursor_end = x - xorigin + w;
268 if (!(cursor_end & 0x7f)) {
269 x--;
270 WARN_ON_ONCE(x < 0);
271 }
272 }
267 } 273 }
268 } 274 }
269 275