summaryrefslogtreecommitdiff
path: root/drivers/crypto/allwinner/sun8i-ss
diff options
context:
space:
mode:
authorColin Ian King <colin.king@canonical.com>2021-04-01 16:18:27 +0100
committerHerbert Xu <herbert@gondor.apana.org.au>2021-04-09 17:45:13 +1000
commit50274b01ac1689b1a3f6bc4b5b3dbf361a55dd3a (patch)
tree6a4e3f53cb5a74a25631cfb60511ac3f70b5083b /drivers/crypto/allwinner/sun8i-ss
parent3d8c5f5a08c39835a365c69d1a6d9518722ed19e (diff)
downloadlwn-50274b01ac1689b1a3f6bc4b5b3dbf361a55dd3a.tar.gz
lwn-50274b01ac1689b1a3f6bc4b5b3dbf361a55dd3a.zip
crypto: sun8i-ss - Fix memory leak of pad
It appears there are several failure return paths that don't seem to be free'ing pad. Fix these. Addresses-Coverity: ("Resource leak") Fixes: d9b45418a917 ("crypto: sun8i-ss - support hash algorithms") Signed-off-by: Colin Ian King <colin.king@canonical.com> Acked-by: Corentin Labbe <clabbe.montjoie@gmail.com> Tested-by: Corentin Labbe <clabbe.montjoie@gmail.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Diffstat (limited to 'drivers/crypto/allwinner/sun8i-ss')
-rw-r--r--drivers/crypto/allwinner/sun8i-ss/sun8i-ss-hash.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/crypto/allwinner/sun8i-ss/sun8i-ss-hash.c b/drivers/crypto/allwinner/sun8i-ss/sun8i-ss-hash.c
index 7d1fc9aba665..3c073eb3db03 100644
--- a/drivers/crypto/allwinner/sun8i-ss/sun8i-ss-hash.c
+++ b/drivers/crypto/allwinner/sun8i-ss/sun8i-ss-hash.c
@@ -348,8 +348,10 @@ int sun8i_ss_hash_run(struct crypto_engine *engine, void *breq)
bf = (__le32 *)pad;
result = kzalloc(digestsize, GFP_KERNEL | GFP_DMA);
- if (!result)
+ if (!result) {
+ kfree(pad);
return -ENOMEM;
+ }
for (i = 0; i < MAX_SG; i++) {
rctx->t_dst[i].addr = 0;
@@ -436,10 +438,9 @@ int sun8i_ss_hash_run(struct crypto_engine *engine, void *breq)
DMA_TO_DEVICE);
dma_unmap_single(ss->dev, addr_res, digestsize, DMA_FROM_DEVICE);
- kfree(pad);
-
memcpy(areq->result, result, algt->alg.hash.halg.digestsize);
theend:
+ kfree(pad);
kfree(result);
crypto_finalize_hash_request(engine, breq, err);
return 0;