diff options
author | Nathan Sullivan <nathan.sullivan@ni.com> | 2014-07-07 10:50:14 -0400 |
---|---|---|
committer | Felipe Balbi <balbi@ti.com> | 2014-07-10 09:45:32 -0400 |
commit | d82aa8aeb0eaa06bad80860a95ca5fdff84e8775 (patch) | |
tree | 5665b867813a66ea58db3be33d2e1a47435f9990 /drivers/usb | |
parent | 029d97ff543219762685805e15d71f7005ad7c5e (diff) |
usb: gadget: fix eem_wrap cloned skb logic
Even if the skb is cloned, we still need a ZLP or USB will stall.
Signed-off-by: Nathan Sullivan <nathan.sullivan@ni.com>
Acked-by: Brad Mouring <brad.mouring@ni.com>
Signed-off-by: Felipe Balbi <balbi@ti.com>
Diffstat (limited to 'drivers/usb')
-rw-r--r-- | drivers/usb/gadget/f_eem.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/drivers/usb/gadget/f_eem.c b/drivers/usb/gadget/f_eem.c index d61c11d765d0..4d8b236ea608 100644 --- a/drivers/usb/gadget/f_eem.c +++ b/drivers/usb/gadget/f_eem.c | |||
@@ -355,20 +355,18 @@ static struct sk_buff *eem_wrap(struct gether *port, struct sk_buff *skb) | |||
355 | int padlen = 0; | 355 | int padlen = 0; |
356 | u16 len = skb->len; | 356 | u16 len = skb->len; |
357 | 357 | ||
358 | if (!skb_cloned(skb)) { | 358 | int headroom = skb_headroom(skb); |
359 | int headroom = skb_headroom(skb); | 359 | int tailroom = skb_tailroom(skb); |
360 | int tailroom = skb_tailroom(skb); | ||
361 | 360 | ||
362 | /* When (len + EEM_HLEN + ETH_FCS_LEN) % in->maxpacket) is 0, | 361 | /* When (len + EEM_HLEN + ETH_FCS_LEN) % in->maxpacket) is 0, |
363 | * stick two bytes of zero-length EEM packet on the end. | 362 | * stick two bytes of zero-length EEM packet on the end. |
364 | */ | 363 | */ |
365 | if (((len + EEM_HLEN + ETH_FCS_LEN) % in->maxpacket) == 0) | 364 | if (((len + EEM_HLEN + ETH_FCS_LEN) % in->maxpacket) == 0) |
366 | padlen += 2; | 365 | padlen += 2; |
367 | 366 | ||
368 | if ((tailroom >= (ETH_FCS_LEN + padlen)) && | 367 | if ((tailroom >= (ETH_FCS_LEN + padlen)) && |
369 | (headroom >= EEM_HLEN)) | 368 | (headroom >= EEM_HLEN) && !skb_cloned(skb)) |
370 | goto done; | 369 | goto done; |
371 | } | ||
372 | 370 | ||
373 | skb2 = skb_copy_expand(skb, EEM_HLEN, ETH_FCS_LEN + padlen, GFP_ATOMIC); | 371 | skb2 = skb_copy_expand(skb, EEM_HLEN, ETH_FCS_LEN + padlen, GFP_ATOMIC); |
374 | dev_kfree_skb_any(skb); | 372 | dev_kfree_skb_any(skb); |