aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/bonding/bond_3ad.c
diff options
context:
space:
mode:
authorJay Vosburgh <fubar@us.ibm.com>2007-06-14 01:11:34 -0400
committerJeff Garzik <jeff@garzik.org>2007-06-20 19:12:41 -0400
commit031ae4deb095a1f18a842740459c5ae184ec931c (patch)
treefe08362942c3a9ba36387b6aed005b21bd77474d /drivers/net/bonding/bond_3ad.c
parent3201e656ce56ed02e9501906c18ffe16ae350a52 (diff)
bonding: Fix 802.3ad no carrier on "no partner found" instance
Modify carrier state determination for 802.3ad mode to comply with section 43.3.9 of IEEE 802.3, which requires that "Links that are not successful candidates for aggregation (e.g., links that are attached to other devices that cannot perform aggregation or links that have been manually configured to be non-aggregatable) are enabled to operate as individual IEEE 802.3 links." Bug reported by Laurent Chavey <chavey@google.com>. This patch is an updated version of his patch that changes the wording of commentary and adds an update to the driver version. Signed-off-by: Jay Vosburgh <fubar@us.ibm.com> Signed-off-by: Laurent Chavey <chavey@google.com> Signed-off-by: Jeff Garzik <jeff@garzik.org>
Diffstat (limited to 'drivers/net/bonding/bond_3ad.c')
-rw-r--r--drivers/net/bonding/bond_3ad.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/drivers/net/bonding/bond_3ad.c b/drivers/net/bonding/bond_3ad.c
index 7e03f41ae2c2..f829e4ad8b49 100644
--- a/drivers/net/bonding/bond_3ad.c
+++ b/drivers/net/bonding/bond_3ad.c
@@ -2303,19 +2303,18 @@ void bond_3ad_handle_link_change(struct slave *slave, char link)
2303} 2303}
2304 2304
2305/* 2305/*
2306 * set link state for bonding master: if we have an active partnered 2306 * set link state for bonding master: if we have an active
2307 * aggregator, we're up, if not, we're down. Presumes that we cannot 2307 * aggregator, we're up, if not, we're down. Presumes that we cannot
2308 * have an active aggregator if there are no slaves with link up. 2308 * have an active aggregator if there are no slaves with link up.
2309 * 2309 *
2310 * This behavior complies with IEEE 802.3 section 43.3.9.
2311 *
2310 * Called by bond_set_carrier(). Return zero if carrier state does not 2312 * Called by bond_set_carrier(). Return zero if carrier state does not
2311 * change, nonzero if it does. 2313 * change, nonzero if it does.
2312 */ 2314 */
2313int bond_3ad_set_carrier(struct bonding *bond) 2315int bond_3ad_set_carrier(struct bonding *bond)
2314{ 2316{
2315 struct aggregator *agg; 2317 if (__get_active_agg(&(SLAVE_AD_INFO(bond->first_slave).aggregator))) {
2316
2317 agg = __get_active_agg(&(SLAVE_AD_INFO(bond->first_slave).aggregator));
2318 if (agg && MAC_ADDRESS_COMPARE(&agg->partner_system, &null_mac_addr)) {
2319 if (!netif_carrier_ok(bond->dev)) { 2318 if (!netif_carrier_ok(bond->dev)) {
2320 netif_carrier_on(bond->dev); 2319 netif_carrier_on(bond->dev);
2321 return 1; 2320 return 1;