From: Zhiqiang Liu Date: Sat, 20 Feb 2021 08:41:29 +0000 (+0800) Subject: debugfs: fix memory leak problem in read_list() X-Git-Tag: v1.46.2~11 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=989a4189698c4efa53b521b6ad8236bbfc3452c3;p=thirdparty%2Fe2fsprogs.git debugfs: fix memory leak problem in read_list() In read_list func, if strtoull() fails in while loop, we will return the error code directly. Then, memory of variable lst will be leaked without setting to *list. Signed-off-by: Zhiqiang Liu Signed-off-by: linfeilong Signed-off-by: Theodore Ts'o --- diff --git a/debugfs/util.c b/debugfs/util.c index be6b550e4..9e8805481 100644 --- a/debugfs/util.c +++ b/debugfs/util.c @@ -530,12 +530,16 @@ errcode_t read_list(char *str, blk64_t **list, size_t *len) errno = 0; y = x = strtoull(tok, &e, 0); - if (errno) - return errno; + if (errno) { + retval = errno; + break; + } if (*e == '-') { y = strtoull(e + 1, NULL, 0); - if (errno) - return errno; + if (errno) { + retval = errno; + break; + } } else if (*e != 0) { retval = EINVAL; break;