Commit 013a7ce8 authored by Ido Schimmel's avatar Ido Schimmel Committed by David S. Miller

bridge: Reorder neighbor suppression check when flooding

The bridge does not flood ARP / NS packets for which a reply was sent to
bridge ports that have neighbor suppression enabled.

Subsequent patches are going to add per-{Port, VLAN} neighbor
suppression, which is going to make it more expensive to check whether
neighbor suppression is enabled since a VLAN lookup will be required.

Therefore, instead of unnecessarily performing this lookup for every
packet, only perform it for ARP / NS packets for which a reply was sent.
Signed-off-by: default avatarIdo Schimmel <idosch@nvidia.com>
Acked-by: default avatarNikolay Aleksandrov <razor@blackwall.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 1cf3fe1c
...@@ -224,8 +224,8 @@ void br_flood(struct net_bridge *br, struct sk_buff *skb, ...@@ -224,8 +224,8 @@ void br_flood(struct net_bridge *br, struct sk_buff *skb,
/* Do not flood to ports that enable proxy ARP */ /* Do not flood to ports that enable proxy ARP */
if (p->flags & BR_PROXYARP) if (p->flags & BR_PROXYARP)
continue; continue;
if ((p->flags & (BR_PROXYARP_WIFI | BR_NEIGH_SUPPRESS)) && if (BR_INPUT_SKB_CB(skb)->proxyarp_replied &&
BR_INPUT_SKB_CB(skb)->proxyarp_replied) (p->flags & (BR_PROXYARP_WIFI | BR_NEIGH_SUPPRESS)))
continue; continue;
prev = maybe_deliver(prev, p, skb, local_orig); prev = maybe_deliver(prev, p, skb, local_orig);
......
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