Windows: UsbDk: Fix potential buffer overflow
authorChris Dickens <christopher.a.dickens@gmail.com>
Mon, 12 Mar 2018 17:25:02 +0000 (10:25 -0700)
committerChris Dickens <christopher.a.dickens@gmail.com>
Mon, 12 Mar 2018 17:25:02 +0000 (10:25 -0700)
Closes #397

Signed-off-by: Chris Dickens <christopher.a.dickens@gmail.com>
libusb/os/windows_usbdk.c
libusb/version_nano.h

index 135500018ccaf498da3eafd6c2a4e74e98380df7..fbccbd5cffcb7e9af9ba84d799a424f0fbe003ef 100644 (file)
@@ -204,9 +204,9 @@ static void usbdk_exit(struct libusb_context *ctx)
 static int usbdk_get_session_id_for_device(struct libusb_context *ctx,
        PUSB_DK_DEVICE_ID id, unsigned long *session_id)
 {
-       char dev_identity[ARRAYSIZE(id->DeviceID) + ARRAYSIZE(id->InstanceID)];
+       char dev_identity[ARRAYSIZE(id->DeviceID) + ARRAYSIZE(id->InstanceID) + 1];
 
-       if (sprintf(dev_identity, "%S%S", id->DeviceID, id->InstanceID) == -1) {
+       if (snprintf(dev_identity, sizeof(dev_identity), "%S%S", id->DeviceID, id->InstanceID) == -1) {
                usbi_warn(ctx, "cannot form device identity", id->DeviceID);
                return LIBUSB_ERROR_NOT_SUPPORTED;
        }
index 5b295ba2ff830799c919648b2595cd22bab46a82..1adf6357ff420dffd6446a7acf3e90ad24ead79a 100644 (file)
@@ -1 +1 @@
-#define LIBUSB_NANO 11304
+#define LIBUSB_NANO 11305