From 5ee6c4cf24fec22036888b9e53fbb0a27b3d6e4b Mon Sep 17 00:00:00 2001 From: Danny Kukawka Date: Fri, 24 Feb 2012 03:45:54 +0000 Subject: [PATCH] --- yaml --- r: 290459 b: refs/heads/master c: 66dc92eddf610d6f4572367f42902e62e19db7cb h: refs/heads/master i: 290457: 12222642d80c53964f8c547b178cd0cea93ca463 290455: 79b1064b70ae2e8102d335c01a2194d6ab5282a7 v: v3 --- [refs] | 2 +- trunk/drivers/net/ethernet/cirrus/mac89x0.c | 12 ++++++++---- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index defa54c0021b..da3dd23700f1 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: f27fd49962dc0f608e5547fc7ae98a8243570610 +refs/heads/master: 66dc92eddf610d6f4572367f42902e62e19db7cb diff --git a/trunk/drivers/net/ethernet/cirrus/mac89x0.c b/trunk/drivers/net/ethernet/cirrus/mac89x0.c index 83781f316d1f..419825ceab3b 100644 --- a/trunk/drivers/net/ethernet/cirrus/mac89x0.c +++ b/trunk/drivers/net/ethernet/cirrus/mac89x0.c @@ -592,10 +592,14 @@ static void set_multicast_list(struct net_device *dev) static int set_mac_address(struct net_device *dev, void *addr) { int i; - printk("%s: Setting MAC address to ", dev->name); - for (i = 0; i < 6; i++) - printk(" %2.2x", dev->dev_addr[i] = ((unsigned char *)addr)[i]); - printk(".\n"); + struct sockaddr *saddr = addr; + + if (!is_valid_ether_addr(addr->sa_data)) + return -EADDRNOTAVAIL; + + memcpy(dev->dev_addr, addr->sa_data, ETH_ALEN); + printk("%s: Setting MAC address to %pM\n", dev->name, dev->dev_addr); + /* set the Ethernet address */ for (i=0; i < ETH_ALEN/2; i++) writereg(dev, PP_IA+i*2, dev->dev_addr[i*2] | (dev->dev_addr[i*2+1] << 8));