bonding: 802.3ad: make aggregator_identifier bond-private
authorJiri Bohac <jiri@boha.cz>
Fri, 14 Feb 2014 17:13:50 +0000 (18:13 +0100)
committerDavid S. Miller <davem@davemloft.net>
Mon, 17 Feb 2014 19:54:06 +0000 (14:54 -0500)
commit163c8ff30dbe473abfbb24a7eac5536c87f3baa9
tree6cbde63c7e067a5b062693183657faf66d2fe3c8
parenteb85569fe2d06c2fbf4de7b66c263ca095b397aa
bonding: 802.3ad: make aggregator_identifier bond-private

aggregator_identifier is used to assign unique aggregator identifiers
to aggregators of a bond during device enslaving.

aggregator_identifier is currently a global variable that is zeroed in
bond_3ad_initialize().

This sequence will lead to duplicate aggregator identifiers for eth1 and eth3:

create bond0
change bond0 mode to 802.3ad
enslave eth0 to bond0  //eth0 gets agg id 1
enslave eth1 to bond0  //eth1 gets agg id 2
create bond1
change bond1 mode to 802.3ad
enslave eth2 to bond1 //aggregator_identifier is reset to 0
//eth2 gets agg id 1
enslave eth3 to bond0  //eth3 gets agg id 2

Fix this by making aggregator_identifier private to the bond.

Signed-off-by: Jiri Bohac <jbohac@suse.cz>
Acked-by: Veaceslav Falico <vfalico@redhat.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/bonding/bond_3ad.c
drivers/net/bonding/bond_3ad.h