|
@@ -475,6 +475,14 @@ static void svc_tcp_write_space(struct sock *sk)
|
|
svc_write_space(sk);
|
|
svc_write_space(sk);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+static void svc_tcp_adjust_wspace(struct svc_xprt *xprt)
|
|
|
|
+{
|
|
|
|
+ struct svc_sock *svsk = container_of(xprt, struct svc_sock, sk_xprt);
|
|
|
|
+
|
|
|
|
+ if (svc_tcp_has_wspace(xprt))
|
|
|
|
+ clear_bit(SOCK_NOSPACE, &svsk->sk_sock->flags);
|
|
|
|
+}
|
|
|
|
+
|
|
/*
|
|
/*
|
|
* See net/ipv6/ip_sockglue.c : ip_cmsg_recv_pktinfo
|
|
* See net/ipv6/ip_sockglue.c : ip_cmsg_recv_pktinfo
|
|
*/
|
|
*/
|
|
@@ -1289,6 +1297,7 @@ static struct svc_xprt_ops svc_tcp_ops = {
|
|
.xpo_has_wspace = svc_tcp_has_wspace,
|
|
.xpo_has_wspace = svc_tcp_has_wspace,
|
|
.xpo_accept = svc_tcp_accept,
|
|
.xpo_accept = svc_tcp_accept,
|
|
.xpo_secure_port = svc_sock_secure_port,
|
|
.xpo_secure_port = svc_sock_secure_port,
|
|
|
|
+ .xpo_adjust_wspace = svc_tcp_adjust_wspace,
|
|
};
|
|
};
|
|
|
|
|
|
static struct svc_xprt_class svc_tcp_class = {
|
|
static struct svc_xprt_class svc_tcp_class = {
|