If the drm_mode_cursor_ioctl is called and the cursor_set2 callback is
implemented, the cursor hotspot is set to (0,0) which is incompatible
with vmwgfx where the hotspot should instead remain unchanged.

So if the driver implements both cursor_set2 and cursor_set, prefer calling
the latter from the drm_mode_cursor ioctl.

Signed-off-by: Thomas Hellstrom <thellstrom at vmware.com>
---
 drivers/gpu/drm/drm_crtc.c | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/drm_crtc.c b/drivers/gpu/drm/drm_crtc.c
index 24c5434..93f80a5 100644
--- a/drivers/gpu/drm/drm_crtc.c
+++ b/drivers/gpu/drm/drm_crtc.c
@@ -2874,7 +2874,8 @@ static int drm_mode_cursor_universal(struct drm_crtc 
*crtc,

 static int drm_mode_cursor_common(struct drm_device *dev,
                                  struct drm_mode_cursor2 *req,
-                                 struct drm_file *file_priv)
+                                 struct drm_file *file_priv,
+                                 bool from_2)
 {
        struct drm_crtc *crtc;
        int ret = 0;
@@ -2907,7 +2908,8 @@ static int drm_mode_cursor_common(struct drm_device *dev,
                        goto out;
                }
                /* Turns off the cursor if handle is 0 */
-               if (crtc->funcs->cursor_set2)
+               if (crtc->funcs->cursor_set2 &&
+                   (from_2 || !crtc->funcs->cursor_set))
                        ret = crtc->funcs->cursor_set2(crtc, file_priv, 
req->handle,
                                                      req->width, req->height, 
req->hot_x, req->hot_y);
                else
@@ -2953,7 +2955,7 @@ int drm_mode_cursor_ioctl(struct drm_device *dev,
        memcpy(&new_req, req, sizeof(struct drm_mode_cursor));
        new_req.hot_x = new_req.hot_y = 0;

-       return drm_mode_cursor_common(dev, &new_req, file_priv);
+       return drm_mode_cursor_common(dev, &new_req, file_priv, false);
 }

 /**
@@ -2976,7 +2978,7 @@ int drm_mode_cursor2_ioctl(struct drm_device *dev,
 {
        struct drm_mode_cursor2 *req = data;

-       return drm_mode_cursor_common(dev, req, file_priv);
+       return drm_mode_cursor_common(dev, req, file_priv, true);
 }

 /**
-- 
2.4.3

Reply via email to