[Spice-devel] intel vgpu & spice & cursor
Marc-André Lureau
marcandre.lureau at redhat.com
Thu Oct 12 09:42:04 UTC 2017
Hi
----- Original Message -----
> Hi,
>
> We need to figure a way to handle intel vgpu with spice, especially how
> to handle the cursor.
>
> What we'll get from the vgpu is two dma-bufs: One for the primary
> plane (aka guest display), one for the cursor plane. We also get the
> position of the cursor. We do *not* get the hotspot of the cursor.
>
> The latter implies client mouse mode isn't going to work, so we need
> some other way to render the cursor. I see basically two options:
>
It's a shame not to have client mouse mode support. I wonder if we could modify the intel driver to pass along the cursor details, like virgl does (see drmModeSetCursor2).
> (a) Update spice-server API (and probably spice protocol too),
> add a call (or two) to pass on cursor dmabuf and position.
>
> (b) Create a new dma-buf in qemu, render guest display with cursor
> to it, pass *that* to spice-server.
>
> I think (a) would be the better choice. It gives more flexibility to
> the spice client, for example it would be possible to create a drm-
> based spice client which simply maps the guest planes to a host
> scanout. I think it'll also have less overhead as qemu has no need to
> touch the dma-bufs then, it just passes on the fds.
Spice has SPICE_MSG_DISPLAY_GL_SCANOUT_UNIX to pass a dmabuf to client, it could be extended as needed or a new similar message could be added.
>
> But option (b) wouldn't be a big deal either. qemu must handle that
> anyway, for the gtk and sdl UIs, so supporting it for spice too would
> be easy.
>
> Comments?
More information about the intel-gvt-dev
mailing list