Loading include/linux/sunrpc/xprt.h +1 −1 Original line number Diff line number Diff line Loading @@ -288,7 +288,7 @@ int xprt_reserve_xprt(struct rpc_xprt *xprt, struct rpc_task *task); int xprt_reserve_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task); void xprt_alloc_slot(struct rpc_xprt *xprt, struct rpc_task *task); void xprt_lock_and_alloc_slot(struct rpc_xprt *xprt, struct rpc_task *task); int xprt_prepare_transmit(struct rpc_task *task); bool xprt_prepare_transmit(struct rpc_task *task); void xprt_transmit(struct rpc_task *task); void xprt_end_transmit(struct rpc_task *task); int xprt_adjust_timeout(struct rpc_rqst *req); Loading net/sunrpc/clnt.c +2 −4 Original line number Diff line number Diff line Loading @@ -1722,8 +1722,7 @@ call_transmit(struct rpc_task *task) task->tk_action = call_status; if (task->tk_status < 0) return; task->tk_status = xprt_prepare_transmit(task); if (task->tk_status != 0) if (!xprt_prepare_transmit(task)) return; task->tk_action = call_transmit_status; /* Encode here so that rpcsec_gss can use correct sequence number. */ Loading Loading @@ -1811,8 +1810,7 @@ call_bc_transmit(struct rpc_task *task) { struct rpc_rqst *req = task->tk_rqstp; task->tk_status = xprt_prepare_transmit(task); if (task->tk_status == -EAGAIN) { if (!xprt_prepare_transmit(task)) { /* * Could not reserve the transport. Try again after the * transport is released. Loading net/sunrpc/xprt.c +9 −6 Original line number Diff line number Diff line Loading @@ -864,24 +864,27 @@ static inline int xprt_has_timer(struct rpc_xprt *xprt) * @task: RPC task about to send a request * */ int xprt_prepare_transmit(struct rpc_task *task) bool xprt_prepare_transmit(struct rpc_task *task) { struct rpc_rqst *req = task->tk_rqstp; struct rpc_xprt *xprt = req->rq_xprt; int err = 0; bool ret = false; dprintk("RPC: %5u xprt_prepare_transmit\n", task->tk_pid); spin_lock_bh(&xprt->transport_lock); if (req->rq_reply_bytes_recvd && !req->rq_bytes_sent) { err = req->rq_reply_bytes_recvd; task->tk_status = req->rq_reply_bytes_recvd; goto out_unlock; } if (!xprt->ops->reserve_xprt(xprt, task)) { task->tk_status = -EAGAIN; goto out_unlock; } if (!xprt->ops->reserve_xprt(xprt, task)) err = -EAGAIN; ret = true; out_unlock: spin_unlock_bh(&xprt->transport_lock); return err; return ret; } void xprt_end_transmit(struct rpc_task *task) Loading Loading
include/linux/sunrpc/xprt.h +1 −1 Original line number Diff line number Diff line Loading @@ -288,7 +288,7 @@ int xprt_reserve_xprt(struct rpc_xprt *xprt, struct rpc_task *task); int xprt_reserve_xprt_cong(struct rpc_xprt *xprt, struct rpc_task *task); void xprt_alloc_slot(struct rpc_xprt *xprt, struct rpc_task *task); void xprt_lock_and_alloc_slot(struct rpc_xprt *xprt, struct rpc_task *task); int xprt_prepare_transmit(struct rpc_task *task); bool xprt_prepare_transmit(struct rpc_task *task); void xprt_transmit(struct rpc_task *task); void xprt_end_transmit(struct rpc_task *task); int xprt_adjust_timeout(struct rpc_rqst *req); Loading
net/sunrpc/clnt.c +2 −4 Original line number Diff line number Diff line Loading @@ -1722,8 +1722,7 @@ call_transmit(struct rpc_task *task) task->tk_action = call_status; if (task->tk_status < 0) return; task->tk_status = xprt_prepare_transmit(task); if (task->tk_status != 0) if (!xprt_prepare_transmit(task)) return; task->tk_action = call_transmit_status; /* Encode here so that rpcsec_gss can use correct sequence number. */ Loading Loading @@ -1811,8 +1810,7 @@ call_bc_transmit(struct rpc_task *task) { struct rpc_rqst *req = task->tk_rqstp; task->tk_status = xprt_prepare_transmit(task); if (task->tk_status == -EAGAIN) { if (!xprt_prepare_transmit(task)) { /* * Could not reserve the transport. Try again after the * transport is released. Loading
net/sunrpc/xprt.c +9 −6 Original line number Diff line number Diff line Loading @@ -864,24 +864,27 @@ static inline int xprt_has_timer(struct rpc_xprt *xprt) * @task: RPC task about to send a request * */ int xprt_prepare_transmit(struct rpc_task *task) bool xprt_prepare_transmit(struct rpc_task *task) { struct rpc_rqst *req = task->tk_rqstp; struct rpc_xprt *xprt = req->rq_xprt; int err = 0; bool ret = false; dprintk("RPC: %5u xprt_prepare_transmit\n", task->tk_pid); spin_lock_bh(&xprt->transport_lock); if (req->rq_reply_bytes_recvd && !req->rq_bytes_sent) { err = req->rq_reply_bytes_recvd; task->tk_status = req->rq_reply_bytes_recvd; goto out_unlock; } if (!xprt->ops->reserve_xprt(xprt, task)) { task->tk_status = -EAGAIN; goto out_unlock; } if (!xprt->ops->reserve_xprt(xprt, task)) err = -EAGAIN; ret = true; out_unlock: spin_unlock_bh(&xprt->transport_lock); return err; return ret; } void xprt_end_transmit(struct rpc_task *task) Loading