mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
xfrm: force a garbage collection after deleting a policy
In some cases after deleting a policy from the SPD the policy would remain in the dst/flow/route cache for an extended period of time which caused problems for SELinux as its dynamic network access controls key off of the number of XFRM policy and state entries. This patch corrects this problem by forcing a XFRM garbage collection whenever a policy is sucessfully removed. Reported-by: Ondrej Moris <omoris@redhat.com> Signed-off-by: Paul Moore <pmoore@redhat.com> Signed-off-by: David S. Miller <davem@davemloft.net> Change-Id: I1aae89f15a467a7661caec89edfef21aa639b852
This commit is contained in:
parent
50bb785569
commit
a664edd900
4 changed files with 13 additions and 1 deletions
|
@ -1157,6 +1157,8 @@ static inline void xfrm_sk_free_policy(struct sock *sk)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
extern void xfrm_garbage_collect(struct net *net);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
static inline void xfrm_sk_free_policy(struct sock *sk) {}
|
static inline void xfrm_sk_free_policy(struct sock *sk) {}
|
||||||
|
@ -1191,6 +1193,9 @@ static inline int xfrm6_policy_check_reverse(struct sock *sk, int dir,
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
static inline void xfrm_garbage_collect(struct net *net)
|
||||||
|
{
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static __inline__
|
static __inline__
|
||||||
|
|
|
@ -2367,6 +2367,8 @@ static int pfkey_spddelete(struct sock *sk, struct sk_buff *skb, const struct sa
|
||||||
|
|
||||||
out:
|
out:
|
||||||
xfrm_pol_put(xp);
|
xfrm_pol_put(xp);
|
||||||
|
if (err == 0)
|
||||||
|
xfrm_garbage_collect(net);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2616,6 +2618,8 @@ static int pfkey_spdget(struct sock *sk, struct sk_buff *skb, const struct sadb_
|
||||||
|
|
||||||
out:
|
out:
|
||||||
xfrm_pol_put(xp);
|
xfrm_pol_put(xp);
|
||||||
|
if (delete && err == 0)
|
||||||
|
xfrm_garbage_collect(net);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -2543,11 +2543,12 @@ static void __xfrm_garbage_collect(struct net *net)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static void xfrm_garbage_collect(struct net *net)
|
void xfrm_garbage_collect(struct net *net)
|
||||||
{
|
{
|
||||||
flow_cache_flush();
|
flow_cache_flush();
|
||||||
__xfrm_garbage_collect(net);
|
__xfrm_garbage_collect(net);
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL(xfrm_garbage_collect);
|
||||||
|
|
||||||
static void xfrm_garbage_collect_deferred(struct net *net)
|
static void xfrm_garbage_collect_deferred(struct net *net)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1688,6 +1688,8 @@ static int xfrm_get_policy(struct sk_buff *skb, struct nlmsghdr *nlh,
|
||||||
|
|
||||||
out:
|
out:
|
||||||
xfrm_pol_put(xp);
|
xfrm_pol_put(xp);
|
||||||
|
if (delete && err == 0)
|
||||||
|
xfrm_garbage_collect(net);
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue