Commit 9fc00369 authored by Eric Dumazet's avatar Eric Dumazet Committed by Ben Hutchings

aoe: reserve enough headroom on skbs

[ Upstream commit 91c57464 ]

Some network drivers use a non default hard_header_len

Transmitted skb should take into account dev->hard_header_len, or risk
crashes or expensive reallocations.

In the case of aoe, lets reserve MAX_HEADER bytes.

David reported a crash in defxx driver, solved by this patch.
Reported-by: default avatarDavid Oostdyk <daveo@ll.mit.edu>
Tested-by: default avatarDavid Oostdyk <daveo@ll.mit.edu>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Cc: Ed Cashin <ecashin@coraid.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarBen Hutchings <ben@decadent.org.uk>
parent 905de42d
...@@ -30,8 +30,9 @@ new_skb(ulong len) ...@@ -30,8 +30,9 @@ new_skb(ulong len)
{ {
struct sk_buff *skb; struct sk_buff *skb;
skb = alloc_skb(len, GFP_ATOMIC); skb = alloc_skb(len + MAX_HEADER, GFP_ATOMIC);
if (skb) { if (skb) {
skb_reserve(skb, MAX_HEADER);
skb_reset_mac_header(skb); skb_reset_mac_header(skb);
skb_reset_network_header(skb); skb_reset_network_header(skb);
skb->protocol = __constant_htons(ETH_P_AOE); skb->protocol = __constant_htons(ETH_P_AOE);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment