aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorHerbert Xu <herbert@gondor.apana.org.au>2007-09-16 19:21:16 -0400
committerDavid S. Miller <davem@davemloft.net>2007-09-16 19:21:16 -0400
commitd9cc20484e5e48c6a5deb4387c20fd45bfbdde8c (patch)
treef0a9f05ad00b8a506abeb3b42cb3346cef7d2155 /drivers/net
parente081e1e3ef4682802ac63b1e5e26158fb9ca9e90 (diff)
[NET] skbuff: Add skb_cow_head
This patch adds an optimised version of skb_cow that avoids the copy if the header can be modified even if the rest of the payload is cloned. This can be used in encapsulating paths where we only need to modify the header. As it is, this can be used in PPPOE and bridging. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/pppoe.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/net/pppoe.c b/drivers/net/pppoe.c
index bac36546e0bf..0d7f570b9a54 100644
--- a/drivers/net/pppoe.c
+++ b/drivers/net/pppoe.c
@@ -860,7 +860,7 @@ static int __pppoe_xmit(struct sock *sk, struct sk_buff *skb)
860 /* Copy the data if there is no space for the header or if it's 860 /* Copy the data if there is no space for the header or if it's
861 * read-only. 861 * read-only.
862 */ 862 */
863 if (skb_cow(skb, sizeof(*ph) + dev->hard_header_len)) 863 if (skb_cow_head(skb, sizeof(*ph) + dev->hard_header_len))
864 goto abort; 864 goto abort;
865 865
866 __skb_push(skb, sizeof(*ph)); 866 __skb_push(skb, sizeof(*ph));