diff options
author | Tom Tucker <tom@opengridcomputing.com> | 2008-04-25 18:08:59 -0500 |
---|---|---|
committer | Tom Tucker <tom@opengridcomputing.com> | 2008-05-19 07:33:47 -0500 |
commit | 5ac461a6f05499fa233ea43b1de80b679d1eec21 (patch) | |
tree | 2c49a3c2338e1bcea424fe2ea99ed373741bbe0c | |
parent | 05a0826a6e6d95ab6e9c3e4a10b58e10f233cc2b (diff) | |
download | op-kernel-dev-5ac461a6f05499fa233ea43b1de80b679d1eec21.zip op-kernel-dev-5ac461a6f05499fa233ea43b1de80b679d1eec21.tar.gz |
svcrdma: Free context on post_recv error in send_reply
If an error is encountered trying to post a recv buffer in send_reply,
free the passed in context. Return an error to the caller so it is
aware that the request was not posted.
Signed-off-by: Tom Tucker <tom@opengridcomputing.com>
-rw-r--r-- | net/sunrpc/xprtrdma/svc_rdma_sendto.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/net/sunrpc/xprtrdma/svc_rdma_sendto.c b/net/sunrpc/xprtrdma/svc_rdma_sendto.c index f61d7bd..fb82b1b 100644 --- a/net/sunrpc/xprtrdma/svc_rdma_sendto.c +++ b/net/sunrpc/xprtrdma/svc_rdma_sendto.c @@ -396,7 +396,8 @@ static int send_reply(struct svcxprt_rdma *rdma, "svcrdma: could not post a receive buffer, err=%d." "Closing transport %p.\n", ret, rdma); set_bit(XPT_CLOSE, &rdma->sc_xprt.xpt_flags); - return 0; + svc_rdma_put_context(ctxt, 0); + return -ENOTCONN; } /* Prepare the context */ |