summaryrefslogtreecommitdiffstats
path: root/net/xfrm
diff options
context:
space:
mode:
authorFlorian Westphal <fw@strlen.de>2017-12-11 18:23:09 +0100
committerSteffen Klassert <steffen.klassert@secunet.com>2017-12-12 06:39:05 +0100
commitd2950278d2d04ff5314abeb38d9c59c4e7c0ee53 (patch)
tree9c9313f9c950711842fa6a2dc0d0745d831ac575 /net/xfrm
parent732706afe1cc46ef48493b3d2b69c98f36314ae4 (diff)
downloadop-kernel-dev-d2950278d2d04ff5314abeb38d9c59c4e7c0ee53.zip
op-kernel-dev-d2950278d2d04ff5314abeb38d9c59c4e7c0ee53.tar.gz
xfrm: put policies when reusing pcpu xdst entry
We need to put the policies when re-using the pcpu xdst entry, else this leaks the reference. Fixes: ec30d78c14a813db39a647b6a348b428 ("xfrm: add xdst pcpu cache") Signed-off-by: Florian Westphal <fw@strlen.de> Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
Diffstat (limited to 'net/xfrm')
-rw-r--r--net/xfrm/xfrm_policy.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/net/xfrm/xfrm_policy.c b/net/xfrm/xfrm_policy.c
index 038ec68..70aa5cb 100644
--- a/net/xfrm/xfrm_policy.c
+++ b/net/xfrm/xfrm_policy.c
@@ -1839,6 +1839,7 @@ xfrm_resolve_and_create_bundle(struct xfrm_policy **pols, int num_pols,
sizeof(struct xfrm_policy *) * num_pols) == 0 &&
xfrm_xdst_can_reuse(xdst, xfrm, err)) {
dst_hold(&xdst->u.dst);
+ xfrm_pols_put(pols, num_pols);
while (err > 0)
xfrm_state_put(xfrm[--err]);
return xdst;
OpenPOWER on IntegriCloud