af_key: mark policy as dead before destroying
authorAlexey Dobriyan <adobriyan@gmail.com>
Fri, 7 Nov 2008 07:08:37 +0000 (23:08 -0800)
committerDavid S. Miller <davem@davemloft.net>
Fri, 7 Nov 2008 07:08:37 +0000 (23:08 -0800)
xfrm_policy_destroy() will oops if not dead policy is passed to it.
On error path in pfkey_compile_policy() exactly this happens.

Oopsable for CAP_NET_ADMIN owners.

Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/key/af_key.c

index 3440a46..5b22e01 100644 (file)
@@ -3188,6 +3188,7 @@ static struct xfrm_policy *pfkey_compile_policy(struct sock *sk, int opt,
        return xp;
 
 out:
+       xp->walk.dead = 1;
        xfrm_policy_destroy(xp);
        return NULL;
 }