diff options
Diffstat (limited to 'drivers/usb/eth/smsc95xx.c')
| -rw-r--r-- | drivers/usb/eth/smsc95xx.c | 16 | 
1 files changed, 6 insertions, 10 deletions
| diff --git a/drivers/usb/eth/smsc95xx.c b/drivers/usb/eth/smsc95xx.c index 7ee4f87ea..2f63340fd 100644 --- a/drivers/usb/eth/smsc95xx.c +++ b/drivers/usb/eth/smsc95xx.c @@ -20,6 +20,7 @@   * MA 02111-1307 USA   */ +#include <asm/unaligned.h>  #include <common.h>  #include <usb.h>  #include <linux/mii.h> @@ -372,26 +373,21 @@ static int smsc95xx_init_mac_address(struct eth_device *eth,  static int smsc95xx_write_hwaddr(struct eth_device *eth)  {  	struct ueth_data *dev = (struct ueth_data *)eth->priv; -	u32 addr_lo, addr_hi; +	u32 addr_lo = __get_unaligned_le32(ð->enetaddr[0]); +	u32 addr_hi = __get_unaligned_le16(ð->enetaddr[4]);  	int ret;  	/* set hardware address */  	debug("** %s()\n", __func__); -	addr_lo = cpu_to_le32(*eth->enetaddr); -	addr_hi = cpu_to_le16(*((u16 *)(eth->enetaddr + 4)));  	ret = smsc95xx_write_reg(dev, ADDRL, addr_lo); -	if (ret < 0) { -		debug("Failed to write ADDRL: %d\n", ret); +	if (ret < 0)  		return ret; -	}  	ret = smsc95xx_write_reg(dev, ADDRH, addr_hi);  	if (ret < 0)  		return ret; -	debug("MAC %02x:%02x:%02x:%02x:%02x:%02x\n", -		eth->enetaddr[0], eth->enetaddr[1], -		eth->enetaddr[2], eth->enetaddr[3], -		eth->enetaddr[4], eth->enetaddr[5]); + +	debug("MAC %pM\n", eth->enetaddr);  	dev->have_hwaddr = 1;  	return 0;  } |