bonding: 802.3ad: make aggregator_identifier bond-private
authorJiri Bohac <jiri@boha.cz>
Fri, 14 Feb 2014 17:13:50 +0000 (18:13 +0100)
committerJiri Slaby <jslaby@suse.cz>
Wed, 26 Feb 2014 09:22:52 +0000 (10:22 +0100)
commitc92210fdc60d7be2ece4fbdbdd82d811355583d8
tree568f1b10e4acba29cbeba02a50b21335f0e205b9
parente8047a7d1ab917588d8dda3d6a99d570be47460e
bonding: 802.3ad: make aggregator_identifier bond-private

[ Upstream commit 163c8ff30dbe473abfbb24a7eac5536c87f3baa9 ]

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>
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
drivers/net/bonding/bond_3ad.c
drivers/net/bonding/bond_3ad.h