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)
committerDavid S. Miller <davem@davemloft.net>
Sat, 16 May 2015 21:08:57 +0000 (17:08 -0400)
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>
net/netlink/af_netlink.c

index dbe885901b34b98134f03d78bc181ef30d8b0322..bf6e76643f7876d8dee4df261baf077aad837be3 100644 (file)
@@ -1081,6 +1081,7 @@ static int netlink_insert(struct sock *sk, u32 portid)
        if (err) {
                if (err == -EEXIST)
                        err = -EADDRINUSE;
+               nlk_sk(sk)->portid = 0;
                sock_put(sk);
        }