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>
This commit is contained in:
Nathan Sullivan 2014-07-07 09:50:14 -05:00 committed by Felipe Balbi
parent 029d97ff54
commit d82aa8aeb0
1 changed files with 10 additions and 12 deletions

View File

@ -355,7 +355,6 @@ static struct sk_buff *eem_wrap(struct gether *port, struct sk_buff *skb)
int padlen = 0; int padlen = 0;
u16 len = skb->len; u16 len = skb->len;
if (!skb_cloned(skb)) {
int headroom = skb_headroom(skb); int headroom = skb_headroom(skb);
int tailroom = skb_tailroom(skb); int tailroom = skb_tailroom(skb);
@ -366,9 +365,8 @@ static struct sk_buff *eem_wrap(struct gether *port, struct sk_buff *skb)
padlen += 2; padlen += 2;
if ((tailroom >= (ETH_FCS_LEN + padlen)) && if ((tailroom >= (ETH_FCS_LEN + padlen)) &&
(headroom >= EEM_HLEN)) (headroom >= EEM_HLEN) && !skb_cloned(skb))
goto done; goto done;
}
skb2 = skb_copy_expand(skb, EEM_HLEN, ETH_FCS_LEN + padlen, GFP_ATOMIC); skb2 = skb_copy_expand(skb, EEM_HLEN, ETH_FCS_LEN + padlen, GFP_ATOMIC);
dev_kfree_skb_any(skb); dev_kfree_skb_any(skb);