aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMarc-André Lureau <marcandre.lureau@redhat.com>2016-07-15 11:14:07 +0200
committerMarc-André Lureau <marcandre.lureau@redhat.com>2016-08-08 00:00:32 +0400
commitec507f112361ddf6dac0f0a30e84d9da1b4910b6 (patch)
tree70358063d9e32689738fe30bee37234b12d8ace5
parent0137a557aac07480ff8447ef372f0581af5ee65a (diff)
downloadqemu-ec507f112361ddf6dac0f0a30e84d9da1b4910b6.zip
qemu-ec507f112361ddf6dac0f0a30e84d9da1b4910b6.tar.gz
qemu-ec507f112361ddf6dac0f0a30e84d9da1b4910b6.tar.bz2
usb: free USBDevice.strings
The list is created during instance init and further populated with usb_desc_set_string(). Clear it when unrealizing the device. Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Reviewed-by: Gerd Hoffmann <kraxel@redhat.com>
-rw-r--r--hw/usb/bus.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/hw/usb/bus.c b/hw/usb/bus.c
index c28ccb8..25913ad 100644
--- a/hw/usb/bus.c
+++ b/hw/usb/bus.c
@@ -279,6 +279,13 @@ static void usb_qdev_realize(DeviceState *qdev, Error **errp)
static void usb_qdev_unrealize(DeviceState *qdev, Error **errp)
{
USBDevice *dev = USB_DEVICE(qdev);
+ USBDescString *s, *next;
+
+ QLIST_FOREACH_SAFE(s, &dev->strings, next, next) {
+ QLIST_REMOVE(s, next);
+ g_free(s->str);
+ g_free(s);
+ }
if (dev->attached) {
usb_device_detach(dev);