a051e56
From 0b608345e114681f66ca0a3cf9d9434728da62ce Mon Sep 17 00:00:00 2001
a051e56
From: Ken Cox <ken@coxcampers.net>
a051e56
Date: Thu, 23 Jun 2011 10:36:43 -0500
a051e56
Subject: [PATCH] Support reading mac address from device tree.
a051e56
a051e56
If CONFIG_OF is enabled, we will try to read the mac address from the device tree.  This enables us the ability to have a "static" mac address on arm boards such as the pandaboard and beagleboard which generate random mac addresses.
a051e56
---
a051e56
 drivers/net/usb/smsc75xx.c |   17 +++++++++++++++++
a051e56
 drivers/net/usb/smsc95xx.c |   18 +++++++++++++++++-
a051e56
 2 files changed, 34 insertions(+), 1 deletions(-)
a051e56
a051e56
diff --git a/drivers/net/usb/smsc75xx.c b/drivers/net/usb/smsc75xx.c
a051e56
index 753ee6e..ac0a200 100644
a051e56
--- a/drivers/net/usb/smsc75xx.c
a051e56
+++ b/drivers/net/usb/smsc75xx.c
a051e56
@@ -29,6 +29,7 @@
a051e56
 #include <linux/crc32.h>
a051e56
 #include <linux/usb/usbnet.h>
a051e56
 #include <linux/slab.h>
a051e56
+#include <linux/of_device.h>
a051e56
 #include "smsc75xx.h"
a051e56
 
a051e56
 #define SMSC_CHIPNAME			"smsc75xx"
a051e56
@@ -658,6 +659,22 @@ static int smsc75xx_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd)
a051e56
 
a051e56
 static void smsc75xx_init_mac_address(struct usbnet *dev)
a051e56
 {
a051e56
+	void *address;
a051e56
+#ifdef CONFIG_OF
a051e56
+	struct device_node *np;
a051e56
+
a051e56
+	/* try the device tree */
a051e56
+	np = of_find_node_by_name(NULL, "smsc75xx");
a051e56
+	if (np) {
a051e56
+		address = of_get_property(np, "local-mac-address", NULL);
a051e56
+		if (address) {
a051e56
+			memcpy(dev->net->dev_addr, address, ETH_ALEN);
a051e56
+			netif_dbg(dev, ifup, dev->net, "MAC address read from device tree\n");
a051e56
+			return;
a051e56
+		}
a051e56
+	}
a051e56
+#endif
a051e56
+
a051e56
 	/* try reading mac address from EEPROM */
a051e56
 	if (smsc75xx_read_eeprom(dev, EEPROM_MAC_OFFSET, ETH_ALEN,
a051e56
 			dev->net->dev_addr) == 0) {
a051e56
diff --git a/drivers/net/usb/smsc95xx.c b/drivers/net/usb/smsc95xx.c
a051e56
index bc86f4b..c83942d 100644
a051e56
--- a/drivers/net/usb/smsc95xx.c
a051e56
+++ b/drivers/net/usb/smsc95xx.c
a051e56
@@ -29,6 +29,7 @@
a051e56
 #include <linux/crc32.h>
a051e56
 #include <linux/usb/usbnet.h>
a051e56
 #include <linux/slab.h>
a051e56
+#include <linux/of_device.h>
a051e56
 #include "smsc95xx.h"
a051e56
 
a051e56
 #define SMSC_CHIPNAME			"smsc95xx"
a051e56
@@ -639,6 +640,22 @@ static int smsc95xx_ioctl(struct net_device *netdev, struct ifreq *rq, int cmd)
a051e56
 
a051e56
 static void smsc95xx_init_mac_address(struct usbnet *dev)
a051e56
 {
a051e56
+	void *address;
a051e56
+#ifdef CONFIG_OF
a051e56
+	struct device_node *np;
a051e56
+
a051e56
+	/* try the device tree */
a051e56
+	np = of_find_node_by_name(NULL, "smsc95xx");
a051e56
+	if (np) {
a051e56
+		address = of_get_property(np, "local-mac-address", NULL);
a051e56
+		if (address) {
a051e56
+			memcpy(dev->net->dev_addr, address, ETH_ALEN);
a051e56
+			netif_dbg(dev, ifup, dev->net, "MAC address read from device tree\n");
a051e56
+			return;
a051e56
+		}
a051e56
+	}
a051e56
+#endif
a051e56
+
a051e56
 	/* try reading mac address from EEPROM */
a051e56
 	if (smsc95xx_read_eeprom(dev, EEPROM_MAC_OFFSET, ETH_ALEN,
a051e56
 			dev->net->dev_addr) == 0) {
a051e56
@@ -648,7 +665,6 @@ static void smsc95xx_init_mac_address(struct usbnet *dev)
a051e56
 			return;
a051e56
 		}
a051e56
 	}
a051e56
-
a051e56
 	/* no eeprom, or eeprom values are invalid. generate random MAC */
a051e56
 	random_ether_addr(dev->net->dev_addr);
a051e56
 	netif_dbg(dev, ifup, dev->net, "MAC address set to random_ether_addr\n");
a051e56
-- 
a051e56
1.7.2.3
a051e56