]> git.ipfire.org Git - thirdparty/nftables.git/commit
src: add vxlan matching support
authorPablo Neira Ayuso <pablo@netfilter.org>
Mon, 2 Jan 2023 14:36:25 +0000 (15:36 +0100)
committerPablo Neira Ayuso <pablo@netfilter.org>
Mon, 2 Jan 2023 14:36:25 +0000 (15:36 +0100)
commit772892a018b4431361a226020b0f7615ab2b304f
tree1c88e423b3c7db8b03f520fd8bf89b36fbd65b39
parent5e7304e12518ecb38ff45746650b5362f975500d
src: add vxlan matching support

This patch adds the initial infrastructure to support for inner header
tunnel matching and its first user: vxlan.

A new struct proto_desc field for payload and meta expression to specify
that the expression refers to inner header matching is used.

The existing codebase to generate bytecode is fully reused, allowing for
reusing existing supported layer 2, 3 and 4 protocols.

Syntax requires to specify vxlan before the inner protocol field:

... vxlan ip protocol udp
... vxlan ip saddr 1.2.3.0/24

This also works with concatenations and anonymous sets, eg.

... vxlan ip saddr . vxlan ip daddr { 1.2.3.4 . 4.3.2.1 }

You have to restrict vxlan matching to udp traffic, otherwise it
complains on missing transport protocol dependency, e.g.

... udp dport 4789 vxlan ip daddr 1.2.3.4

The bytecode that is generated uses the new inner expression:

 # nft --debug=netlink add rule netdev x y udp dport 4789 vxlan ip saddr 1.2.3.4
 netdev x y
  [ meta load l4proto => reg 1 ]
  [ cmp eq reg 1 0x00000011 ]
  [ payload load 2b @ transport header + 2 => reg 1 ]
  [ cmp eq reg 1 0x0000b512 ]
  [ inner type 1 hdrsize 8 flags f [ meta load protocol => reg 1 ] ]
  [ cmp eq reg 1 0x00000008 ]
  [ inner type 1 hdrsize 8 flags f [ payload load 4b @ network header + 12 => reg 1 ] ]
  [ cmp eq reg 1 0x04030201 ]

JSON support is not included in this patch.

Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
16 files changed:
include/expression.h
include/linux/netfilter/nf_tables.h
include/netlink.h
include/payload.h
include/proto.h
include/rule.h
src/evaluate.c
src/expression.c
src/meta.c
src/netlink_delinearize.c
src/netlink_linearize.c
src/parser_bison.y
src/payload.c
src/proto.c
src/rule.c
src/scanner.l