Commit 59464b26 authored by Trond Myklebust's avatar Trond Myklebust

SUNRPC: SOFTCONN tasks should time out when on the sending list

SOFTCONN tasks need to periodically check if the transport is still
connected, so that they can time out if that is not the case.
Signed-off-by: default avatarTrond Myklebust <trond.myklebust@hammerspace.com>
parent f663507e
...@@ -283,7 +283,7 @@ int xprt_reserve_xprt(struct rpc_xprt *xprt, struct rpc_task *task) ...@@ -283,7 +283,7 @@ int xprt_reserve_xprt(struct rpc_xprt *xprt, struct rpc_task *task)
xprt_clear_locked(xprt); xprt_clear_locked(xprt);
out_sleep: out_sleep:
task->tk_status = -EAGAIN; task->tk_status = -EAGAIN;
if (RPC_IS_SOFT(task)) if (RPC_IS_SOFT(task) || RPC_IS_SOFTCONN(task))
rpc_sleep_on_timeout(&xprt->sending, task, NULL, rpc_sleep_on_timeout(&xprt->sending, task, NULL,
xprt_request_timeout(req)); xprt_request_timeout(req));
else else
...@@ -349,7 +349,7 @@ int xprt_reserve_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task) ...@@ -349,7 +349,7 @@ int xprt_reserve_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task)
xprt_clear_locked(xprt); xprt_clear_locked(xprt);
out_sleep: out_sleep:
task->tk_status = -EAGAIN; task->tk_status = -EAGAIN;
if (RPC_IS_SOFT(task)) if (RPC_IS_SOFT(task) || RPC_IS_SOFTCONN(task))
rpc_sleep_on_timeout(&xprt->sending, task, NULL, rpc_sleep_on_timeout(&xprt->sending, task, NULL,
xprt_request_timeout(req)); xprt_request_timeout(req));
else else
......
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