net: Rename and export copy_skb_header
commit 08303c189581c985e60f588ad92a041e46b6e307 upstream. [ jgross@suse.com: added as needed by XSA-403 mitigation ] copy_skb_header is renamed to skb_copy_header and exported. Exposing this function give more flexibility in copying SKBs. skb_copy and skb_copy_expand do not give enough control over which parts are copied. Signed-off-by: Ilya Lesokhin <ilyal@mellanox.com> Signed-off-by: Boris Pismenny <borisp@mellanox.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
bb5584c25b
commit
b0740b251e
@ -975,6 +975,7 @@ static inline struct sk_buff *alloc_skb_head(gfp_t priority)
|
||||
struct sk_buff *skb_morph(struct sk_buff *dst, struct sk_buff *src);
|
||||
int skb_copy_ubufs(struct sk_buff *skb, gfp_t gfp_mask);
|
||||
struct sk_buff *skb_clone(struct sk_buff *skb, gfp_t priority);
|
||||
void skb_copy_header(struct sk_buff *new, const struct sk_buff *old);
|
||||
struct sk_buff *skb_copy(const struct sk_buff *skb, gfp_t priority);
|
||||
struct sk_buff *__pskb_copy_fclone(struct sk_buff *skb, int headroom,
|
||||
gfp_t gfp_mask, bool fclone);
|
||||
|
@ -1071,7 +1071,7 @@ static void skb_headers_offset_update(struct sk_buff *skb, int off)
|
||||
skb->inner_mac_header += off;
|
||||
}
|
||||
|
||||
static void copy_skb_header(struct sk_buff *new, const struct sk_buff *old)
|
||||
void skb_copy_header(struct sk_buff *new, const struct sk_buff *old)
|
||||
{
|
||||
__copy_skb_header(new, old);
|
||||
|
||||
@ -1079,6 +1079,7 @@ static void copy_skb_header(struct sk_buff *new, const struct sk_buff *old)
|
||||
skb_shinfo(new)->gso_segs = skb_shinfo(old)->gso_segs;
|
||||
skb_shinfo(new)->gso_type = skb_shinfo(old)->gso_type;
|
||||
}
|
||||
EXPORT_SYMBOL(skb_copy_header);
|
||||
|
||||
static inline int skb_alloc_rx_flag(const struct sk_buff *skb)
|
||||
{
|
||||
@ -1122,7 +1123,7 @@ struct sk_buff *skb_copy(const struct sk_buff *skb, gfp_t gfp_mask)
|
||||
if (skb_copy_bits(skb, -headerlen, n->head, headerlen + skb->len))
|
||||
BUG();
|
||||
|
||||
copy_skb_header(n, skb);
|
||||
skb_copy_header(n, skb);
|
||||
return n;
|
||||
}
|
||||
EXPORT_SYMBOL(skb_copy);
|
||||
@ -1185,7 +1186,7 @@ struct sk_buff *__pskb_copy_fclone(struct sk_buff *skb, int headroom,
|
||||
skb_clone_fraglist(n);
|
||||
}
|
||||
|
||||
copy_skb_header(n, skb);
|
||||
skb_copy_header(n, skb);
|
||||
out:
|
||||
return n;
|
||||
}
|
||||
@ -1356,7 +1357,7 @@ struct sk_buff *skb_copy_expand(const struct sk_buff *skb,
|
||||
skb->len + head_copy_len))
|
||||
BUG();
|
||||
|
||||
copy_skb_header(n, skb);
|
||||
skb_copy_header(n, skb);
|
||||
|
||||
skb_headers_offset_update(n, newheadroom - oldheadroom);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user