Hi

On Tue, Mar 25, 2025 at 10:52 AM Qiang Yu <yuq...@gmail.com> wrote:
>
> On Tue, Mar 25, 2025 at 2:37 PM Marc-André Lureau
> <marcandre.lur...@gmail.com> wrote:
> >
> > Hi
> >
> > On Tue, Mar 25, 2025 at 7:26 AM Qiang Yu <yuq...@gmail.com> wrote:
> > >
> > > On Mon, Mar 24, 2025 at 10:06 PM Marc-André Lureau
> > > <marcandre.lur...@gmail.com> wrote:
> > > >
> > > > Hi
> > > >
> > > > On Mon, Mar 24, 2025 at 5:20 PM Qiang Yu <yuq...@gmail.com> wrote:
> > > > >
> > > > > On Mon, Mar 24, 2025 at 6:04 PM Marc-André Lureau
> > > > > <marcandre.lur...@redhat.com> wrote:
> > > > > >
> > > > > > Hi
> > > > > >
> > > > > > On Mon, Mar 24, 2025 at 12:19 PM <yuq...@gmail.com> wrote:
> > > > > > >
> > > > > > > From: Qiang Yu <yuq...@gmail.com>
> > > > > > >
> > > > > > > mesa/radeonsi is going to support explicit midifier which
> > > > > > > may export a multi-plane texture. For example, texture with
> > > > > > > DCC enabled (a compressed format) has two planes, one with
> > > > > > > compressed data, the other with meta data for compression.
> > > > > > >
> > > > > > > Signed-off-by: Qiang Yu <yuq...@gmail.com>
> > > > > > > ---
> > > > > > >  hw/display/vhost-user-gpu.c     |  6 ++-
> > > > > > >  hw/display/virtio-gpu-udmabuf.c |  6 ++-
> > > > > > >  hw/vfio/display.c               |  7 ++--
> > > > > > >  include/ui/dmabuf.h             | 20 ++++++----
> > > > > > >  ui/dbus-listener.c              | 10 ++---
> > > > > > >  ui/dmabuf.c                     | 67 
> > > > > > > +++++++++++++++++++++------------
> > > > > > >  ui/egl-helpers.c                |  4 +-
> > > > > > >  ui/spice-display.c              |  4 +-
> > > > > > >  8 files changed, 76 insertions(+), 48 deletions(-)
> > > > > > >
> > > > > > > diff --git a/hw/display/vhost-user-gpu.c 
> > > > > > > b/hw/display/vhost-user-gpu.c
> > > > > > > index 2aed6243f6..a7949c7078 100644
> > > > > > > --- a/hw/display/vhost-user-gpu.c
> > > > > > > +++ b/hw/display/vhost-user-gpu.c
> > > > > > > @@ -249,6 +249,8 @@ vhost_user_gpu_handle_display(VhostUserGPU 
> > > > > > > *g, VhostUserGpuMsg *msg)
> > > > > > >      case VHOST_USER_GPU_DMABUF_SCANOUT: {
> > > > > > >          VhostUserGpuDMABUFScanout *m = 
> > > > > > > &msg->payload.dmabuf_scanout;
> > > > > > >          int fd = qemu_chr_fe_get_msgfd(&g->vhost_chr);
> > > > > > > +        uint32_t offset = 0;
> > > > > > > +        uint32_t stride = m->fd_stride;
> > > > > > >          uint64_t modifier = 0;
> > > > > > >          QemuDmaBuf *dmabuf;
> > > > > > >
> > > > > > > @@ -282,10 +284,10 @@ vhost_user_gpu_handle_display(VhostUserGPU 
> > > > > > > *g, VhostUserGpuMsg *msg)
> > > > > > >          }
> > > > > > >
> > > > > > >          dmabuf = qemu_dmabuf_new(m->width, m->height,
> > > > > > > -                                 m->fd_stride, 0, 0,
> > > > > > > +                                 &offset, &stride, 0, 0,
> > > > > > >                                   m->fd_width, m->fd_height,
> > > > > > >                                   m->fd_drm_fourcc, modifier,
> > > > > > > -                                 fd, false, m->fd_flags &
> > > > > > > +                                 &fd, 1, false, m->fd_flags &
> > > > > > >                                   
> > > > > > > VIRTIO_GPU_RESOURCE_FLAG_Y_0_TOP);
> > > > > > >
> > > > > > >          dpy_gl_scanout_dmabuf(con, dmabuf);
> > > > > > > diff --git a/hw/display/virtio-gpu-udmabuf.c 
> > > > > > > b/hw/display/virtio-gpu-udmabuf.c
> > > > > > > index 85ca23cb32..34fbe05b7a 100644
> > > > > > > --- a/hw/display/virtio-gpu-udmabuf.c
> > > > > > > +++ b/hw/display/virtio-gpu-udmabuf.c
> > > > > > > @@ -176,16 +176,18 @@ static VGPUDMABuf
> > > > > > >                            struct virtio_gpu_rect *r)
> > > > > > >  {
> > > > > > >      VGPUDMABuf *dmabuf;
> > > > > > > +    uint32_t offset = 0;
> > > > > > >
> > > > > > >      if (res->dmabuf_fd < 0) {
> > > > > > >          return NULL;
> > > > > > >      }
> > > > > > >
> > > > > > >      dmabuf = g_new0(VGPUDMABuf, 1);
> > > > > > > -    dmabuf->buf = qemu_dmabuf_new(r->width, r->height, 
> > > > > > > fb->stride,
> > > > > > > +    dmabuf->buf = qemu_dmabuf_new(r->width, r->height,
> > > > > > > +                                  &offset, &fb->stride,
> > > > > > >                                    r->x, r->y, fb->width, 
> > > > > > > fb->height,
> > > > > > >                                    
> > > > > > > qemu_pixman_to_drm_format(fb->format),
> > > > > > > -                                  0, res->dmabuf_fd, true, 
> > > > > > > false);
> > > > > > > +                                  0, &res->dmabuf_fd, 1, true, 
> > > > > > > false);
> > > > > > >      dmabuf->scanout_id = scanout_id;
> > > > > > >      QTAILQ_INSERT_HEAD(&g->dmabuf.bufs, dmabuf, next);
> > > > > > >
> > > > > > > diff --git a/hw/vfio/display.c b/hw/vfio/display.c
> > > > > > > index ea87830fe0..9d882235fb 100644
> > > > > > > --- a/hw/vfio/display.c
> > > > > > > +++ b/hw/vfio/display.c
> > > > > > > @@ -214,6 +214,7 @@ static VFIODMABuf 
> > > > > > > *vfio_display_get_dmabuf(VFIOPCIDevice *vdev,
> > > > > > >      struct vfio_device_gfx_plane_info plane;
> > > > > > >      VFIODMABuf *dmabuf;
> > > > > > >      int fd, ret;
> > > > > > > +    uint32_t offset = 0;
> > > > > > >
> > > > > > >      memset(&plane, 0, sizeof(plane));
> > > > > > >      plane.argsz = sizeof(plane);
> > > > > > > @@ -246,10 +247,10 @@ static VFIODMABuf 
> > > > > > > *vfio_display_get_dmabuf(VFIOPCIDevice *vdev,
> > > > > > >
> > > > > > >      dmabuf = g_new0(VFIODMABuf, 1);
> > > > > > >      dmabuf->dmabuf_id  = plane.dmabuf_id;
> > > > > > > -    dmabuf->buf = qemu_dmabuf_new(plane.width, plane.height,
> > > > > > > -                                  plane.stride, 0, 0, 
> > > > > > > plane.width,
> > > > > > > +    dmabuf->buf = qemu_dmabuf_new(plane.width, plane.height, 
> > > > > > > &offset,
> > > > > > > +                                  &plane.stride, 0, 0, 
> > > > > > > plane.width,
> > > > > > >                                    plane.height, plane.drm_format,
> > > > > > > -                                  plane.drm_format_mod, fd, 
> > > > > > > false, false);
> > > > > > > +                                  plane.drm_format_mod, &fd, 1, 
> > > > > > > false, false);
> > > > > > >
> > > > > > >      if (plane_type == DRM_PLANE_TYPE_CURSOR) {
> > > > > > >          vfio_display_update_cursor(dmabuf, &plane);
> > > > > > > diff --git a/include/ui/dmabuf.h b/include/ui/dmabuf.h
> > > > > > > index dc74ba895a..407fb2274e 100644
> > > > > > > --- a/include/ui/dmabuf.h
> > > > > > > +++ b/include/ui/dmabuf.h
> > > > > > > @@ -10,24 +10,29 @@
> > > > > > >  #ifndef DMABUF_H
> > > > > > >  #define DMABUF_H
> > > > > > >
> > > > > > > +#define DMABUF_MAX_PLANES 4
> > > > > > > +
> > > > > > >  typedef struct QemuDmaBuf QemuDmaBuf;
> > > > > > >
> > > > > > >  QemuDmaBuf *qemu_dmabuf_new(uint32_t width, uint32_t height,
> > > > > > > -                            uint32_t stride, uint32_t x,
> > > > > > > -                            uint32_t y, uint32_t backing_width,
> > > > > > > -                            uint32_t backing_height, uint32_t 
> > > > > > > fourcc,
> > > > > > > -                            uint64_t modifier, int dmabuf_fd,
> > > > > > > +                            const uint32_t *offset, const 
> > > > > > > uint32_t *stride,
> > > > > > > +                            uint32_t x, uint32_t y,
> > > > > > > +                            uint32_t backing_width, uint32_t 
> > > > > > > backing_height,
> > > > > > > +                            uint32_t fourcc, uint64_t modifier,
> > > > > > > +                            const int32_t *dmabuf_fd, uint32_t 
> > > > > > > num_planes,
> > > > > > >                              bool allow_fences, bool y0_top);
> > > > > > >  void qemu_dmabuf_free(QemuDmaBuf *dmabuf);
> > > > > > >
> > > > > > >  G_DEFINE_AUTOPTR_CLEANUP_FUNC(QemuDmaBuf, qemu_dmabuf_free);
> > > > > > >
> > > > > > > -int qemu_dmabuf_get_fd(QemuDmaBuf *dmabuf);
> > > > > > > -int qemu_dmabuf_dup_fd(QemuDmaBuf *dmabuf);
> > > > > > > +const int *qemu_dmabuf_get_fd(QemuDmaBuf *dmabuf);
> > > > > >
> > > > > > For clarity, I think the functions should be renamed to a plural 
> > > > > > form:
> > > > > > get_fds, dup_fds, get_strides, get_offsets etc.. I would also have a
> > > > > > size_t *n_fds to return the length of the returned array.
> > > > > >
> > > > > The returned array length is always 4. Valid fds are within num_planes
> > > > > elements. There's no user for n_fds argument.
> > > >
> > > > I understand it is not strictly needed, but it's about being explicit
> > > > for the API, and making it safer for future refactoring as well.
> > > >
> > > Then we have to maintain a record for valid fds just for "explicit for 
> > > API"?
> > > These APIs are all internal use, we can change them whenever needed.
> > > We should not add an used arg which costs extra maintenance effort.
> >
> > void qemu_dmabuf_dup_fd(QemuDmaBuf *dmabuf, int *fd);
> >
> > Sorry, that is not good enough. Someone reading this declaration will
> > rightfully expect the function to only set *fd. At the bare minimum,
> > you would need to document the function to explain what to expect
> > instead.
> >
> > Contrast with:
> >
> > void qemu_dmabuf_dup_fds(QemuDmaBuf *dmabuf, int *fds, size_t n_fds);
> >
> > Where you explicitly have to deal with an array of fds.
> >
> > It is similar for the rest of the functions and for consistency.
> >
> Then is it OK for you that we always use like this?
> qemu_dmabuf_dup_fds(dmabuf, fds, 4);
> fds = qemu_dmabuf_get_fds(dmabuf, &nfds); /* nfds always equals 4 and unused 
> */

It's better, with extra assert(nfds == 4) or runtime condition.

>
> > >
> > > > >
> > > > > > > +void qemu_dmabuf_dup_fd(QemuDmaBuf *dmabuf, int *fd);
> > > > > >
> > > > > > That function should take an n_fds arguments as well (fd being 
> > > > > > renamed
> > > > > > to fds as well)
> > > > > >
> > > > > We just dup all fds in dmabuf, so no need for n_fds argument. And 
> > > > > there's
> > > > > no use for this arg either.
> > > > >
> > > > > > thanks
> > > > > >
> > > > > > >  void qemu_dmabuf_close(QemuDmaBuf *dmabuf);
> > > > > > >  uint32_t qemu_dmabuf_get_width(QemuDmaBuf *dmabuf);
> > > > > > >  uint32_t qemu_dmabuf_get_height(QemuDmaBuf *dmabuf);
> > > > > > > -uint32_t qemu_dmabuf_get_stride(QemuDmaBuf *dmabuf);
> > > > > > > +const uint32_t *qemu_dmabuf_get_offset(QemuDmaBuf *dmabuf);
> > > > > > > +const uint32_t *qemu_dmabuf_get_stride(QemuDmaBuf *dmabuf);
> > > > > > > +uint32_t qemu_dmabuf_get_num_planes(QemuDmaBuf *dmabuf);
> > > > > > >  uint32_t qemu_dmabuf_get_fourcc(QemuDmaBuf *dmabuf);
> > > > > > >  uint64_t qemu_dmabuf_get_modifier(QemuDmaBuf *dmabuf);
> > > > > > >  uint32_t qemu_dmabuf_get_texture(QemuDmaBuf *dmabuf);
> > > > > > > @@ -44,6 +49,5 @@ void qemu_dmabuf_set_texture(QemuDmaBuf 
> > > > > > > *dmabuf, uint32_t texture);
> > > > > > >  void qemu_dmabuf_set_fence_fd(QemuDmaBuf *dmabuf, int32_t 
> > > > > > > fence_fd);
> > > > > > >  void qemu_dmabuf_set_sync(QemuDmaBuf *dmabuf, void *sync);
> > > > > > >  void qemu_dmabuf_set_draw_submitted(QemuDmaBuf *dmabuf, bool 
> > > > > > > draw_submitted);
> > > > > > > -void qemu_dmabuf_set_fd(QemuDmaBuf *dmabuf, int32_t fd);
> > > > > > >
> > > > > > >  #endif
> > > > > > > diff --git a/ui/dbus-listener.c b/ui/dbus-listener.c
> > > > > > > index 51244c9240..3b39a23846 100644
> > > > > > > --- a/ui/dbus-listener.c
> > > > > > > +++ b/ui/dbus-listener.c
> > > > > > > @@ -299,7 +299,7 @@ static void 
> > > > > > > dbus_scanout_dmabuf(DisplayChangeListener *dcl,
> > > > > > >      uint64_t modifier;
> > > > > > >      bool y0_top;
> > > > > > >
> > > > > > > -    fd = qemu_dmabuf_get_fd(dmabuf);
> > > > > > > +    fd = qemu_dmabuf_get_fd(dmabuf)[0];
> > > > > > >      fd_list = g_unix_fd_list_new();
> > > > > > >      if (g_unix_fd_list_append(fd_list, fd, &err) != 0) {
> > > > > > >          error_report("Failed to setup dmabuf fdlist: %s", 
> > > > > > > err->message);
> > > > > > > @@ -310,7 +310,7 @@ static void 
> > > > > > > dbus_scanout_dmabuf(DisplayChangeListener *dcl,
> > > > > > >
> > > > > > >      width = qemu_dmabuf_get_width(dmabuf);
> > > > > > >      height = qemu_dmabuf_get_height(dmabuf);
> > > > > > > -    stride = qemu_dmabuf_get_stride(dmabuf);
> > > > > > > +    stride = qemu_dmabuf_get_stride(dmabuf)[0];
> > > > > > >      fourcc = qemu_dmabuf_get_fourcc(dmabuf);
> > > > > > >      modifier = qemu_dmabuf_get_modifier(dmabuf);
> > > > > > >      y0_top = qemu_dmabuf_get_y0_top(dmabuf);
> > > > > > > @@ -505,7 +505,7 @@ static void 
> > > > > > > dbus_scanout_texture(DisplayChangeListener *dcl,
> > > > > > >  #ifdef CONFIG_GBM
> > > > > > >      g_autoptr(QemuDmaBuf) dmabuf = NULL;
> > > > > > >      int fd;
> > > > > > > -    uint32_t stride, fourcc;
> > > > > > > +    uint32_t offset = 0, stride, fourcc;
> > > > > > >      uint64_t modifier;
> > > > > > >
> > > > > > >      assert(tex_id);
> > > > > > > @@ -515,8 +515,8 @@ static void 
> > > > > > > dbus_scanout_texture(DisplayChangeListener *dcl,
> > > > > > >          error_report("%s: failed to get fd for texture", 
> > > > > > > __func__);
> > > > > > >          return;
> > > > > > >      }
> > > > > > > -    dmabuf = qemu_dmabuf_new(w, h, stride, x, y, backing_width,
> > > > > > > -                             backing_height, fourcc, modifier, 
> > > > > > > fd,
> > > > > > > +    dmabuf = qemu_dmabuf_new(w, h, &offset, &stride, x, y, 
> > > > > > > backing_width,
> > > > > > > +                             backing_height, fourcc, modifier, 
> > > > > > > &fd, 1,
> > > > > > >                               false, backing_y_0_top);
> > > > > > >
> > > > > > >      dbus_scanout_dmabuf(dcl, dmabuf);
> > > > > > > diff --git a/ui/dmabuf.c b/ui/dmabuf.c
> > > > > > > index df7a09703f..c4eb307042 100644
> > > > > > > --- a/ui/dmabuf.c
> > > > > > > +++ b/ui/dmabuf.c
> > > > > > > @@ -11,10 +11,12 @@
> > > > > > >  #include "ui/dmabuf.h"
> > > > > > >
> > > > > > >  struct QemuDmaBuf {
> > > > > > > -    int       fd;
> > > > > > > +    int       fd[DMABUF_MAX_PLANES];
> > > > > > >      uint32_t  width;
> > > > > > >      uint32_t  height;
> > > > > > > -    uint32_t  stride;
> > > > > > > +    uint32_t  offset[DMABUF_MAX_PLANES];
> > > > > > > +    uint32_t  stride[DMABUF_MAX_PLANES];
> > > > > > > +    uint32_t  num_planes;
> > > > > > >      uint32_t  fourcc;
> > > > > > >      uint64_t  modifier;
> > > > > > >      uint32_t  texture;
> > > > > > > @@ -30,28 +32,33 @@ struct QemuDmaBuf {
> > > > > > >  };
> > > > > > >
> > > > > > >  QemuDmaBuf *qemu_dmabuf_new(uint32_t width, uint32_t height,
> > > > > > > -                            uint32_t stride, uint32_t x,
> > > > > > > -                            uint32_t y, uint32_t backing_width,
> > > > > > > -                            uint32_t backing_height, uint32_t 
> > > > > > > fourcc,
> > > > > > > -                            uint64_t modifier, int32_t dmabuf_fd,
> > > > > > > +                            const uint32_t *offset, const 
> > > > > > > uint32_t *stride,
> > > > > > > +                            uint32_t x, uint32_t y,
> > > > > > > +                            uint32_t backing_width, uint32_t 
> > > > > > > backing_height,
> > > > > > > +                            uint32_t fourcc, uint64_t modifier,
> > > > > > > +                            const int32_t *dmabuf_fd, uint32_t 
> > > > > > > num_planes,
> > > > > > >                              bool allow_fences, bool y0_top) {
> > > > > > >      QemuDmaBuf *dmabuf;
> > > > > > >
> > > > > > > +    assert(num_planes > 0 && num_planes <= DMABUF_MAX_PLANES);
> > > > > > > +
> > > > > > >      dmabuf = g_new0(QemuDmaBuf, 1);
> > > > > > >
> > > > > > >      dmabuf->width = width;
> > > > > > >      dmabuf->height = height;
> > > > > > > -    dmabuf->stride = stride;
> > > > > > > +    memcpy(dmabuf->offset, offset, num_planes * sizeof(*offset));
> > > > > > > +    memcpy(dmabuf->stride, stride, num_planes * sizeof(*stride));
> > > > > > >      dmabuf->x = x;
> > > > > > >      dmabuf->y = y;
> > > > > > >      dmabuf->backing_width = backing_width;
> > > > > > >      dmabuf->backing_height = backing_height;
> > > > > > >      dmabuf->fourcc = fourcc;
> > > > > > >      dmabuf->modifier = modifier;
> > > > > > > -    dmabuf->fd = dmabuf_fd;
> > > > > > > +    memcpy(dmabuf->fd, dmabuf_fd, num_planes * 
> > > > > > > sizeof(*dmabuf_fd));
> > > > > > >      dmabuf->allow_fences = allow_fences;
> > > > > > >      dmabuf->y0_top = y0_top;
> > > > > > >      dmabuf->fence_fd = -1;
> > > > > > > +    dmabuf->num_planes = num_planes;
> > > > > > >
> > > > > > >      return dmabuf;
> > > > > > >  }
> > > > > > > @@ -65,31 +72,35 @@ void qemu_dmabuf_free(QemuDmaBuf *dmabuf)
> > > > > > >      g_free(dmabuf);
> > > > > > >  }
> > > > > > >
> > > > > > > -int qemu_dmabuf_get_fd(QemuDmaBuf *dmabuf)
> > > > > > > +const int *qemu_dmabuf_get_fd(QemuDmaBuf *dmabuf)
> > > > > > >  {
> > > > > > >      assert(dmabuf != NULL);
> > > > > > >
> > > > > > >      return dmabuf->fd;
> > > > > > >  }
> > > > > > >
> > > > > > > -int qemu_dmabuf_dup_fd(QemuDmaBuf *dmabuf)
> > > > > > > +void qemu_dmabuf_dup_fd(QemuDmaBuf *dmabuf, int *fd)
> > > > > > >  {
> > > > > > > +    int i;
> > > > > > > +
> > > > > > >      assert(dmabuf != NULL);
> > > > > > >
> > > > > > > -    if (dmabuf->fd >= 0) {
> > > > > > > -        return dup(dmabuf->fd);
> > > > > > > -    } else {
> > > > > > > -        return -1;
> > > > > > > +    for (i = 0; i < dmabuf->num_planes; i++) {
> > > > > > > +        fd[i] = dmabuf->fd[i] >= 0 ? dup(dmabuf->fd[i]) : -1;
> > > > > > >      }
> > > > > > >  }
> > > > > > >
> > > > > > >  void qemu_dmabuf_close(QemuDmaBuf *dmabuf)
> > > > > > >  {
> > > > > > > +    int i;
> > > > > > > +
> > > > > > >      assert(dmabuf != NULL);
> > > > > > >
> > > > > > > -    if (dmabuf->fd >= 0) {
> > > > > > > -        close(dmabuf->fd);
> > > > > > > -        dmabuf->fd = -1;
> > > > > > > +    for (i = 0; i < dmabuf->num_planes; i++) {
> > > > > > > +        if (dmabuf->fd[i] >= 0) {
> > > > > > > +            close(dmabuf->fd[i]);
> > > > > > > +            dmabuf->fd[i] = -1;
> > > > > > > +        }
> > > > > > >      }
> > > > > > >  }
> > > > > > >
> > > > > > > @@ -107,13 +118,27 @@ uint32_t qemu_dmabuf_get_height(QemuDmaBuf 
> > > > > > > *dmabuf)
> > > > > > >      return dmabuf->height;
> > > > > > >  }
> > > > > > >
> > > > > > > -uint32_t qemu_dmabuf_get_stride(QemuDmaBuf *dmabuf)
> > > > > > > +const uint32_t *qemu_dmabuf_get_offset(QemuDmaBuf *dmabuf)
> > > > > > > +{
> > > > > > > +    assert(dmabuf != NULL);
> > > > > > > +
> > > > > > > +    return dmabuf->offset;
> > > > > > > +}
> > > > > > > +
> > > > > > > +const uint32_t *qemu_dmabuf_get_stride(QemuDmaBuf *dmabuf)
> > > > > > >  {
> > > > > > >      assert(dmabuf != NULL);
> > > > > > >
> > > > > > >      return dmabuf->stride;
> > > > > > >  }
> > > > > > >
> > > > > > > +uint32_t qemu_dmabuf_get_num_planes(QemuDmaBuf *dmabuf)
> > > > > > > +{
> > > > > > > +    assert(dmabuf != NULL);
> > > > > > > +
> > > > > > > +    return dmabuf->num_planes;
> > > > > > > +}
> > > > > > > +
> > > > > > >  uint32_t qemu_dmabuf_get_fourcc(QemuDmaBuf *dmabuf)
> > > > > > >  {
> > > > > > >      assert(dmabuf != NULL);
> > > > > > > @@ -221,9 +246,3 @@ void 
> > > > > > > qemu_dmabuf_set_draw_submitted(QemuDmaBuf *dmabuf, bool 
> > > > > > > draw_submitted)
> > > > > > >      assert(dmabuf != NULL);
> > > > > > >      dmabuf->draw_submitted = draw_submitted;
> > > > > > >  }
> > > > > > > -
> > > > > > > -void qemu_dmabuf_set_fd(QemuDmaBuf *dmabuf, int32_t fd)
> > > > > > > -{
> > > > > > > -    assert(dmabuf != NULL);
> > > > > > > -    dmabuf->fd = fd;
> > > > > > > -}
> > > > > > > diff --git a/ui/egl-helpers.c b/ui/egl-helpers.c
> > > > > > > index d591159480..72a1405782 100644
> > > > > > > --- a/ui/egl-helpers.c
> > > > > > > +++ b/ui/egl-helpers.c
> > > > > > > @@ -323,9 +323,9 @@ void egl_dmabuf_import_texture(QemuDmaBuf 
> > > > > > > *dmabuf)
> > > > > > >      attrs[i++] = qemu_dmabuf_get_fourcc(dmabuf);
> > > > > > >
> > > > > > >      attrs[i++] = EGL_DMA_BUF_PLANE0_FD_EXT;
> > > > > > > -    attrs[i++] = qemu_dmabuf_get_fd(dmabuf);
> > > > > > > +    attrs[i++] = qemu_dmabuf_get_fd(dmabuf)[0];
> > > > > > >      attrs[i++] = EGL_DMA_BUF_PLANE0_PITCH_EXT;
> > > > > > > -    attrs[i++] = qemu_dmabuf_get_stride(dmabuf);
> > > > > > > +    attrs[i++] = qemu_dmabuf_get_stride(dmabuf)[0];
> > > > > > >      attrs[i++] = EGL_DMA_BUF_PLANE0_OFFSET_EXT;
> > > > > > >      attrs[i++] = 0;
> > > > > > >  #ifdef EGL_DMA_BUF_PLANE0_MODIFIER_LO_EXT
> > > > > > > diff --git a/ui/spice-display.c b/ui/spice-display.c
> > > > > > > index c794ae0649..82598fe9e8 100644
> > > > > > > --- a/ui/spice-display.c
> > > > > > > +++ b/ui/spice-display.c
> > > > > > > @@ -1075,10 +1075,10 @@ static void 
> > > > > > > qemu_spice_gl_update(DisplayChangeListener *dcl,
> > > > > > >                                       stride, fourcc, false);
> > > > > > >              }
> > > > > > >          } else {
> > > > > > > -            stride = qemu_dmabuf_get_stride(dmabuf);
> > > > > > > +            stride = qemu_dmabuf_get_stride(dmabuf)[0];
> > > > > > >              fourcc = qemu_dmabuf_get_fourcc(dmabuf);
> > > > > > >              y_0_top = qemu_dmabuf_get_y0_top(dmabuf);
> > > > > > > -            fd = qemu_dmabuf_dup_fd(dmabuf);
> > > > > > > +            qemu_dmabuf_dup_fd(dmabuf, &fd);
> > > > > > >
> > > > > > >              trace_qemu_spice_gl_forward_dmabuf(ssd->qxl.id, 
> > > > > > > width, height);
> > > > > > >              /* note: spice server will close the fd, so hand 
> > > > > > > over a dup */
> > > > > > > --
> > > > > > > 2.43.0
> > > > > > >
> > > > > >
> > > > >
> > > >
> > > >
> > > > --
> > > > Marc-André Lureau
> >
> >
> >
> > --
> > Marc-André Lureau



-- 
Marc-André Lureau

Reply via email to