diff options
-rw-r--r-- | net/smc/af_smc.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/net/smc/af_smc.c b/net/smc/af_smc.c index cea3c36ea0da..47946f489fd4 100644 --- a/net/smc/af_smc.c +++ b/net/smc/af_smc.c | |||
@@ -707,8 +707,6 @@ static int __smc_connect(struct smc_sock *smc) | |||
707 | int smc_type; | 707 | int smc_type; |
708 | int rc = 0; | 708 | int rc = 0; |
709 | 709 | ||
710 | sock_hold(&smc->sk); /* sock put in passive closing */ | ||
711 | |||
712 | if (smc->use_fallback) | 710 | if (smc->use_fallback) |
713 | return smc_connect_fallback(smc, smc->fallback_rsn); | 711 | return smc_connect_fallback(smc, smc->fallback_rsn); |
714 | 712 | ||
@@ -853,6 +851,8 @@ static int smc_connect(struct socket *sock, struct sockaddr *addr, | |||
853 | rc = kernel_connect(smc->clcsock, addr, alen, flags); | 851 | rc = kernel_connect(smc->clcsock, addr, alen, flags); |
854 | if (rc && rc != -EINPROGRESS) | 852 | if (rc && rc != -EINPROGRESS) |
855 | goto out; | 853 | goto out; |
854 | |||
855 | sock_hold(&smc->sk); /* sock put in passive closing */ | ||
856 | if (flags & O_NONBLOCK) { | 856 | if (flags & O_NONBLOCK) { |
857 | if (schedule_work(&smc->connect_work)) | 857 | if (schedule_work(&smc->connect_work)) |
858 | smc->connect_nonblock = 1; | 858 | smc->connect_nonblock = 1; |