From 5c105d9f3fd086aff195d3849dcf847d6b0bd927 Mon Sep 17 00:00:00 2001 From: blogic Date: Fri, 5 Oct 2012 10:12:53 +0000 Subject: branch Attitude Adjustment git-svn-id: svn://svn.openwrt.org/openwrt/branches/attitude_adjustment@33625 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- .../patches-3.3/654-avoid_skb_cow_realloc.patch | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) create mode 100644 target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch (limited to 'target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch') diff --git a/target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch b/target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch new file mode 100644 index 000000000..5b2537127 --- /dev/null +++ b/target/linux/generic/patches-3.3/654-avoid_skb_cow_realloc.patch @@ -0,0 +1,21 @@ +--- a/include/linux/skbuff.h ++++ b/include/linux/skbuff.h +@@ -1850,12 +1850,15 @@ static inline int skb_clone_writable(con + static inline int __skb_cow(struct sk_buff *skb, unsigned int headroom, + int cloned) + { ++ unsigned int alloc_headroom = headroom; + int delta = 0; + + if (headroom < NET_SKB_PAD) +- headroom = NET_SKB_PAD; +- if (headroom > skb_headroom(skb)) +- delta = headroom - skb_headroom(skb); ++ alloc_headroom = NET_SKB_PAD; ++ if (headroom > skb_headroom(skb) || ++ (cloned && alloc_headroom > skb_headroom(skb))) { ++ delta = alloc_headroom - skb_headroom(skb); ++ } + + if (delta || cloned) + return pskb_expand_head(skb, ALIGN(delta, NET_SKB_PAD), 0, -- cgit v1.2.3