|
@@ -892,9 +892,15 @@ static void bond_do_fail_over_mac(struct bonding *bond,
|
|
|
|
|
|
switch (bond->params.fail_over_mac) {
|
|
switch (bond->params.fail_over_mac) {
|
|
case BOND_FOM_ACTIVE:
|
|
case BOND_FOM_ACTIVE:
|
|
- if (new_active)
|
|
|
|
|
|
+ if (new_active) {
|
|
memcpy(bond->dev->dev_addr, new_active->dev->dev_addr,
|
|
memcpy(bond->dev->dev_addr, new_active->dev->dev_addr,
|
|
new_active->dev->addr_len);
|
|
new_active->dev->addr_len);
|
|
|
|
+ write_unlock_bh(&bond->curr_slave_lock);
|
|
|
|
+ read_unlock(&bond->lock);
|
|
|
|
+ call_netdevice_notifiers(NETDEV_CHANGEADDR, bond->dev);
|
|
|
|
+ read_lock(&bond->lock);
|
|
|
|
+ write_lock_bh(&bond->curr_slave_lock);
|
|
|
|
+ }
|
|
break;
|
|
break;
|
|
case BOND_FOM_FOLLOW:
|
|
case BOND_FOM_FOLLOW:
|
|
/*
|
|
/*
|