qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [Qemu-devel] [PATCH] vhost-user: modify SET_LOG_BASE to pass mmap si


From: Michael S. Tsirkin
Subject: Re: [Qemu-devel] [PATCH] vhost-user: modify SET_LOG_BASE to pass mmap size and offset
Date: Wed, 11 Nov 2015 17:17:23 +0200

On Wed, Nov 11, 2015 at 09:32:17AM -0500, Marc-André Lureau wrote:
> Hi
> 
> ----- Original Message -----
> > Unlike the kernel, vhost-user application accesses log table by
> > mmaping it to its user space. This change adds two new fields to
> > VhostUserMsg payload: mmap_size, and mmap_offset and make QEMU to
> > pass the to vhost-user application in VHOST_USER_SET_LOG_BASE
> > request.
> > 
> > Signed-off-by: Victor Kaplansky <address@hidden>
> 
> What's the motivation for doing this? The offset is always 0, and the size 
> must at least match the size of VM memory.

Remote doesn't know the size though, and offset is only there
in the current implementation.

> > 
> > ---
> >  hw/virtio/vhost-user.c    | 11 +++++++++--
> >  tests/vhost-user-test.c   |  8 ++++++++
> >  docs/specs/vhost-user.txt |  8 +++++++-
> >  3 files changed, 24 insertions(+), 3 deletions(-)
> > 
> > diff --git a/hw/virtio/vhost-user.c b/hw/virtio/vhost-user.c
> > index 83c84f1..46c63bc 100644
> > --- a/hw/virtio/vhost-user.c
> > +++ b/hw/virtio/vhost-user.c
> > @@ -75,6 +75,11 @@ typedef struct VhostUserMemory {
> >      VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
> >  } VhostUserMemory;
> >  
> > +typedef struct VhostUserLog {
> > +    uint64_t mmap_size;
> > +    uint64_t mmap_offset;
> > +} VhostUserLog;
> > +
> >  typedef struct VhostUserMsg {
> >      VhostUserRequest request;
> >  
> > @@ -89,6 +94,7 @@ typedef struct VhostUserMsg {
> >          struct vhost_vring_state state;
> >          struct vhost_vring_addr addr;
> >          VhostUserMemory memory;
> > +        VhostUserLog log;
> >      } payload;
> >  } QEMU_PACKED VhostUserMsg;
> >  
> > @@ -200,8 +206,9 @@ static int vhost_user_set_log_base(struct vhost_dev 
> > *dev,
> > uint64_t base,
> >      VhostUserMsg msg = {
> >          .request = VHOST_USER_SET_LOG_BASE,
> >          .flags = VHOST_USER_VERSION,
> > -        .payload.u64 = base,
> > -        .size = sizeof(msg.payload.u64),
> > +        .payload.log.mmap_size = log->size,
> > +        .payload.log.mmap_offset = 0,
> > +        .size = sizeof(msg.payload.log),
> >      };
> >  
> >      if (shmfd && log->fd != -1) {
> > diff --git a/tests/vhost-user-test.c b/tests/vhost-user-test.c
> > index b6dde75..f005ecf 100644
> > --- a/tests/vhost-user-test.c
> > +++ b/tests/vhost-user-test.c
> > @@ -86,6 +86,11 @@ typedef struct VhostUserMemory {
> >      VhostUserMemoryRegion regions[VHOST_MEMORY_MAX_NREGIONS];
> >  } VhostUserMemory;
> >  
> > +typedef struct VhostUserLog {
> > +    uint64_t mmap_size;
> > +    uint64_t mmap_offset;
> > +} VhostUserLog;
> > +
> >  typedef struct VhostUserMsg {
> >      VhostUserRequest request;
> >  
> > @@ -94,10 +99,13 @@ typedef struct VhostUserMsg {
> >      uint32_t flags;
> >      uint32_t size; /* the following payload size */
> >      union {
> > +#define VHOST_USER_VRING_IDX_MASK   (0xff)
> > +#define VHOST_USER_VRING_NOFD_MASK  (0x1<<8)
> >          uint64_t u64;
> >          struct vhost_vring_state state;
> >          struct vhost_vring_addr addr;
> >          VhostUserMemory memory;
> > +        VhostUserLog log;
> >      } payload;
> >  } QEMU_PACKED VhostUserMsg;
> >  
> > diff --git a/docs/specs/vhost-user.txt b/docs/specs/vhost-user.txt
> > index e0d71e2..eb8f2b2 100644
> > --- a/docs/specs/vhost-user.txt
> > +++ b/docs/specs/vhost-user.txt
> > @@ -98,6 +98,7 @@ typedef struct VhostUserMsg {
> >          struct vhost_vring_state state;
> >          struct vhost_vring_addr addr;
> >          VhostUserMemory memory;
> > +        VhostUserLog log;
> >      };
> >  } QEMU_PACKED VhostUserMsg;
> >  
> > @@ -282,7 +283,12 @@ Message types
> >        Master payload: u64
> >        Slave payload: N/A
> >  
> > -      Sets the logging base address.
> > +      Sets logging shared memory space.
> > +      When slave has VHOST_USER_PROTOCOL_F_LOG_SHMFD protocol
> > +      feature, the log memory fd is provided in the ancillary data of
> > +      VHOST_USER_SET_LOG_BASE message, the size and offset of shared
> > +      memory area provided in the message.
> > +
> >  
> >   * VHOST_USER_SET_LOG_FD
> >  
> > --
> > --Victor
> > 



reply via email to

[Prev in Thread] Current Thread [Next in Thread]