On Sun, Nov 13, 2016 at 01:31:16PM +0300, Mike Krinkin wrote: > Since usb_endpoint_maxp now returns only lower 11 bits mult > calculation here isn't correct anymore and that breaks webcam > for me. Patch make use of usb_endpoint_maxp_mult instead of > direct calculation. > > Fixes: abb621844f6a ("usb: ch9: make usb_endpoint_maxp() return > only packet size") > > Signed-off-by: Mike Krinkin <krinkin.m.u@xxxxxxxxx> > --- > drivers/usb/core/urb.c | 7 ++----- > 1 file changed, 2 insertions(+), 5 deletions(-) > > diff --git a/drivers/usb/core/urb.c b/drivers/usb/core/urb.c > index 0be49a1..d75cb8c 100644 > --- a/drivers/usb/core/urb.c > +++ b/drivers/usb/core/urb.c > @@ -412,11 +412,8 @@ int usb_submit_urb(struct urb *urb, gfp_t mem_flags) > } > > /* "high bandwidth" mode, 1-3 packets/uframe? */ > - if (dev->speed == USB_SPEED_HIGH) { > - int mult = 1 + ((max >> 11) & 0x03); > - max &= 0x07ff; > - max *= mult; > - } > + if (dev->speed == USB_SPEED_HIGH) > + max *= usb_endpoint_maxp_mult(&ep->desc); > > if (urb->number_of_packets <= 0) > return -EINVAL; Felipe, this looks like it belongs in your tree... -- To unsubscribe from this list: send the line "unsubscribe linux-usb" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html