nftables: backport fix to interval based rules
authorKevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk>
Tue, 20 Sep 2022 14:16:37 +0000 (15:16 +0100)
committerKevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk>
Mon, 26 Sep 2022 17:02:15 +0000 (18:02 +0100)
'rule inet dscpclassify dscp_match  meta l4proto { udp }  th dport { 3478 }
 th sport { 3478-3497, 16384-16387 } goto ct_set_ef' works with
'nft add', but not 'nft insert', the latter yields:
"BUG: unhandled op 4".

Signed-off-by: Kevin Darbyshire-Bryant <ldir@darbyshire-bryant.me.uk>
package/network/utils/nftables/Makefile
package/network/utils/nftables/patches/0001-fix-nft.patch [new file with mode: 0644]

index fd53e3faa13cfcd402a71a46a1c3430337dce471..9691151c7b07605c4ea121e42393fa0e52b62dca 100644 (file)
@@ -7,7 +7,7 @@ include $(TOPDIR)/rules.mk
 
 PKG_NAME:=nftables
 PKG_VERSION:=1.0.5
-PKG_RELEASE:=1
+PKG_RELEASE:=2
 
 PKG_SOURCE:=$(PKG_NAME)-$(PKG_VERSION).tar.bz2
 PKG_SOURCE_URL:=https://netfilter.org/projects/$(PKG_NAME)/files
diff --git a/package/network/utils/nftables/patches/0001-fix-nft.patch b/package/network/utils/nftables/patches/0001-fix-nft.patch
new file mode 100644 (file)
index 0000000..2138e25
--- /dev/null
@@ -0,0 +1,23 @@
+'rule inet dscpclassify dscp_match  meta l4proto { udp }  th dport { 3478 }  th sport { 3478-3497, 16384-16387 } goto ct_set_ef'
+works with 'nft add', but not 'nft insert', the latter yields: "BUG: unhandled op 4".
+
+Fixes: 81e36530fcac ("src: replace interval segment tree overlap and automerge")
+Signed-off-by: Florian Westphal <fw@strlen.de>
+---
+ src/evaluate.c | 1 +
+ 1 file changed, 1 insertion(+)
+
+diff --git a/src/evaluate.c b/src/evaluate.c
+index d9c9ca28a53a..edebd7bcd8ab 100644
+--- a/src/evaluate.c
++++ b/src/evaluate.c
+@@ -1520,6 +1520,7 @@ static int interval_set_eval(struct eval_ctx *ctx, struct set *set,
+       switch (ctx->cmd->op) {
+       case CMD_CREATE:
+       case CMD_ADD:
++      case CMD_INSERT:
+               if (set->automerge) {
+                       ret = set_automerge(ctx->msgs, ctx->cmd, set, init,
+                                           ctx->nft->debug_mask);
+-- 
+2.35.1