reported by tests/monitor# bash run-tests.sh
...
SUMMARY: AddressSanitizer: heap-use-after-free /home/pablo/devel/scm/git-netfilter/nftables/src/expression.c:1385 in expr_ops
Due to incorrect structure layout when calling interval_expr_copy().
Fixes: c1f0476fd590 ("segtree: copy expr data to closing element")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
i = range_expr_alloc(&low->location,
expr_clone(expr_value(low)), i);
i = set_elem_expr_alloc(&low->location, i);
- if (low->etype == EXPR_MAPPING)
+ if (low->etype == EXPR_MAPPING) {
i = mapping_expr_alloc(&i->location, i,
expr_clone(low->right));
-
- interval_expr_copy(i, low);
+ interval_expr_copy(i->left, low->left);
+ } else {
+ interval_expr_copy(i, low);
+ }
expr_free(low);
}