diff options
author | Vlad Yasevich <vyasevich@gmail.com> | 2014-09-15 15:24:26 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-09-15 17:38:30 -0400 |
commit | c095f248e63ada504dd90c90baae673ae10ee3fe (patch) | |
tree | 022c58eb61785526f6cb1690992459eba8338531 /net/bridge | |
parent | 7ce64c79c4decdeb1afe0bf2f6ef834b382871d1 (diff) |
bridge: Fix br_should_learn to check vlan_enabled
As Toshiaki Makita pointed out, the BRIDGE_INPUT_SKB_CB will
not be initialized in br_should_learn() as that function
is called only from br_handle_local_finish(). That is
an input handler for link-local ethernet traffic so it perfectly
correct to check br->vlan_enabled here.
Reported-by: Toshiaki Makita<toshiaki.makita1@gmail.com>
Fixes: 20adfa1 bridge: Check if vlan filtering is enabled only once.
Signed-off-by: Vladislav Yasevich <vyasevic@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/bridge')
-rw-r--r-- | net/bridge/br_vlan.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/bridge/br_vlan.c b/net/bridge/br_vlan.c index 4b86738eca9a..3ba57fcdcd13 100644 --- a/net/bridge/br_vlan.c +++ b/net/bridge/br_vlan.c | |||
@@ -280,7 +280,7 @@ bool br_should_learn(struct net_bridge_port *p, struct sk_buff *skb, u16 *vid) | |||
280 | struct net_port_vlans *v; | 280 | struct net_port_vlans *v; |
281 | 281 | ||
282 | /* If filtering was disabled at input, let it pass. */ | 282 | /* If filtering was disabled at input, let it pass. */ |
283 | if (!BR_INPUT_SKB_CB(skb)->vlan_filtered) | 283 | if (!br->vlan_enabled) |
284 | return true; | 284 | return true; |
285 | 285 | ||
286 | v = rcu_dereference(p->vlan_info); | 286 | v = rcu_dereference(p->vlan_info); |