[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [PATCH v2 1/2] virtio-9p-device: fix memleak in virtio_9p_device_unr
From: |
Greg Kurz |
Subject: |
Re: [PATCH v2 1/2] virtio-9p-device: fix memleak in virtio_9p_device_unrealize |
Date: |
Mon, 20 Jan 2020 14:24:45 +0100 |
On Fri, 17 Jan 2020 08:43:42 -0500
"Michael S. Tsirkin" <address@hidden> wrote:
> On Fri, Jan 17, 2020 at 01:52:53PM +0100, Christian Schoenebeck wrote:
> > On Freitag, 17. Januar 2020 07:09:26 CET address@hidden wrote:
> > > From: Pan Nengyuan <address@hidden>
> > >
> > > v->vq forgot to cleanup in virtio_9p_device_unrealize, the memory leak
> > > stack is as follow:
> > >
> > > Direct leak of 14336 byte(s) in 2 object(s) allocated from:
> > > #0 0x7f819ae43970 (/lib64/libasan.so.5+0xef970) ??:?
> > > #1 0x7f819872f49d (/lib64/libglib-2.0.so.0+0x5249d) ??:?
> > > #2 0x55a3a58da624 (./x86_64-softmmu/qemu-system-x86_64+0x2c14624)
> > > /mnt/sdb/qemu/hw/virtio/virtio.c:2327 #3 0x55a3a571bac7
> > > (./x86_64-softmmu/qemu-system-x86_64+0x2a55ac7)
> > > /mnt/sdb/qemu/hw/9pfs/virtio-9p-device.c:209 #4 0x55a3a58e7bc6
> > > (./x86_64-softmmu/qemu-system-x86_64+0x2c21bc6)
> > > /mnt/sdb/qemu/hw/virtio/virtio.c:3504 #5 0x55a3a5ebfb37
> > > (./x86_64-softmmu/qemu-system-x86_64+0x31f9b37)
> > > /mnt/sdb/qemu/hw/core/qdev.c:876
> > >
> > > Reported-by: Euler Robot <address@hidden>
> > > Signed-off-by: Pan Nengyuan <address@hidden>
> >
> > Reviewed-by: Christian Schoenebeck <address@hidden>
> >
> > Maybe you could add this patch to your revised PR Greg?
>
> I'm testing all the related virtio changes and they will be
> in my next PR.
>
Thanks Michael.
You can add this tag for the whole series:
Acked-by: Greg Kurz <address@hidden>
> > > ---
> > > Changes V2 to V1:
> > > - use old function virtio_del_queue to make it easier for stable branch
> > > to merge (suggested by Christian Schoenebeck)
> > > ---
> > > hw/9pfs/virtio-9p-device.c | 1 +
> > > 1 file changed, 1 insertion(+)
> > >
> > > diff --git a/hw/9pfs/virtio-9p-device.c b/hw/9pfs/virtio-9p-device.c
> > > index b5a7c03f26..910dc5045e 100644
> > > --- a/hw/9pfs/virtio-9p-device.c
> > > +++ b/hw/9pfs/virtio-9p-device.c
> > > @@ -215,6 +215,7 @@ static void virtio_9p_device_unrealize(DeviceState
> > > *dev,
> > > Error **errp) V9fsVirtioState *v = VIRTIO_9P(dev);
> > > V9fsState *s = &v->state;
> > >
> > > + virtio_del_queue(vdev, 0);
> > > virtio_cleanup(vdev);
> > > v9fs_device_unrealize_common(s, errp);
> > > }
> >
> >
> >
>