]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
crypto: af_alg - Allow af_af_alg_release_parent to be called on nokey path
authorHerbert Xu <herbert@gondor.apana.org.au>
Wed, 13 Jan 2016 06:59:03 +0000 (14:59 +0800)
committerLuis Henriques <luis.henriques@canonical.com>
Tue, 2 Feb 2016 19:09:56 +0000 (19:09 +0000)
commit 6a935170a980024dd29199e9dbb5c4da4767a1b9 upstream.

This patch allows af_alg_release_parent to be called even for
nokey sockets.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Luis Henriques <luis.henriques@canonical.com>
crypto/af_alg.c
include/crypto/if_alg.h

index afe3dad23f08beb09b75be1185e0be375fe4370e..d86ef339d8cb7ac4102fb1d32e4211c24850b39c 100644 (file)
@@ -133,6 +133,12 @@ void af_alg_release_parent(struct sock *sk)
        bool last;
 
        sk = ask->parent;
+
+       if (ask->nokey_refcnt && !ask->refcnt) {
+               sock_put(sk);
+               return;
+       }
+
        ask = alg_sk(sk);
 
        lock_sock(sk);
@@ -258,8 +264,8 @@ int af_alg_accept(struct sock *sk, struct socket *newsock)
        struct alg_sock *ask = alg_sk(sk);
        const struct af_alg_type *type;
        struct sock *sk2;
+       unsigned int nokey;
        int err;
-       bool nokey;
 
        lock_sock(sk);
        type = ask->type;
@@ -292,6 +298,7 @@ int af_alg_accept(struct sock *sk, struct socket *newsock)
                sock_hold(sk);
        alg_sk(sk2)->parent = sk;
        alg_sk(sk2)->type = type;
+       alg_sk(sk2)->nokey_refcnt = nokey;
 
        newsock->ops = type->ops;
        newsock->state = SS_CONNECTED;
index 9e6a2f38c52f6b3eb75db2bc15570b6c5b0aa2f5..bfefd8139e18fedb65b39d68305f1dd9c70f419a 100644 (file)
@@ -31,6 +31,7 @@ struct alg_sock {
        struct sock *parent;
 
        unsigned int refcnt;
+       unsigned int nokey_refcnt;
 
        const struct af_alg_type *type;
        void *private;