diff options
author | Patrick McHardy <kaber@trash.net> | 2007-11-13 11:58:44 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2007-11-13 11:58:44 +0100 |
commit | 81d9ddae856678c45297550e9353c8a5a7fd6438 (patch) | |
tree | 7623400b1c2cd42cc1491fa991dbe8313e76bc1c /net/bridge | |
parent | [NETFILTER]: Consolidate nf_sockopt and compat_nf_sockopt (diff) | |
download | linux-81d9ddae856678c45297550e9353c8a5a7fd6438.tar.xz linux-81d9ddae856678c45297550e9353c8a5a7fd6438.zip |
[NETFILTER]: bridge: fix double POSTROUTING hook invocation
Packets routed between bridges have the POST_ROUTING hook invoked
twice since bridging mistakes them for bridged packets because
they have skb->nf_bridge set.
Signed-off-by: Patrick McHardy <kaber@trash.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/bridge')
-rw-r--r-- | net/bridge/br_netfilter.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/net/bridge/br_netfilter.c b/net/bridge/br_netfilter.c index da22f900e89d..c1757c79dfbb 100644 --- a/net/bridge/br_netfilter.c +++ b/net/bridge/br_netfilter.c @@ -766,6 +766,9 @@ static unsigned int br_nf_post_routing(unsigned int hook, struct sk_buff *skb, if (!nf_bridge) return NF_ACCEPT; + if (!(nf_bridge->mask & (BRNF_BRIDGED | BRNF_BRIDGED_DNAT))) + return NF_ACCEPT; + if (!realoutdev) return NF_DROP; |