]> git.proxmox.com Git - mirror_qemu.git/commitdiff
usb: fix unbound stack usage for usb_mtp_add_str
authorPeter Xu <peterx@redhat.com>
Thu, 10 Mar 2016 02:35:24 +0000 (10:35 +0800)
committerGerd Hoffmann <kraxel@redhat.com>
Fri, 18 Mar 2016 12:55:16 +0000 (13:55 +0100)
Use heap instead of stack.

Signed-off-by: Peter Xu <peterx@redhat.com>
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/usb/dev-mtp.c

index 7391783193a0e8c0f04b82b9ff9800b2fa8da715..62fb7cd51810601355960ee099a187066cad831d 100644 (file)
@@ -718,7 +718,7 @@ static void usb_mtp_add_wstr(MTPData *data, const wchar_t *str)
 static void usb_mtp_add_str(MTPData *data, const char *str)
 {
     uint32_t len = strlen(str)+1;
-    wchar_t wstr[len];
+    wchar_t *wstr = g_new(wchar_t, len);
     size_t ret;
 
     ret = mbstowcs(wstr, str, len);
@@ -727,6 +727,8 @@ static void usb_mtp_add_str(MTPData *data, const char *str)
     } else {
         usb_mtp_add_wstr(data, wstr);
     }
+
+    g_free(wstr);
 }
 
 static void usb_mtp_add_time(MTPData *data, time_t time)