12345678910111213141516171819202122232425262728293031323334353637 |
- From: Felix Fietkau <[email protected]>
- Date: Fri, 22 Feb 2019 13:21:15 +0100
- Subject: [PATCH] mac80211: allocate tailroom for forwarded mesh packets
- Forwarded packets enter the tx path through ieee80211_add_pending_skb,
- which skips the ieee80211_skb_resize call.
- Fixes WARN_ON in ccmp_encrypt_skb and resulting packet loss.
- Cc: [email protected]
- Signed-off-by: Felix Fietkau <[email protected]>
- Signed-off-by: Johannes Berg <[email protected]>
- ---
- --- a/net/mac80211/rx.c
- +++ b/net/mac80211/rx.c
- @@ -2598,6 +2598,7 @@ ieee80211_rx_h_mesh_fwding(struct ieee80
- struct ieee80211_sub_if_data *sdata = rx->sdata;
- struct ieee80211_if_mesh *ifmsh = &sdata->u.mesh;
- u16 ac, q, hdrlen;
- + int tailroom = 0;
-
- hdr = (struct ieee80211_hdr *) skb->data;
- hdrlen = ieee80211_hdrlen(hdr->frame_control);
- @@ -2684,8 +2685,12 @@ ieee80211_rx_h_mesh_fwding(struct ieee80
- if (!ifmsh->mshcfg.dot11MeshForwarding)
- goto out;
-
- + if (sdata->crypto_tx_tailroom_needed_cnt)
- + tailroom = IEEE80211_ENCRYPT_TAILROOM;
- +
- fwd_skb = skb_copy_expand(skb, local->tx_headroom +
- - sdata->encrypt_headroom, 0, GFP_ATOMIC);
- + sdata->encrypt_headroom,
- + tailroom, GFP_ATOMIC);
- if (!fwd_skb)
- goto out;
-
|