summaryrefslogtreecommitdiffstats
path: root/drivers/usb/storage
diff options
context:
space:
mode:
authorHans de Goede <hdegoede@redhat.com>2013-10-29 09:06:54 +0100
committerSarah Sharp <sarah.a.sharp@linux.intel.com>2014-03-05 00:38:18 +0100
commitd495c1baa1b3ba277bb5ae24adeab0600151cba4 (patch)
treea6e6865ef95dfdbc41be9241939de1a969d3b552 /drivers/usb/storage
parentuas: Add uas_find_endpoints() helper function (diff)
downloadlinux-d495c1baa1b3ba277bb5ae24adeab0600151cba4.tar.xz
linux-d495c1baa1b3ba277bb5ae24adeab0600151cba4.zip
uas: Fix bounds check in uas_find_endpoints
The loop uses up to 3 bytes of the endpoint extra data. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Sarah Sharp <sarah.a.sharp@linux.intel.com>
Diffstat (limited to 'drivers/usb/storage')
-rw-r--r--drivers/usb/storage/uas.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/usb/storage/uas.c b/drivers/usb/storage/uas.c
index 1ac66f290fbf..7662b3e13c4d 100644
--- a/drivers/usb/storage/uas.c
+++ b/drivers/usb/storage/uas.c
@@ -907,7 +907,7 @@ static int uas_find_endpoints(struct usb_host_interface *alt,
for (i = 0; i < n_endpoints; i++) {
unsigned char *extra = endpoint[i].extra;
int len = endpoint[i].extralen;
- while (len > 1) {
+ while (len >= 3) {
if (extra[1] == USB_DT_PIPE_USAGE) {
unsigned pipe_id = extra[2];
if (pipe_id > 0 && pipe_id < 5)