diff options
-rw-r--r-- | drivers/net/bonding/bond_main.c | 7 | ||||
-rw-r--r-- | drivers/net/bonding/bond_sysfs.c | 8 |
2 files changed, 7 insertions, 8 deletions
diff --git a/drivers/net/bonding/bond_main.c b/drivers/net/bonding/bond_main.c index 2c3f9db91b50..4e7473e557ff 100644 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c | |||
@@ -1522,6 +1522,13 @@ int bond_enslave(struct net_device *bond_dev, struct net_device *slave_dev) | |||
1522 | } | 1522 | } |
1523 | } | 1523 | } |
1524 | 1524 | ||
1525 | /* If this is the first slave, then we need to set the master's hardware | ||
1526 | * address to be the same as the slave's. */ | ||
1527 | if (bond->slave_cnt == 0) | ||
1528 | memcpy(bond->dev->dev_addr, slave_dev->dev_addr, | ||
1529 | slave_dev->addr_len); | ||
1530 | |||
1531 | |||
1525 | new_slave = kzalloc(sizeof(struct slave), GFP_KERNEL); | 1532 | new_slave = kzalloc(sizeof(struct slave), GFP_KERNEL); |
1526 | if (!new_slave) { | 1533 | if (!new_slave) { |
1527 | res = -ENOMEM; | 1534 | res = -ENOMEM; |
diff --git a/drivers/net/bonding/bond_sysfs.c b/drivers/net/bonding/bond_sysfs.c index a4cbaf78ad1c..496ac1ec614d 100644 --- a/drivers/net/bonding/bond_sysfs.c +++ b/drivers/net/bonding/bond_sysfs.c | |||
@@ -250,14 +250,6 @@ static ssize_t bonding_store_slaves(struct device *d, | |||
250 | switch (command[0]) { | 250 | switch (command[0]) { |
251 | case '+': | 251 | case '+': |
252 | pr_info("%s: Adding slave %s.\n", bond->dev->name, dev->name); | 252 | pr_info("%s: Adding slave %s.\n", bond->dev->name, dev->name); |
253 | |||
254 | /* If this is the first slave, then we need to set | ||
255 | the master's hardware address to be the same as the | ||
256 | slave's. */ | ||
257 | if (is_zero_ether_addr(bond->dev->dev_addr)) | ||
258 | memcpy(bond->dev->dev_addr, dev->dev_addr, | ||
259 | dev->addr_len); | ||
260 | |||
261 | res = bond_enslave(bond->dev, dev); | 253 | res = bond_enslave(bond->dev, dev); |
262 | break; | 254 | break; |
263 | 255 | ||