]> git.karo-electronics.de Git - linux-beck.git/commitdiff
media: usb: uvc: make use of new usb_endpoint_maxp_mult()
authorFelipe Balbi <felipe.balbi@linux.intel.com>
Wed, 28 Sep 2016 10:22:53 +0000 (13:22 +0300)
committerFelipe Balbi <felipe.balbi@linux.intel.com>
Tue, 1 Nov 2016 08:17:25 +0000 (10:17 +0200)
We have introduced a helper to calculate multiplier
value from wMaxPacketSize. Start using it.

Acked-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: Mauro Carvalho Chehab <mchehab@kernel.org>
Cc: <linux-media@vger.kernel.org>
Signed-off-by: Felipe Balbi <felipe.balbi@linux.intel.com>
drivers/media/usb/uvc/uvc_video.c

index b5589d5f5da495224f9bbd83717707adc7070b4d..11e0e5f4e1c2e46705fb033cec5613aaa15d7f57 100644 (file)
@@ -1467,6 +1467,7 @@ static unsigned int uvc_endpoint_max_bpi(struct usb_device *dev,
                                         struct usb_host_endpoint *ep)
 {
        u16 psize;
+       u16 mult;
 
        switch (dev->speed) {
        case USB_SPEED_SUPER:
@@ -1474,7 +1475,8 @@ static unsigned int uvc_endpoint_max_bpi(struct usb_device *dev,
                return le16_to_cpu(ep->ss_ep_comp.wBytesPerInterval);
        case USB_SPEED_HIGH:
                psize = usb_endpoint_maxp(&ep->desc);
-               return (psize & 0x07ff) * (1 + ((psize >> 11) & 3));
+               mult = usb_endpoint_maxp_mult(&ep->desc);
+               return (psize & 0x07ff) * mult;
        case USB_SPEED_WIRELESS:
                psize = usb_endpoint_maxp(&ep->desc);
                return psize;