Commit d275880a authored by Trond Myklebust's avatar Trond Myklebust

SUNRPC: Fix Oops in xs_tcp_send_request() when transport is disconnected

If a disconnection occurs while we're trying to reply to a server
callback, then we may end up calling xs_tcp_send_request() with a NULL
value for transport->inet, which trips up the call to
tcp_sock_set_cork().

Fixes: d737e5d4 ("SUNRPC: Set TCP_CORK until the transmit queue is empty")
Cc: stable@vger.kernel.org
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent a421d218
...@@ -1010,6 +1010,8 @@ static int xs_tcp_send_request(struct rpc_rqst *req) ...@@ -1010,6 +1010,8 @@ static int xs_tcp_send_request(struct rpc_rqst *req)
kernel_sock_shutdown(transport->sock, SHUT_RDWR); kernel_sock_shutdown(transport->sock, SHUT_RDWR);
return -ENOTCONN; return -ENOTCONN;
} }
if (!transport->inet)
return -ENOTCONN;
xs_pktdump("packet data:", xs_pktdump("packet data:",
req->rq_svec->iov_base, req->rq_svec->iov_base,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment