|
@@ -1315,8 +1315,11 @@ static ssize_t smc_sendpage(struct socket *sock, struct page *page,
|
|
|
|
|
|
smc = smc_sk(sk);
|
|
smc = smc_sk(sk);
|
|
lock_sock(sk);
|
|
lock_sock(sk);
|
|
- if (sk->sk_state != SMC_ACTIVE)
|
|
|
|
|
|
+ if (sk->sk_state != SMC_ACTIVE) {
|
|
|
|
+ release_sock(sk);
|
|
goto out;
|
|
goto out;
|
|
|
|
+ }
|
|
|
|
+ release_sock(sk);
|
|
if (smc->use_fallback)
|
|
if (smc->use_fallback)
|
|
rc = kernel_sendpage(smc->clcsock, page, offset,
|
|
rc = kernel_sendpage(smc->clcsock, page, offset,
|
|
size, flags);
|
|
size, flags);
|
|
@@ -1324,7 +1327,6 @@ static ssize_t smc_sendpage(struct socket *sock, struct page *page,
|
|
rc = sock_no_sendpage(sock, page, offset, size, flags);
|
|
rc = sock_no_sendpage(sock, page, offset, size, flags);
|
|
|
|
|
|
out:
|
|
out:
|
|
- release_sock(sk);
|
|
|
|
return rc;
|
|
return rc;
|
|
}
|
|
}
|
|
|
|
|