]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
usb: ehci: fix memory leak in ehci_init_transfer
authorLi Qiang <liqiang6-s@360.cn>
Tue, 8 Nov 2016 12:11:10 +0000 (04:11 -0800)
committerStefan Hajnoczi <stefanha@redhat.com>
Thu, 10 Nov 2016 15:29:58 +0000 (15:29 +0000)
In ehci_init_transfer function, if the 'cpage' is bigger than 4,
it doesn't free the 'p->sgl' once allocated previously thus leading
a memory leak issue. This patch avoid this.

Signed-off-by: Li Qiang <liqiang6-s@360.cn>
Message-id: 5821c0f4.091c6b0a.e0c92.e811@mx.google.com
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/usb/hcd-ehci.c

index f4ece9abed985ebfd883630855944aedfd98c6d7..7622a3ae7250c7eacd7f08427f0df8c40720f3de 100644 (file)
@@ -1190,6 +1190,7 @@ static int ehci_init_transfer(EHCIPacket *p)
     while (bytes > 0) {
         if (cpage > 4) {
             fprintf(stderr, "cpage out of range (%d)\n", cpage);
+            qemu_sglist_destroy(&p->sgl);
             return -1;
         }