uci: free configs list memory on return
authorYousong Zhou <yszhou4tech@gmail.com>
Mon, 21 Oct 2019 06:10:29 +0000 (06:10 +0000)
committerJo-Philipp Wich <jo@mein.io>
Tue, 26 May 2020 14:16:50 +0000 (16:16 +0200)
Signed-off-by: Yousong Zhou <yszhou4tech@gmail.com>
[fix whitespace]
Signed-off-by: Jo-Philipp Wich <jo@mein.io>
(cherry picked from commit 9ecfada16d7ad5ae942e6c0e65e1b9d7e89e21df)

uci.c

diff --git a/uci.c b/uci.c
index 0de6f3e23f8d3ba2fbfa1a653a9129ce26fb7dd0..522c24e8d569bf92aa8e1cf65d91d7c972135183 100644 (file)
--- a/uci.c
+++ b/uci.c
@@ -1286,6 +1286,8 @@ rpc_uci_changes(struct ubus_context *ctx, struct ubus_object *obj,
                uci_unload(cursor, p);
        }
 
+       free(configs);
+
        blobmsg_close_table(&buf, c);
 
        ubus_send_reply(ctx, req, buf.head);
@@ -1390,6 +1392,8 @@ rpc_uci_configs(struct ubus_context *ctx, struct ubus_object *obj,
        for (i = 0; configs[i]; i++)
                blobmsg_add_string(&buf, NULL, configs[i]);
 
+       free(configs);
+
        blobmsg_close_array(&buf, c);
 
        ubus_send_reply(ctx, req, buf.head);