diff options
-rw-r--r-- | drivers/net/bonding/bond_alb.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/net/bonding/bond_alb.c b/drivers/net/bonding/bond_alb.c index e53847884319..2ec945c3b9ba 100644 --- a/drivers/net/bonding/bond_alb.c +++ b/drivers/net/bonding/bond_alb.c | |||
@@ -995,7 +995,7 @@ static void rlb_clear_vlan(struct bonding *bond, unsigned short vlan_id) | |||
995 | /*********************** tlb/rlb shared functions *********************/ | 995 | /*********************** tlb/rlb shared functions *********************/ |
996 | 996 | ||
997 | static void alb_send_lp_vid(struct slave *slave, u8 mac_addr[], | 997 | static void alb_send_lp_vid(struct slave *slave, u8 mac_addr[], |
998 | u16 vid) | 998 | __be16 vlan_proto, u16 vid) |
999 | { | 999 | { |
1000 | struct learning_pkt pkt; | 1000 | struct learning_pkt pkt; |
1001 | struct sk_buff *skb; | 1001 | struct sk_buff *skb; |
@@ -1021,7 +1021,7 @@ static void alb_send_lp_vid(struct slave *slave, u8 mac_addr[], | |||
1021 | skb->dev = slave->dev; | 1021 | skb->dev = slave->dev; |
1022 | 1022 | ||
1023 | if (vid) { | 1023 | if (vid) { |
1024 | skb = vlan_put_tag(skb, htons(ETH_P_8021Q), vid); | 1024 | skb = vlan_put_tag(skb, vlan_proto, vid); |
1025 | if (!skb) { | 1025 | if (!skb) { |
1026 | pr_err("%s: Error: failed to insert VLAN tag\n", | 1026 | pr_err("%s: Error: failed to insert VLAN tag\n", |
1027 | slave->bond->dev->name); | 1027 | slave->bond->dev->name); |
@@ -1040,13 +1040,14 @@ static void alb_send_learning_packets(struct slave *slave, u8 mac_addr[]) | |||
1040 | struct list_head *iter; | 1040 | struct list_head *iter; |
1041 | 1041 | ||
1042 | /* send untagged */ | 1042 | /* send untagged */ |
1043 | alb_send_lp_vid(slave, mac_addr, 0); | 1043 | alb_send_lp_vid(slave, mac_addr, 0, 0); |
1044 | 1044 | ||
1045 | /* loop through vlans and send one packet for each */ | 1045 | /* loop through vlans and send one packet for each */ |
1046 | rcu_read_lock(); | 1046 | rcu_read_lock(); |
1047 | netdev_for_each_all_upper_dev_rcu(bond->dev, upper, iter) { | 1047 | netdev_for_each_all_upper_dev_rcu(bond->dev, upper, iter) { |
1048 | if (is_vlan_dev(upper) && vlan_get_encap_level(upper) == 0) | 1048 | if (is_vlan_dev(upper) && vlan_get_encap_level(upper) == 0) |
1049 | alb_send_lp_vid(slave, mac_addr, | 1049 | alb_send_lp_vid(slave, mac_addr, |
1050 | vlan_dev_vlan_proto(upper), | ||
1050 | vlan_dev_vlan_id(upper)); | 1051 | vlan_dev_vlan_id(upper)); |
1051 | } | 1052 | } |
1052 | rcu_read_unlock(); | 1053 | rcu_read_unlock(); |