crypto: sa2ul - Fix memory leak of rxd
[ Upstream commit 854b7737199848a91f6adfa0a03cf6f0c46c86e8 ]
There are two error return paths that are not freeing rxd and causing
memory leaks. Fix these.
Addresses-Coverity: ("Resource leak")
Fixes: 00c9211f60 ("crypto: sa2ul - Fix DMA mapping API usage")
Signed-off-by: Colin Ian King <colin.king@canonical.com>
Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
2c67a9333d
commit
0e596b3734
@@ -1138,8 +1138,10 @@ static int sa_run(struct sa_req *req)
|
||||
mapped_sg->sgt.sgl = src;
|
||||
mapped_sg->sgt.orig_nents = src_nents;
|
||||
ret = dma_map_sgtable(ddev, &mapped_sg->sgt, dir_src, 0);
|
||||
if (ret)
|
||||
if (ret) {
|
||||
kfree(rxd);
|
||||
return ret;
|
||||
}
|
||||
|
||||
mapped_sg->dir = dir_src;
|
||||
mapped_sg->mapped = true;
|
||||
@@ -1147,8 +1149,10 @@ static int sa_run(struct sa_req *req)
|
||||
mapped_sg->sgt.sgl = req->src;
|
||||
mapped_sg->sgt.orig_nents = sg_nents;
|
||||
ret = dma_map_sgtable(ddev, &mapped_sg->sgt, dir_src, 0);
|
||||
if (ret)
|
||||
if (ret) {
|
||||
kfree(rxd);
|
||||
return ret;
|
||||
}
|
||||
|
||||
mapped_sg->dir = dir_src;
|
||||
mapped_sg->mapped = true;
|
||||
|
||||
Reference in New Issue
Block a user