@@ -2831,6 +2831,9 @@ static int drm_mode_cursor_universal(struct drm_crtc *crtc,
DRM_DEBUG_KMS("failed to wrap cursor buffer in drm framebuffer\n");
return PTR_ERR(fb);
}
+
+ crtc->hot_x = req->hot_x;
+ crtc->hot_y = req->hot_y;
} else {
fb = NULL;
}
@@ -2841,11 +2844,11 @@ static int drm_mode_cursor_universal(struct drm_crtc *crtc,
}
if (req->flags & DRM_MODE_CURSOR_MOVE) {
- crtc_x = req->x;
- crtc_y = req->y;
+ crtc_x = req->x - crtc->hot_x;
+ crtc_y = req->y - crtc->hot_y;
} else {
- crtc_x = crtc->cursor_x;
- crtc_y = crtc->cursor_y;
+ crtc_x = crtc->cursor_x - crtc->hot_x;
+ crtc_y = crtc->cursor_y - crtc->hot_y;
}
if (fb) {
@@ -445,6 +445,10 @@ struct drm_crtc {
int cursor_x;
int cursor_y;
+ /* hotspot of cursor */
+ int hot_x;
+ int hot_y;
+
bool enabled;
/* Requested mode from modesetting. */
The request's hot_x and hot_y are set correctly for both DRM_IOCTL_MODE_CURSOR and DRM_IOCTL_MODE_CURSOR2 so we just need to save the values and then apply the offset to the cursor plane when the cursor moves. Signed-off-by: John Keeping <john@metanate.com> --- drivers/gpu/drm/drm_crtc.c | 11 +++++++---- include/drm/drm_crtc.h | 4 ++++ 2 files changed, 11 insertions(+), 4 deletions(-)