From: Weili Qian Date: Sat, 11 Dec 2021 08:17:19 +0000 (+0800) Subject: crypto: hisilicon/hpre - fix memory leak in hpre_curve25519_src_init() X-Git-Url: http://git.maquefel.me/?a=commitdiff_plain;h=51fa916b81e5f406a74f14a31a3a228c3cc060ad;p=linux.git crypto: hisilicon/hpre - fix memory leak in hpre_curve25519_src_init() hpre_curve25519_src_init() allocates memory for 'ptr' before calling memcmp(). If memcmp() returns 0, the function will return '-EINVAL' without freeing memory. Signed-off-by: Weili Qian Signed-off-by: Herbert Xu --- diff --git a/drivers/crypto/hisilicon/hpre/hpre_crypto.c b/drivers/crypto/hisilicon/hpre/hpre_crypto.c index 0f1724d355b81..97d54c1465c2b 100644 --- a/drivers/crypto/hisilicon/hpre/hpre_crypto.c +++ b/drivers/crypto/hisilicon/hpre/hpre_crypto.c @@ -1862,7 +1862,7 @@ static int hpre_curve25519_src_init(struct hpre_asym_request *hpre_req, */ if (memcmp(ptr, p, ctx->key_sz) == 0) { dev_err(dev, "gx is p!\n"); - return -EINVAL; + goto err; } else if (memcmp(ptr, p, ctx->key_sz) > 0) { hpre_curve25519_src_modulo_p(ptr); }