From: Zack Rusin <za...@vmware.com>

Atomic modesetting got support for mouse hotspots via the hotspot
properties. Drivers need to create those properties on cursor planes
which require the mouse hotspot coordinates.

Add the code creating hotspot properties and port away from old legacy
hotspot API. The legacy hotspot paths have an implementation that works
with new atomic properties so there's no reason to keep them and it
makes sense to unify both paths.

Signed-off-by: Zack Rusin <za...@vmware.com>
Cc: David Airlie <airl...@linux.ie>
Cc: Gerd Hoffmann <kra...@redhat.com>
Cc: Gurchetan Singh <gurchetansi...@chromium.org>
Cc: Chia-I Wu <olva...@gmail.com>
Cc: Daniel Vetter <dan...@ffwll.ch>
Cc: virtualizat...@lists.linux-foundation.org
---
 drivers/gpu/drm/virtio/virtgpu_display.c | 1 +
 drivers/gpu/drm/virtio/virtgpu_plane.c   | 8 ++++----
 2 files changed, 5 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/virtio/virtgpu_display.c 
b/drivers/gpu/drm/virtio/virtgpu_display.c
index f73352e7b832..848ac2314399 100644
--- a/drivers/gpu/drm/virtio/virtgpu_display.c
+++ b/drivers/gpu/drm/virtio/virtgpu_display.c
@@ -288,6 +288,7 @@ static int vgdev_output_init(struct virtio_gpu_device 
*vgdev, int index)
 
        drm_connector_attach_encoder(connector, encoder);
        drm_connector_register(connector);
+       drm_plane_create_hotspot_properties(cursor);
        return 0;
 }
 
diff --git a/drivers/gpu/drm/virtio/virtgpu_plane.c 
b/drivers/gpu/drm/virtio/virtgpu_plane.c
index 6d3cc9e238a4..21c8adf51c6c 100644
--- a/drivers/gpu/drm/virtio/virtgpu_plane.c
+++ b/drivers/gpu/drm/virtio/virtgpu_plane.c
@@ -331,16 +331,16 @@ static void virtio_gpu_cursor_plane_update(struct 
drm_plane *plane,
                DRM_DEBUG("update, handle %d, pos +%d+%d, hot %d,%d\n", handle,
                          plane->state->crtc_x,
                          plane->state->crtc_y,
-                         plane->state->fb ? plane->state->fb->hot_x : 0,
-                         plane->state->fb ? plane->state->fb->hot_y : 0);
+                         plane->state->hotspot_x,
+                         plane->state->hotspot_y);
                output->cursor.hdr.type =
                        cpu_to_le32(VIRTIO_GPU_CMD_UPDATE_CURSOR);
                output->cursor.resource_id = cpu_to_le32(handle);
                if (plane->state->fb) {
                        output->cursor.hot_x =
-                               cpu_to_le32(plane->state->fb->hot_x);
+                               cpu_to_le32(plane->state->hotspot_x);
                        output->cursor.hot_y =
-                               cpu_to_le32(plane->state->fb->hot_y);
+                               cpu_to_le32(plane->state->hotspot_y);
                } else {
                        output->cursor.hot_x = cpu_to_le32(0);
                        output->cursor.hot_y = cpu_to_le32(0);
-- 
2.34.1

Reply via email to