ubifs: Fix memleak in ubifs_init_authentication
authorDinghao Liu <dinghao.liu@zju.edu.cn>
Tue, 5 Jan 2021 06:03:40 +0000 (14:03 +0800)
committerRichard Weinberger <richard@nod.at>
Fri, 12 Feb 2021 20:53:22 +0000 (21:53 +0100)
When crypto_shash_digestsize() fails, c->hmac_tfm
has not been freed before returning, which leads
to memleak.

Fixes: 49525e5eecca5 ("ubifs: Add helper functions for authentication support")
Signed-off-by: Dinghao Liu <dinghao.liu@zju.edu.cn>
Reviewed-by: Zhihao Cheng <chengzhihao1@huawei.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
fs/ubifs/auth.c

index 51a7c8c2c3f0aee28c900208c2a6e50bb041f7b8..e564d5ff87816380ccf65712c99bf8fa9c9bf4ee 100644 (file)
@@ -327,7 +327,7 @@ int ubifs_init_authentication(struct ubifs_info *c)
                ubifs_err(c, "hmac %s is bigger than maximum allowed hmac size (%d > %d)",
                          hmac_name, c->hmac_desc_len, UBIFS_HMAC_ARR_SZ);
                err = -EINVAL;
-               goto out_free_hash;
+               goto out_free_hmac;
        }
 
        err = crypto_shash_setkey(c->hmac_tfm, ukp->data, ukp->datalen);