Commit 91619eb6 authored by Pablo Neira Ayuso's avatar Pablo Neira Ayuso

netfilter: nft_inner: set tunnel offset to GRE header offset

Set inner tunnel offset to the GRE header, this is redundant to existing
transport header offset, but this normalizes the handling of the tunnel
header regardless its location in the layering. GRE version 0 is overloaded
with RFCs, the type decorator in the inner expression might also be useful
to interpret matching fields from the netlink delinearize path in userspace.
Signed-off-by: default avatarPablo Neira Ayuso <pablo@netfilter.org>
parent 0db14b95
...@@ -174,8 +174,13 @@ static int nft_inner_parse_tunhdr(const struct nft_inner *priv, ...@@ -174,8 +174,13 @@ static int nft_inner_parse_tunhdr(const struct nft_inner *priv,
const struct nft_pktinfo *pkt, const struct nft_pktinfo *pkt,
struct nft_inner_tun_ctx *ctx, u32 *off) struct nft_inner_tun_ctx *ctx, u32 *off)
{ {
if (pkt->tprot != IPPROTO_UDP || if (pkt->tprot == IPPROTO_GRE) {
pkt->tprot != IPPROTO_GRE) ctx->inner_tunoff = pkt->thoff;
ctx->flags |= NFT_PAYLOAD_CTX_INNER_TUN;
return 0;
}
if (pkt->tprot != IPPROTO_UDP)
return -1; return -1;
ctx->inner_tunoff = *off; ctx->inner_tunoff = *off;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment