xprtrdma: Fix regbuf data not freed in rpcrdma_req_create()
[ Upstream commit 9181f40fb2952fd59ecb75e7158620c9c669eee3 ]
If rdma receive buffer allocate failed, should call rpcrdma_regbuf_free()
to free the send buffer, otherwise, the buffer data will be leaked.
Fixes: bb93a1ae2b
("xprtrdma: Allocate req's regbufs at xprt create time")
Signed-off-by: Zhang Xiaoxu <zhangxiaoxu5@huawei.com>
Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:

committed by
Greg Kroah-Hartman

parent
0649129359
commit
be7d90fc3a
@@ -866,7 +866,7 @@ struct rpcrdma_req *rpcrdma_req_create(struct rpcrdma_xprt *r_xprt, size_t size,
|
|||||||
return req;
|
return req;
|
||||||
|
|
||||||
out3:
|
out3:
|
||||||
kfree(req->rl_sendbuf);
|
rpcrdma_regbuf_free(req->rl_sendbuf);
|
||||||
out2:
|
out2:
|
||||||
kfree(req);
|
kfree(req);
|
||||||
out1:
|
out1:
|
||||||
|
Reference in New Issue
Block a user