From: Pablo Neira Ayuso Date: Fri, 3 Jan 2025 16:40:52 +0000 (+0100) Subject: intervals: do not merge intervals with different timeout X-Git-Tag: v1.1.2~102 X-Git-Url: http://git.ipfire.org/gitweb/gitweb.cgi?a=commitdiff_plain;h=da0bac050c8b2588242727f9915a1ea8bc48ceb2;p=thirdparty%2Fnftables.git intervals: do not merge intervals with different timeout If timeout/expiration of contiguous intervals is different, then do not merge them. Fixes: 81e36530fcac ("src: replace interval segment tree overlap and automerge") Signed-off-by: Pablo Neira Ayuso --- diff --git a/src/intervals.c b/src/intervals.c index 44fdda36..ffd474fd 100644 --- a/src/intervals.c +++ b/src/intervals.c @@ -156,6 +156,8 @@ static void set_prev_elem(struct expr **prev, struct expr *i, mpz_set(prev_range->high, range->high); } +static struct expr *interval_expr_key(struct expr *i); + static void setelem_automerge(struct set_automerge_ctx *ctx) { struct expr *i, *next, *prev = NULL; @@ -175,7 +177,9 @@ static void setelem_automerge(struct set_automerge_ctx *ctx) range_expr_value_low(range.low, i); range_expr_value_high(range.high, i); - if (!prev) { + if (!prev || + interval_expr_key(prev)->timeout != interval_expr_key(i)->timeout || + interval_expr_key(prev)->expiration != interval_expr_key(i)->expiration) { set_prev_elem(&prev, i, &prev_range, &range); continue; }