diff options
Diffstat (limited to 'drivers/usb/misc/usbtest.c')
-rw-r--r-- | drivers/usb/misc/usbtest.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/usb/misc/usbtest.c b/drivers/usb/misc/usbtest.c index eee82ca55b7b..b3fc602b2e24 100644 --- a/drivers/usb/misc/usbtest.c +++ b/drivers/usb/misc/usbtest.c | |||
@@ -202,12 +202,13 @@ found: | |||
202 | return tmp; | 202 | return tmp; |
203 | } | 203 | } |
204 | 204 | ||
205 | if (in) { | 205 | if (in) |
206 | dev->in_pipe = usb_rcvbulkpipe(udev, | 206 | dev->in_pipe = usb_rcvbulkpipe(udev, |
207 | in->desc.bEndpointAddress & USB_ENDPOINT_NUMBER_MASK); | 207 | in->desc.bEndpointAddress & USB_ENDPOINT_NUMBER_MASK); |
208 | if (out) | ||
208 | dev->out_pipe = usb_sndbulkpipe(udev, | 209 | dev->out_pipe = usb_sndbulkpipe(udev, |
209 | out->desc.bEndpointAddress & USB_ENDPOINT_NUMBER_MASK); | 210 | out->desc.bEndpointAddress & USB_ENDPOINT_NUMBER_MASK); |
210 | } | 211 | |
211 | if (iso_in) { | 212 | if (iso_in) { |
212 | dev->iso_in = &iso_in->desc; | 213 | dev->iso_in = &iso_in->desc; |
213 | dev->in_iso_pipe = usb_rcvisocpipe(udev, | 214 | dev->in_iso_pipe = usb_rcvisocpipe(udev, |
@@ -1964,6 +1965,9 @@ test_queue(struct usbtest_dev *dev, struct usbtest_param_32 *param, | |||
1964 | int status = 0; | 1965 | int status = 0; |
1965 | struct urb *urbs[param->sglen]; | 1966 | struct urb *urbs[param->sglen]; |
1966 | 1967 | ||
1968 | if (!param->sglen || param->iterations > UINT_MAX / param->sglen) | ||
1969 | return -EINVAL; | ||
1970 | |||
1967 | memset(&context, 0, sizeof(context)); | 1971 | memset(&context, 0, sizeof(context)); |
1968 | context.count = param->iterations * param->sglen; | 1972 | context.count = param->iterations * param->sglen; |
1969 | context.dev = dev; | 1973 | context.dev = dev; |
@@ -2087,6 +2091,8 @@ usbtest_do_ioctl(struct usb_interface *intf, struct usbtest_param_32 *param) | |||
2087 | 2091 | ||
2088 | if (param->iterations <= 0) | 2092 | if (param->iterations <= 0) |
2089 | return -EINVAL; | 2093 | return -EINVAL; |
2094 | if (param->sglen > MAX_SGLEN) | ||
2095 | return -EINVAL; | ||
2090 | /* | 2096 | /* |
2091 | * Just a bunch of test cases that every HCD is expected to handle. | 2097 | * Just a bunch of test cases that every HCD is expected to handle. |
2092 | * | 2098 | * |