diff options
author | Danny Kukawka <danny.kukawka@bisect.de> | 2012-02-17 00:43:30 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-02-17 15:58:06 -0500 |
commit | 6a214fd4142d585ef2226e8ef6bc29a15403506f (patch) | |
tree | b68498a0b99aae6269ddc84e8e4baf7586e20e99 /drivers/net/ethernet/atheros | |
parent | 939d2254fc259fd5ca0872f96b56f6966d804e24 (diff) |
atheros eth: set addr_assign_type if random_ether_addr() used
Set addr_assign_type correctly to NET_ADDR_RANDOM in case
a random MAC address was generated and assigned to the netdevice.
Fix error handling in atl1c_probe(). If atl1c_read_mac_addr()
couldn't get the hw mac address, and a random mac address get
set return the error code. Don't go to err_eeprom in
atl1c_probe(), use the generated MAC address in this case.
Reset the state to NET_ADDR_PERM as soon as the MAC get
changed via .ndo_set_mac_address.
v2: use bitops
Signed-off-by: Danny Kukawka <danny.kukawka@bisect.de>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/atheros')
-rw-r--r-- | drivers/net/ethernet/atheros/atl1c/atl1c_hw.c | 2 | ||||
-rw-r--r-- | drivers/net/ethernet/atheros/atl1c/atl1c_main.c | 9 | ||||
-rw-r--r-- | drivers/net/ethernet/atheros/atlx/atl1.c | 12 | ||||
-rw-r--r-- | drivers/net/ethernet/atheros/atlx/atlx.c | 1 |
4 files changed, 15 insertions, 9 deletions
diff --git a/drivers/net/ethernet/atheros/atl1c/atl1c_hw.c b/drivers/net/ethernet/atheros/atl1c/atl1c_hw.c index 23f2ab0f2fa8..bd1667cbffa6 100644 --- a/drivers/net/ethernet/atheros/atl1c/atl1c_hw.c +++ b/drivers/net/ethernet/atheros/atl1c/atl1c_hw.c | |||
@@ -224,7 +224,7 @@ int atl1c_read_mac_addr(struct atl1c_hw *hw) | |||
224 | random_ether_addr(hw->perm_mac_addr); | 224 | random_ether_addr(hw->perm_mac_addr); |
225 | 225 | ||
226 | memcpy(hw->mac_addr, hw->perm_mac_addr, sizeof(hw->perm_mac_addr)); | 226 | memcpy(hw->mac_addr, hw->perm_mac_addr, sizeof(hw->perm_mac_addr)); |
227 | return 0; | 227 | return err; |
228 | } | 228 | } |
229 | 229 | ||
230 | /* | 230 | /* |
diff --git a/drivers/net/ethernet/atheros/atl1c/atl1c_main.c b/drivers/net/ethernet/atheros/atl1c/atl1c_main.c index 2c8ed70704aa..ccdf1f6e2f9f 100644 --- a/drivers/net/ethernet/atheros/atl1c/atl1c_main.c +++ b/drivers/net/ethernet/atheros/atl1c/atl1c_main.c | |||
@@ -468,6 +468,7 @@ static int atl1c_set_mac_addr(struct net_device *netdev, void *p) | |||
468 | 468 | ||
469 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); | 469 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); |
470 | memcpy(adapter->hw.mac_addr, addr->sa_data, netdev->addr_len); | 470 | memcpy(adapter->hw.mac_addr, addr->sa_data, netdev->addr_len); |
471 | netdev->addr_assign_type &= ~NET_ADDR_RANDOM; | ||
471 | 472 | ||
472 | atl1c_hw_set_mac_addr(&adapter->hw); | 473 | atl1c_hw_set_mac_addr(&adapter->hw); |
473 | 474 | ||
@@ -2745,10 +2746,9 @@ static int __devinit atl1c_probe(struct pci_dev *pdev, | |||
2745 | err = -EIO; | 2746 | err = -EIO; |
2746 | goto err_reset; | 2747 | goto err_reset; |
2747 | } | 2748 | } |
2748 | if (atl1c_read_mac_addr(&adapter->hw) != 0) { | 2749 | if (atl1c_read_mac_addr(&adapter->hw)) { |
2749 | err = -EIO; | 2750 | /* got a random MAC address, set NET_ADDR_RANDOM to netdev */ |
2750 | dev_err(&pdev->dev, "get mac address failed\n"); | 2751 | netdev->addr_assign_type |= NET_ADDR_RANDOM; |
2751 | goto err_eeprom; | ||
2752 | } | 2752 | } |
2753 | memcpy(netdev->dev_addr, adapter->hw.mac_addr, netdev->addr_len); | 2753 | memcpy(netdev->dev_addr, adapter->hw.mac_addr, netdev->addr_len); |
2754 | memcpy(netdev->perm_addr, adapter->hw.mac_addr, netdev->addr_len); | 2754 | memcpy(netdev->perm_addr, adapter->hw.mac_addr, netdev->addr_len); |
@@ -2773,7 +2773,6 @@ static int __devinit atl1c_probe(struct pci_dev *pdev, | |||
2773 | err_reset: | 2773 | err_reset: |
2774 | err_register: | 2774 | err_register: |
2775 | err_sw_init: | 2775 | err_sw_init: |
2776 | err_eeprom: | ||
2777 | iounmap(adapter->hw.hw_addr); | 2776 | iounmap(adapter->hw.hw_addr); |
2778 | err_init_netdev: | 2777 | err_init_netdev: |
2779 | err_ioremap: | 2778 | err_ioremap: |
diff --git a/drivers/net/ethernet/atheros/atlx/atl1.c b/drivers/net/ethernet/atheros/atlx/atl1.c index 9bd204976648..40ac41436549 100644 --- a/drivers/net/ethernet/atheros/atlx/atl1.c +++ b/drivers/net/ethernet/atheros/atlx/atl1.c | |||
@@ -534,14 +534,17 @@ static int atl1_get_permanent_address(struct atl1_hw *hw) | |||
534 | */ | 534 | */ |
535 | static s32 atl1_read_mac_addr(struct atl1_hw *hw) | 535 | static s32 atl1_read_mac_addr(struct atl1_hw *hw) |
536 | { | 536 | { |
537 | s32 ret = 0; | ||
537 | u16 i; | 538 | u16 i; |
538 | 539 | ||
539 | if (atl1_get_permanent_address(hw)) | 540 | if (atl1_get_permanent_address(hw)) { |
540 | random_ether_addr(hw->perm_mac_addr); | 541 | random_ether_addr(hw->perm_mac_addr); |
542 | ret = 1; | ||
543 | } | ||
541 | 544 | ||
542 | for (i = 0; i < ETH_ALEN; i++) | 545 | for (i = 0; i < ETH_ALEN; i++) |
543 | hw->mac_addr[i] = hw->perm_mac_addr[i]; | 546 | hw->mac_addr[i] = hw->perm_mac_addr[i]; |
544 | return 0; | 547 | return ret; |
545 | } | 548 | } |
546 | 549 | ||
547 | /* | 550 | /* |
@@ -3007,7 +3010,10 @@ static int __devinit atl1_probe(struct pci_dev *pdev, | |||
3007 | } | 3010 | } |
3008 | 3011 | ||
3009 | /* copy the MAC address out of the EEPROM */ | 3012 | /* copy the MAC address out of the EEPROM */ |
3010 | atl1_read_mac_addr(&adapter->hw); | 3013 | if (atl1_read_mac_addr(&adapter->hw)) { |
3014 | /* mark random mac */ | ||
3015 | netdev->addr_assign_type |= NET_ADDR_RANDOM; | ||
3016 | } | ||
3011 | memcpy(netdev->dev_addr, adapter->hw.mac_addr, netdev->addr_len); | 3017 | memcpy(netdev->dev_addr, adapter->hw.mac_addr, netdev->addr_len); |
3012 | 3018 | ||
3013 | if (!is_valid_ether_addr(netdev->dev_addr)) { | 3019 | if (!is_valid_ether_addr(netdev->dev_addr)) { |
diff --git a/drivers/net/ethernet/atheros/atlx/atlx.c b/drivers/net/ethernet/atheros/atlx/atlx.c index 8ff7411094d5..3cd8837236dc 100644 --- a/drivers/net/ethernet/atheros/atlx/atlx.c +++ b/drivers/net/ethernet/atheros/atlx/atlx.c | |||
@@ -84,6 +84,7 @@ static int atlx_set_mac(struct net_device *netdev, void *p) | |||
84 | 84 | ||
85 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); | 85 | memcpy(netdev->dev_addr, addr->sa_data, netdev->addr_len); |
86 | memcpy(adapter->hw.mac_addr, addr->sa_data, netdev->addr_len); | 86 | memcpy(adapter->hw.mac_addr, addr->sa_data, netdev->addr_len); |
87 | netdev->addr_assign_type &= ~NET_ADDR_RANDOM; | ||
87 | 88 | ||
88 | atlx_set_mac_addr(&adapter->hw); | 89 | atlx_set_mac_addr(&adapter->hw); |
89 | return 0; | 90 | return 0; |