Skip to content

Commit 9cc4b7c

Browse files
James HughesKalle Valo
authored andcommitted
brcmfmac: Make skb header writable before use
The driver was making changes to the skb_header without ensuring it was writable (i.e. uncloned). This patch also removes some boiler plate header size checking/adjustment code as that is also handled by the skb_cow_header function used to make header writable. Signed-off-by: James Hughes <james.hughes@raspberrypi.org> Acked-by: Arend van Spriel <arend.vanspriel@broadcom.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
1 parent 455a1eb commit 9cc4b7c

File tree

1 file changed

+5
-14
lines changed
  • drivers/net/wireless/broadcom/brcm80211/brcmfmac

1 file changed

+5
-14
lines changed

drivers/net/wireless/broadcom/brcm80211/brcmfmac/core.c

Lines changed: 5 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -210,22 +210,13 @@ static netdev_tx_t brcmf_netdev_start_xmit(struct sk_buff *skb,
210210
goto done;
211211
}
212212

213-
/* Make sure there's enough room for any header */
214-
if (skb_headroom(skb) < drvr->hdrlen) {
215-
struct sk_buff *skb2;
216-
217-
brcmf_dbg(INFO, "%s: insufficient headroom\n",
213+
/* Make sure there's enough writable headroom*/
214+
ret = skb_cow_head(skb, drvr->hdrlen);
215+
if (ret < 0) {
216+
brcmf_err("%s: skb_cow_head failed\n",
218217
brcmf_ifname(ifp));
219-
drvr->bus_if->tx_realloc++;
220-
skb2 = skb_realloc_headroom(skb, drvr->hdrlen);
221218
dev_kfree_skb(skb);
222-
skb = skb2;
223-
if (skb == NULL) {
224-
brcmf_err("%s: skb_realloc_headroom failed\n",
225-
brcmf_ifname(ifp));
226-
ret = -ENOMEM;
227-
goto done;
228-
}
219+
goto done;
229220
}
230221

231222
/* validate length for ether packet */

0 commit comments

Comments
 (0)