]> git.ipfire.org Git - thirdparty/nftables.git/commitdiff
netlink: do binop postprocessing also for map lookups
authorFlorian Westphal <fw@strlen.de>
Sun, 24 Jan 2016 12:37:10 +0000 (13:37 +0100)
committerFlorian Westphal <fw@strlen.de>
Tue, 26 Jan 2016 13:31:30 +0000 (14:31 +0100)
old nft list:
mark set unknown unknown & 0xfff [invalid type] map { 3 : 0x00000017, 1 : 0x0000002a}
new:
mark set vlan id map { 3 : 0x00000017, 1 : 0x0000002a}

Signed-off-by: Florian Westphal <fw@strlen.de>
Acked-by: Pablo Neira Ayuso <pablo@netfilter.org>
src/netlink_delinearize.c
tests/py/inet/map.t
tests/py/inet/map.t.payload.inet
tests/py/inet/map.t.payload.ip
tests/py/inet/map.t.payload.netdev

index 724d52f76e6e8a55efe646318a0ab78e87c5d76e..76d598ca8ada325fae74fcbaa16c199c00bae209 100644 (file)
@@ -1204,6 +1204,18 @@ static void binop_postprocess(struct rule_pp_ctx *ctx, struct expr *expr)
        }
 }
 
+static void map_binop_postprocess(struct rule_pp_ctx *ctx, struct expr *expr)
+{
+       struct expr *binop = expr->left;
+
+       if (binop->op != OP_AND)
+               return;
+
+       if (binop->left->ops->type == EXPR_PAYLOAD &&
+           binop->right->ops->type == EXPR_VALUE)
+               binop_postprocess(ctx, expr);
+}
+
 static void relational_binop_postprocess(struct rule_pp_ctx *ctx, struct expr *expr)
 {
        struct expr *binop = expr->left, *value = expr->right;
@@ -1356,6 +1368,14 @@ static void expr_postprocess(struct rule_pp_ctx *ctx, struct expr **exprp)
 
        switch (expr->ops->type) {
        case EXPR_MAP:
+               switch (expr->map->ops->type) {
+               case EXPR_BINOP:
+                       map_binop_postprocess(ctx, expr);
+                       break;
+               default:
+                       break;
+               }
+
                expr_postprocess(ctx, &expr->map);
                expr_postprocess(ctx, &expr->mappings);
                break;
index f48afcd205cf0912a24b00c0dab462611ed6dbfb..5075540bcba73554966ce8fb3683b392fb223fb4 100644 (file)
@@ -6,3 +6,4 @@
 *netdev;test-netdev;ingress
 
 mark set ip saddr map { 10.2.3.2 : 0x0000002a, 10.2.3.1 : 0x00000017};ok;mark set ip saddr map { 10.2.3.1 : 0x00000017, 10.2.3.2 : 0x0000002a}
+mark set ip hdrlength map { 5 : 0x00000017, 4 : 0x00000001};ok;mark set ip hdrlength map { 4 : 0x00000001, 5 : 0x00000017}
index 73e68b6004fe4b64253f730e17b32bfdae4d44b7..a0ff003b22d38c36ce98a078e5e3ca066b4a0678 100644 (file)
@@ -9,3 +9,15 @@ inet test-inet input
   [ lookup reg 1 set map%d dreg 1 ]
   [ meta set mark with reg 1 ]
 
+# mark set ip hdrlength map { 5 : 0x00000017, 4 : 0x00000001}
+map%d test-inet b
+map%d test-inet 0
+       element 00000005  : 00000017 0 [end]    element 00000004  : 00000001 0 [end]
+inet test-inet input
+  [ meta load nfproto => reg 1 ]
+  [ cmp eq reg 1 0x00000002 ]
+  [ payload load 1b @ network header + 0 => reg 1 ]
+  [ bitwise reg 1 = (reg=1 & 0x0000000f ) ^ 0x00000000 ]
+  [ lookup reg 1 set map%d dreg 1 ]
+  [ meta set mark with reg 1 ]
+
index 54b9583a36b8847eeceebead5fd0e257a7653fb8..465a55ae57838d4d309d589fa3b0c1401dfb4aea 100644 (file)
@@ -7,3 +7,13 @@ ip test-ip input
   [ lookup reg 1 set map%d dreg 1 ]
   [ meta set mark with reg 1 ]
 
+# mark set ip hdrlength map { 5 : 0x00000017, 4 : 0x00000001}
+map%d test-ip4 b
+map%d test-ip4 0
+       element 00000004  : 00000001 0 [end]    element 00000005  : 00000017 0 [end]
+ip test-ip4 input
+  [ payload load 1b @ network header + 0 => reg 1 ]
+  [ bitwise reg 1 = (reg=1 & 0x0000000f ) ^ 0x00000000 ]
+  [ lookup reg 1 set map%d dreg 1 ]
+  [ meta set mark with reg 1 ]
+
index 27a3ca8f3b8148656dafcf0fd349af74113b2aec..fb9260cbec503e7f09af74b6510cd0df76cd80b8 100644 (file)
@@ -9,3 +9,15 @@ netdev test-netdev ingress
   [ lookup reg 1 set map%d dreg 1 ]
   [ meta set mark with reg 1 ]
 
+# mark set ip hdrlength map { 5 : 0x00000017, 4 : 0x00000001}
+map%d test-netdev b
+map%d test-netdev 0
+       element 00000005  : 00000017 0 [end]    element 00000004  : 00000001 0 [end]
+netdev test-netdev ingress
+  [ meta load protocol => reg 1 ]
+  [ cmp eq reg 1 0x00000008 ]
+  [ payload load 1b @ network header + 0 => reg 1 ]
+  [ bitwise reg 1 = (reg=1 & 0x0000000f ) ^ 0x00000000 ]
+  [ lookup reg 1 set map%d dreg 1 ]
+  [ meta set mark with reg 1 ]
+