diff options
author | Danny Kukawka <danny.kukawka@bisect.de> | 2012-02-17 05:43:22 +0000 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-02-17 15:52:30 -0500 |
commit | 7718f2c27dbdae0b22b2268a9c1b38edf0d8fa16 (patch) | |
tree | 311abdca60965f202ff3bb96eae4ba215b1cc733 /drivers/net/ethernet/amd | |
parent | 3ccdca7775968145d4218bf7e240bf48f7ed9cea (diff) | |
download | op-kernel-dev-7718f2c27dbdae0b22b2268a9c1b38edf0d8fa16.zip op-kernel-dev-7718f2c27dbdae0b22b2268a9c1b38edf0d8fa16.tar.gz |
au1000_eth: use eth_hw_addr_random() instead of random_ether_addr()
Use eth_hw_addr_random() instead of calling random_ether_addr()
to set addr_assign_type correctly to NET_ADDR_RANDOM.
v2: adapt to eth_hw_addr_random()
Signed-off-by: Danny Kukawka <danny.kukawka@bisect.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/amd')
-rw-r--r-- | drivers/net/ethernet/amd/au1000_eth.c | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/drivers/net/ethernet/amd/au1000_eth.c b/drivers/net/ethernet/amd/au1000_eth.c index c1dfdc8..397596b 100644 --- a/drivers/net/ethernet/amd/au1000_eth.c +++ b/drivers/net/ethernet/amd/au1000_eth.c @@ -1129,9 +1129,6 @@ static int __devinit au1000_probe(struct platform_device *pdev) au1000_setup_hw_rings(aup, aup->macdma); - /* set a random MAC now in case platform_data doesn't provide one */ - random_ether_addr(dev->dev_addr); - writel(0, aup->enable); aup->mac_enabled = 0; @@ -1141,8 +1138,12 @@ static int __devinit au1000_probe(struct platform_device *pdev) " PHY search on MAC0\n"); aup->phy1_search_mac0 = 1; } else { - if (is_valid_ether_addr(pd->mac)) + if (is_valid_ether_addr(pd->mac)) { memcpy(dev->dev_addr, pd->mac, 6); + } else { + /* Set a random MAC since no valid provided by platform_data. */ + eth_hw_addr_random(dev); + } aup->phy_static_config = pd->phy_static_config; aup->phy_search_highest_addr = pd->phy_search_highest_addr; |