summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--net/smc/af_smc.c4
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;