From: Tony Ambardar Date: Mon, 15 Jan 2024 20:29:48 +0000 (-0800) Subject: kmodloader: fix memory leak in scan_loaded_modules() X-Git-Url: http://git.cdn.openwrt.org/?a=commitdiff_plain;h=811ca6c2234a3d13efef55947a9cff8bef56ceb7;p=project%2Fubox.git kmodloader: fix memory leak in scan_loaded_modules() Commit 4c7b720b9c63 fixed some error-handling paths but introduced another memory leak; update and fix. Fixes: 4c7b720b9c63 ("kmodloader: fix GCC fanalyzer warnings") Signed-off-by: Tony Ambardar --- diff --git a/kmodloader.c b/kmodloader.c index 259ac52..0afc795 100644 --- a/kmodloader.c +++ b/kmodloader.c @@ -311,12 +311,13 @@ static int scan_loaded_modules(void) { size_t buf_len = 0; char *buf = NULL; + int rv = -1; FILE *fp; fp = fopen("/proc/modules", "r"); if (!fp) { ULOG_ERR("failed to open /proc/modules\n"); - return -1; + goto out; } while (getline(&buf, &buf_len, fp) > 0) { @@ -338,16 +339,18 @@ static int scan_loaded_modules(void) } if (!n) { ULOG_ERR("Failed to allocate memory for module\n"); - return -1; + goto out; } n->usage = m.usage; n->state = LOADED; } + rv = 0; +out: free(buf); fclose(fp); - return 0; + return rv; } static struct module* get_module_info(const char *module, const char *name)