mac80211: dont orphan TX skb
authorJohannes Berg <johannes.berg@intel.com>
Fri, 7 Oct 2011 12:55:40 +0000 (14:55 +0200)
committerJohn W. Linville <linville@tuxdriver.com>
Tue, 11 Oct 2011 20:41:21 +0000 (16:41 -0400)
This was another workaround for truesize "bugs".
The reason we did this was that when we orphaned
the SKB it wouldn't be truesize-checked later.
Now that the check is gone (and we just charge
the former smaller size to the socket) there's
no longer a reason to orphan the skb here.

Keep the skb charged to the socket until it is
really freed (or orphaned in TX status). This
helps flow control and allows us to get at the
socket later for other purposes.

Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: John W. Linville <linville@tuxdriver.com>
net/mac80211/tx.c

index 6792f52ee886d642ee2aa4506a904cb9dd85b6f6..97ac2c4ce1bf33bf4433e327ea7a2b2e88067067 100644 (file)
@@ -1384,11 +1384,6 @@ static int ieee80211_skb_resize(struct ieee80211_sub_if_data *sdata,
                tail_need = max_t(int, tail_need, 0);
        }
 
-       if (head_need || tail_need) {
-               /* Sorry. Can't account for this any more */
-               skb_orphan(skb);
-       }
-
        if (skb_cloned(skb))
                I802_DEBUG_INC(local->tx_expand_skb_head_cloned);
        else if (head_need || tail_need)