From e08c8bbfeda80f3807ce3784558ce1fb6f0d2bc8 Mon Sep 17 00:00:00 2001 From: Pablo Neira Ayuso Date: Wed, 3 Oct 2018 12:16:40 +0200 Subject: segtree: memleak in get_set_decompose() Release set content on error. Moreover, release input set content in case we finally manage to decompose it. Signed-off-by: Pablo Neira Ayuso --- src/segtree.c | 2 ++ 1 file changed, 2 insertions(+) (limited to 'src/segtree.c') diff --git a/src/segtree.c b/src/segtree.c index 0d53c83f..dc2554b7 100644 --- a/src/segtree.c +++ b/src/segtree.c @@ -727,6 +727,7 @@ int get_set_decompose(struct table *table, struct set *set) range = get_set_interval_find(table, set->handle.set.name, left, i); if (!range) { + expr_free(new_init); errno = ENOENT; return -1; } @@ -755,6 +756,7 @@ int get_set_decompose(struct table *table, struct set *set) compound_expr_add(new_init, expr_clone(left)); } + expr_free(set->init); set->init = new_init; return 0; -- cgit v1.2.3