From 59cd46c24ac50bf2c1003296e029d9078b266041 Mon Sep 17 00:00:00 2001 From: Manuel Alfayate Corchete Date: Fri, 5 Feb 2021 22:16:50 +0100 Subject: [PATCH] [KMS/DRM] Merge patch for bug #5532: No need to correct cursor position now that all windows are fullscreen. Link: https://bugzilla.libsdl.org/show_bug.cgi?id=5519. --- src/video/kmsdrm/SDL_kmsdrmmouse.c | 17 +++++------------ 1 file changed, 5 insertions(+), 12 deletions(-) diff --git a/src/video/kmsdrm/SDL_kmsdrmmouse.c b/src/video/kmsdrm/SDL_kmsdrmmouse.c index f2964782a..6a0e09e4a 100644 --- a/src/video/kmsdrm/SDL_kmsdrmmouse.c +++ b/src/video/kmsdrm/SDL_kmsdrmmouse.c @@ -349,8 +349,7 @@ cleanup: void KMSDRM_InitCursor() { - SDL_Mouse *mouse = NULL; - mouse = SDL_GetMouse(); + SDL_Mouse *mouse = SDL_GetMouse(); if (!mouse || !mouse->cur_cursor || !mouse->cursor_shown) { return; @@ -442,14 +441,11 @@ KMSDRM_WarpMouseGlobal(int x, int y) /* And now update the cursor graphic position on screen. */ if (dispdata->cursor_bo) { - int drm_fd, screen_y; + int drm_fd; int ret = 0; - /* Correct the Y coordinate, because DRM mouse coordinates start on screen top. */ - screen_y = dispdata->mode.vdisplay - window->h + mouse->y; - drm_fd = KMSDRM_gbm_device_get_fd(KMSDRM_gbm_bo_get_device(dispdata->cursor_bo)); - ret = KMSDRM_drmModeMoveCursor(drm_fd, dispdata->crtc->crtc_id, x, screen_y); + ret = KMSDRM_drmModeMoveCursor(drm_fd, dispdata->crtc->crtc_id, x, y); if (ret) { SDL_SetError("drmModeMoveCursor() failed."); @@ -504,7 +500,7 @@ static void KMSDRM_MoveCursor(SDL_Cursor * cursor) { SDL_Mouse *mouse = SDL_GetMouse(); - int drm_fd, screen_y; + int drm_fd; int ret = 0; /* We must NOT call SDL_SendMouseMotion() here or we will enter recursivity! @@ -521,10 +517,7 @@ KMSDRM_MoveCursor(SDL_Cursor * cursor) drm_fd = KMSDRM_gbm_device_get_fd(KMSDRM_gbm_bo_get_device(dispdata->cursor_bo)); - /* Correct the Y coordinate, because DRM mouse coordinates start on screen top. */ - screen_y = dispdata->mode.vdisplay - window->h + mouse->y; - - ret = KMSDRM_drmModeMoveCursor(drm_fd, dispdata->crtc->crtc_id, mouse->x, screen_y); + ret = KMSDRM_drmModeMoveCursor(drm_fd, dispdata->crtc->crtc_id, mouse->x, mouse->y); if (ret) { SDL_SetError("drmModeMoveCursor() failed.");