netlink: Reset portid after netlink_insert failure
authorHerbert Xu <herbert@gondor.apana.org.au>
Sat, 16 May 2015 13:50:28 +0000 (21:50 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 23 Jun 2015 00:03:20 +0000 (17:03 -0700)
[ Upstream commit c0bb07df7d981e4091432754e30c9c720e2c0c78 ]

The commit c5adde9468b0714a051eac7f9666f23eb10b61f7 ("netlink:
eliminate nl_sk_hash_lock") breaks the autobind retry mechanism
because it doesn't reset portid after a failed netlink_insert.

This means that should autobind fail the first time around, then
the socket will be stuck in limbo as it can never be bound again
since it already has a non-zero portid.

Fixes: c5adde9468b0 ("netlink: eliminate nl_sk_hash_lock")
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
net/netlink/af_netlink.c

index d1d7a8166f469b016d185011c00864e7bbbd4697..e98dc53f30ce097de700154dd9bc827979613962 100644 (file)
@@ -1069,6 +1069,7 @@ static int netlink_insert(struct sock *sk, u32 portid)
        err = 0;
        if (!__netlink_insert(table, sk)) {
                err = -EADDRINUSE;
+               nlk_sk(sk)->portid = 0;
                sock_put(sk);
        }