Browse Source

svcrdma: Free context on ib_post_recv error

If there is an error posting the recv WR to the RQ, free the
context associated with the WR. This would leak a context when
asynchronous errors occurred on the transport while conccurent threads
were processing their RPC.

Signed-off-by: Tom Tucker <tom@opengridcomputing.com>
Tom Tucker 17 years ago
parent
commit
05a0826a6e
1 changed files with 2 additions and 0 deletions
  1. 2 0
      net/sunrpc/xprtrdma/svc_rdma_transport.c

+ 2 - 0
net/sunrpc/xprtrdma/svc_rdma_transport.c

@@ -524,6 +524,8 @@ int svc_rdma_post_recv(struct svcxprt_rdma *xprt)
 	recv_wr.wr_id = (u64)(unsigned long)ctxt;
 	recv_wr.wr_id = (u64)(unsigned long)ctxt;
 
 
 	ret = ib_post_recv(xprt->sc_qp, &recv_wr, &bad_recv_wr);
 	ret = ib_post_recv(xprt->sc_qp, &recv_wr, &bad_recv_wr);
+	if (ret)
+		svc_rdma_put_context(ctxt, 1);
 	return ret;
 	return ret;
 }
 }