]> git.ipfire.org Git - thirdparty/nftables.git/commitdiff
optimize: compare expression length
authorPablo Neira Ayuso <pablo@netfilter.org>
Mon, 18 Nov 2024 11:44:06 +0000 (12:44 +0100)
committerPablo Neira Ayuso <pablo@netfilter.org>
Thu, 23 Jan 2025 00:35:37 +0000 (01:35 +0100)
commit bc0311378285d41850e3508df905d75959ba4239 upstream.

do not merge raw payload expressions with different length.

Other expression rely on key comparison which is assumed to have the
same length already.

Fixes: 60dcc01d6351 ("optimize: add __expr_cmp()")
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
src/optimize.c
tests/shell/testcases/optimizations/nomerge_raw_payload [new file with mode: 0755]

index dd7385bae31adf9a82aac42cde4459b1adba505a..8fc2b90140d4a13b004cd111f60bc8bdc04fdeab 100644 (file)
@@ -38,6 +38,8 @@ static bool __expr_cmp(const struct expr *expr_a, const struct expr *expr_b)
 {
        if (expr_a->etype != expr_b->etype)
                return false;
+       if (expr_a->len != expr_b->len)
+               return false;
 
        switch (expr_a->etype) {
        case EXPR_PAYLOAD:
diff --git a/tests/shell/testcases/optimizations/nomerge_raw_payload b/tests/shell/testcases/optimizations/nomerge_raw_payload
new file mode 100755 (executable)
index 0000000..bb8678a
--- /dev/null
@@ -0,0 +1,13 @@
+#!/bin/bash
+
+set -e
+
+RULESET="table ip x {
+        chain y {
+                type filter hook prerouting priority raw; policy accept;
+                @th,160,32 0x02736c00 drop comment \"sl\"
+                @th,160,112 0x870697a7a6173656f03636f6d00 drop comment \"pizzaseo.com\"
+        }
+}"
+
+$NFT -o -f - <<< $RULESET