mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 14:43:16 +00:00
[IPSEC]: Move xfrm_state_check into xfrm_output.c
The functions xfrm_state_check and xfrm_state_check_space are only used by the output code in xfrm_output.c so we can move them over. Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
406ef77c89
commit
83815dea47
@ -1013,7 +1013,6 @@ extern void xfrm_spd_getinfo(struct xfrmk_spdinfo *si);
|
|||||||
extern int xfrm_replay_check(struct xfrm_state *x, __be32 seq);
|
extern int xfrm_replay_check(struct xfrm_state *x, __be32 seq);
|
||||||
extern void xfrm_replay_advance(struct xfrm_state *x, __be32 seq);
|
extern void xfrm_replay_advance(struct xfrm_state *x, __be32 seq);
|
||||||
extern void xfrm_replay_notify(struct xfrm_state *x, int event);
|
extern void xfrm_replay_notify(struct xfrm_state *x, int event);
|
||||||
extern int xfrm_state_check(struct xfrm_state *x, struct sk_buff *skb);
|
|
||||||
extern int xfrm_state_mtu(struct xfrm_state *x, int mtu);
|
extern int xfrm_state_mtu(struct xfrm_state *x, int mtu);
|
||||||
extern int xfrm_init_state(struct xfrm_state *x);
|
extern int xfrm_init_state(struct xfrm_state *x);
|
||||||
extern int xfrm_output(struct sk_buff *skb);
|
extern int xfrm_output(struct sk_buff *skb);
|
||||||
|
@ -18,6 +18,28 @@
|
|||||||
#include <net/dst.h>
|
#include <net/dst.h>
|
||||||
#include <net/xfrm.h>
|
#include <net/xfrm.h>
|
||||||
|
|
||||||
|
static int xfrm_state_check_space(struct xfrm_state *x, struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
int nhead = x->props.header_len + LL_RESERVED_SPACE(skb->dst->dev)
|
||||||
|
- skb_headroom(skb);
|
||||||
|
|
||||||
|
if (nhead > 0)
|
||||||
|
return pskb_expand_head(skb, nhead, 0, GFP_ATOMIC);
|
||||||
|
|
||||||
|
/* Check tail too... */
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static int xfrm_state_check(struct xfrm_state *x, struct sk_buff *skb)
|
||||||
|
{
|
||||||
|
int err = xfrm_state_check_expire(x);
|
||||||
|
if (err < 0)
|
||||||
|
goto err;
|
||||||
|
err = xfrm_state_check_space(x, skb);
|
||||||
|
err:
|
||||||
|
return err;
|
||||||
|
}
|
||||||
|
|
||||||
int xfrm_output(struct sk_buff *skb)
|
int xfrm_output(struct sk_buff *skb)
|
||||||
{
|
{
|
||||||
struct dst_entry *dst = skb->dst;
|
struct dst_entry *dst = skb->dst;
|
||||||
|
@ -1152,29 +1152,6 @@ int xfrm_state_check_expire(struct xfrm_state *x)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL(xfrm_state_check_expire);
|
EXPORT_SYMBOL(xfrm_state_check_expire);
|
||||||
|
|
||||||
static int xfrm_state_check_space(struct xfrm_state *x, struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
int nhead = x->props.header_len + LL_RESERVED_SPACE(skb->dst->dev)
|
|
||||||
- skb_headroom(skb);
|
|
||||||
|
|
||||||
if (nhead > 0)
|
|
||||||
return pskb_expand_head(skb, nhead, 0, GFP_ATOMIC);
|
|
||||||
|
|
||||||
/* Check tail too... */
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int xfrm_state_check(struct xfrm_state *x, struct sk_buff *skb)
|
|
||||||
{
|
|
||||||
int err = xfrm_state_check_expire(x);
|
|
||||||
if (err < 0)
|
|
||||||
goto err;
|
|
||||||
err = xfrm_state_check_space(x, skb);
|
|
||||||
err:
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL(xfrm_state_check);
|
|
||||||
|
|
||||||
struct xfrm_state *
|
struct xfrm_state *
|
||||||
xfrm_state_lookup(xfrm_address_t *daddr, __be32 spi, u8 proto,
|
xfrm_state_lookup(xfrm_address_t *daddr, __be32 spi, u8 proto,
|
||||||
unsigned short family)
|
unsigned short family)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user