summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArturo Borrero <arturo.borrero.glez@gmail.com>2014-11-08 22:40:37 +0100
committerPablo Neira Ayuso <pablo@netfilter.org>2014-11-10 18:34:00 +0100
commit022121c0dccab3fd124e2b345bb7c439cb6dd92d (patch)
treea44860750ef2e15b2bbf5bbcd28079db443e17f7
parent457c2065827cc05a4c30e27fd57da998550dd078 (diff)
downloadiptables-ebtables-compat-experimental3.tar.gz
nft-bridge: fix printing of inverted protocols, addressesebtables-compat-experimental3
Previous to this patch, no '!' is printed in payload comparisions. This patch solves it, so we can print for example inverted protocols: % ebtables-compat -L [...] -p ! 0x800 -j ACCEPT Signed-off-by: Arturo Borrero Gonzalez <arturo.borrero.glez@gmail.com> Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
-rw-r--r--iptables/nft-bridge.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/iptables/nft-bridge.c b/iptables/nft-bridge.c
index 0e21b468..3ed62398 100644
--- a/iptables/nft-bridge.c
+++ b/iptables/nft-bridge.c
@@ -268,15 +268,21 @@ static void nft_bridge_parse_payload(struct nft_xt_ctx *ctx,
get_cmp_data(e, addr, sizeof(addr), &inv);
for (i = 0; i < ETH_ALEN; i++)
fw->destmac[i] = addr[i];
+ if (inv)
+ fw->invflags |= EBT_IDEST;
break;
case offsetof(struct ethhdr, h_source):
get_cmp_data(e, addr, sizeof(addr), &inv);
for (i = 0; i < ETH_ALEN; i++)
fw->sourcemac[i] = addr[i];
+ if (inv)
+ fw->invflags |= EBT_ISOURCE;
break;
case offsetof(struct ethhdr, h_proto):
get_cmp_data(e, &ethproto, sizeof(ethproto), &inv);
fw->ethproto = ethproto;
+ if (inv)
+ fw->invflags |= EBT_IPROTO;
break;
}
}