From: Bjørn Mork Date: Mon, 16 Jan 2012 14:11:59 +0000 (+0100) Subject: USB: cdc-wdm: better allocate a buffer that is at least as big as we tell the USB... X-Git-Tag: firefly_0821_release~3680^2~3608^2~15 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=655e247daf52b202a6c2d0f8a06dd2051e756ce4;p=firefly-linux-kernel-4.4.55.git USB: cdc-wdm: better allocate a buffer that is at least as big as we tell the USB core As it turns out, there was a mismatch between the allocated inbuf size (desc->bMaxPacketSize0, typically something like 64) and the length we specified in the URB (desc->wMaxCommand, typically something like 2048) Signed-off-by: Bjørn Mork Cc: Oliver Neukum Cc: stable Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/usb/class/cdc-wdm.c b/drivers/usb/class/cdc-wdm.c index 07aa67611b65..a940ad9d0d8f 100644 --- a/drivers/usb/class/cdc-wdm.c +++ b/drivers/usb/class/cdc-wdm.c @@ -723,7 +723,7 @@ next_desc: goto err; desc->inbuf = usb_alloc_coherent(interface_to_usbdev(intf), - desc->bMaxPacketSize0, + desc->wMaxCommand, GFP_KERNEL, &desc->response->transfer_dma); if (!desc->inbuf)