[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-devel] [PATCH v2 4/9] vhost: alloc shareable log
From: |
Michael S. Tsirkin |
Subject: |
Re: [Qemu-devel] [PATCH v2 4/9] vhost: alloc shareable log |
Date: |
Wed, 29 Jul 2015 20:22:15 +0300 |
On Wed, Jul 29, 2015 at 01:04:51PM -0400, Marc-André Lureau wrote:
> Hi
>
> ----- Original Message -----
> > * Marc-André Lureau (address@hidden) wrote:
> > > If the backend is of type VHOST_BACKEND_TYPE_USER, allocate
> > > shareable memory.
> > >
> > > Note: vhost_log_get() can use a global "vhost_log" that can be shared by
> > > several vhost devices. We may want instead a common shareable log and a
> > > common non-shareable one.
> > >
> > > Signed-off-by: Marc-André Lureau <address@hidden>
> > > ---
> > > hw/virtio/vhost.c | 38 +++++++++++++++++++++++++++++++-------
> > > include/hw/virtio/vhost.h | 3 ++-
> > > 2 files changed, 33 insertions(+), 8 deletions(-)
> > >
> > > diff --git a/hw/virtio/vhost.c b/hw/virtio/vhost.c
> > > index 2712c6f..862e786 100644
> > > --- a/hw/virtio/vhost.c
> > > +++ b/hw/virtio/vhost.c
> > > @@ -18,6 +18,7 @@
> > > #include "qemu/atomic.h"
> > > #include "qemu/range.h"
> > > #include "qemu/error-report.h"
> > > +#include "qemu/memfd.h"
> > > #include <linux/vhost.h>
> > > #include "exec/address-spaces.h"
> > > #include "hw/virtio/virtio-bus.h"
> > > @@ -286,20 +287,34 @@ static uint64_t vhost_get_log_size(struct vhost_dev
> > > *dev)
> > > }
> > > return log_size;
> > > }
> > > -static struct vhost_log *vhost_log_alloc(uint64_t size)
> > > +
> > > +static struct vhost_log *vhost_log_alloc(uint64_t size, bool share)
> > > {
> > > - struct vhost_log *log = g_malloc0(sizeof *log + size *
> > > sizeof(*(log->log)));
> > > + struct vhost_log *log;
> > > + uint64_t logsize = size * sizeof(*(log->log));
> > > + int fd = -1;
> > > +
> > > + log = g_new0(struct vhost_log, 1);
> > > + if (share) {
> > > + log->log = qemu_memfd_alloc("vhost-log", logsize,
> > > +
> > > F_SEAL_GROW|F_SEAL_SHRINK|F_SEAL_SEAL,
> > > &fd);
> > > + memset(log->log, 0, logsize);
> >
> > qemu_memfd_alloc can return NULL can't it - so that needs checking?
> >
> > > + } else {
> > > + log->log = g_malloc0(logsize);
> >
> > I know the old code also used g_malloc0, but if the log isn't 'small'
> > then g_try_malloc0 is possibly safer and properly return errors
> > if it can't be allocated.
>
> Yeah, I agree it's better to check for the return value here (as you pointed
> out, I followed the existing pattern).
>
> Maybe we are just screwed if it happens, live migration shouldn't succeed if
> it can't be done properly imho.
>
> What's your take on this Michael?
>
> cheers
I guess we could fail migration in that case ...
Since current code uses g_malloc0 I feel this can be addressed by
a separate patch later.
--
MST
- [Qemu-devel] [PATCH v2 0/9] vhost-user: add migration log support (for 2.5), Marc-André Lureau, 2015/07/28
- [Qemu-devel] [PATCH v2 5/9] vhost: document log resizing, Marc-André Lureau, 2015/07/28
- [Qemu-devel] [PATCH v2 6/9] vhost: use variable arguments for vhost_call(), Marc-André Lureau, 2015/07/28
- [Qemu-devel] [PATCH v2 7/9] vhost-user: start and end the va_list, Marc-André Lureau, 2015/07/28
- [Qemu-devel] [PATCH v2 8/9] vhost-user: send log shm fd along with log_base, Marc-André Lureau, 2015/07/28
- [Qemu-devel] [PATCH v2 9/9] vhost-user: document migration log, Marc-André Lureau, 2015/07/28