diff options
author | Ondrej Zary <linux@rainbow-software.org> | 2014-06-30 12:38:30 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-07-07 20:06:51 -0400 |
commit | 59be4ad6bb01fa80b6ad2cf15163ccb617f7d603 (patch) | |
tree | 73ebd5cedb349998a2ee6d47a4cb8815bcf0bc06 /drivers/net/ethernet/ti | |
parent | e36124d464d5ba74a171385ac1ba93acf4343de4 (diff) |
tlan: Fix MAC address byte order on OC-2325/OC-2326
Olicom OC-2325 and OC-2326 cards have the MAC address byte-swapped in EEPROM.
Byte-swap the MAC address if it's located at offset 0xF8.
Signed-off-by: Ondrej Zary <linux@rainbow-software.org>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet/ti')
-rw-r--r-- | drivers/net/ethernet/ti/tlan.c | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/drivers/net/ethernet/ti/tlan.c b/drivers/net/ethernet/ti/tlan.c index 00ec926084ea..cacc76da91a2 100644 --- a/drivers/net/ethernet/ti/tlan.c +++ b/drivers/net/ethernet/ti/tlan.c | |||
@@ -863,7 +863,7 @@ static int tlan_init(struct net_device *dev) | |||
863 | priv->rx_list_dma + sizeof(struct tlan_list)*TLAN_NUM_RX_LISTS; | 863 | priv->rx_list_dma + sizeof(struct tlan_list)*TLAN_NUM_RX_LISTS; |
864 | 864 | ||
865 | err = 0; | 865 | err = 0; |
866 | for (i = 0; i < 6 ; i++) | 866 | for (i = 0; i < ETH_ALEN; i++) |
867 | err |= tlan_ee_read_byte(dev, | 867 | err |= tlan_ee_read_byte(dev, |
868 | (u8) priv->adapter->addr_ofs + i, | 868 | (u8) priv->adapter->addr_ofs + i, |
869 | (u8 *) &dev->dev_addr[i]); | 869 | (u8 *) &dev->dev_addr[i]); |
@@ -871,7 +871,14 @@ static int tlan_init(struct net_device *dev) | |||
871 | pr_err("%s: Error reading MAC from eeprom: %d\n", | 871 | pr_err("%s: Error reading MAC from eeprom: %d\n", |
872 | dev->name, err); | 872 | dev->name, err); |
873 | } | 873 | } |
874 | dev->addr_len = 6; | 874 | /* Olicom OC-2325/OC-2326 have the address byte-swapped */ |
875 | if (priv->adapter->addr_ofs == 0xf8) { | ||
876 | for (i = 0; i < ETH_ALEN; i += 2) { | ||
877 | char tmp = dev->dev_addr[i]; | ||
878 | dev->dev_addr[i] = dev->dev_addr[i + 1]; | ||
879 | dev->dev_addr[i + 1] = tmp; | ||
880 | } | ||
881 | } | ||
875 | 882 | ||
876 | netif_carrier_off(dev); | 883 | netif_carrier_off(dev); |
877 | 884 | ||