OSDN Git Service

ubifs: Fix memory leak in __ubifs_node_verify_hmac error path
authorWenwen Wang <wenwen@cs.uga.edu>
Tue, 20 Aug 2019 03:24:50 +0000 (22:24 -0500)
committerRichard Weinberger <richard@nod.at>
Sun, 15 Sep 2019 20:11:58 +0000 (22:11 +0200)
In __ubifs_node_verify_hmac(), 'hmac' is allocated through kmalloc().
However, it is not deallocated in the following execution if
ubifs_node_calc_hmac() fails, leading to a memory leak bug. To fix this
issue, free 'hmac' before returning the error.

Fixes: 49525e5eecca ("ubifs: Add helper functions for authentication support")
Signed-off-by: Wenwen Wang <wenwen@cs.uga.edu>
Signed-off-by: Richard Weinberger <richard@nod.at>
fs/ubifs/auth.c

index d9af2de..8cdbd53 100644 (file)
@@ -479,8 +479,10 @@ int __ubifs_node_verify_hmac(const struct ubifs_info *c, const void *node,
                return -ENOMEM;
 
        err = ubifs_node_calc_hmac(c, node, len, ofs_hmac, hmac);
-       if (err)
+       if (err) {
+               kfree(hmac);
                return err;
+       }
 
        err = crypto_memneq(hmac, node + ofs_hmac, hmac_len);