Commit 457e1a8a authored by David S. Miller's avatar David S. Miller

[SUNGEM]: Consolidate powerpc and sparc MAC probing code.

Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent dadb830d
...@@ -66,9 +66,7 @@ ...@@ -66,9 +66,7 @@
#ifdef CONFIG_SPARC #ifdef CONFIG_SPARC
#include <asm/idprom.h> #include <asm/idprom.h>
#include <asm/openprom.h> #include <asm/prom.h>
#include <asm/oplib.h>
#include <asm/pbm.h>
#endif #endif
#ifdef CONFIG_PPC_PMAC #ifdef CONFIG_PPC_PMAC
...@@ -2906,34 +2904,17 @@ static int __devinit gem_get_device_address(struct gem *gp) ...@@ -2906,34 +2904,17 @@ static int __devinit gem_get_device_address(struct gem *gp)
{ {
#if defined(CONFIG_SPARC) || defined(CONFIG_PPC_PMAC) #if defined(CONFIG_SPARC) || defined(CONFIG_PPC_PMAC)
struct net_device *dev = gp->dev; struct net_device *dev = gp->dev;
#endif
#if defined(CONFIG_SPARC)
struct pci_dev *pdev = gp->pdev;
struct pcidev_cookie *pcp = pdev->sysdata;
int use_idprom = 1;
if (pcp != NULL) {
const unsigned char *addr;
int len;
addr = of_get_property(pcp->prom_node, "local-mac-address",
&len);
if (addr && len == 6) {
use_idprom = 0;
memcpy(dev->dev_addr, addr, 6);
}
}
if (use_idprom)
memcpy(dev->dev_addr, idprom->id_ethaddr, 6);
#elif defined(CONFIG_PPC_PMAC)
const unsigned char *addr; const unsigned char *addr;
addr = get_property(gp->of_node, "local-mac-address", NULL); addr = get_property(gp->of_node, "local-mac-address", NULL);
if (addr == NULL) { if (addr == NULL) {
#ifdef CONFIG_SPARC
addr = idprom->id_ethaddr;
#else
printk("\n"); printk("\n");
printk(KERN_ERR "%s: can't get mac-address\n", dev->name); printk(KERN_ERR "%s: can't get mac-address\n", dev->name);
return -1; return -1;
#endif
} }
memcpy(dev->dev_addr, addr, 6); memcpy(dev->dev_addr, addr, 6);
#else #else
...@@ -3091,7 +3072,7 @@ static int __devinit gem_init_one(struct pci_dev *pdev, ...@@ -3091,7 +3072,7 @@ static int __devinit gem_init_one(struct pci_dev *pdev,
/* On Apple, we want a reference to the Open Firmware device-tree /* On Apple, we want a reference to the Open Firmware device-tree
* node. We use it for clock control. * node. We use it for clock control.
*/ */
#ifdef CONFIG_PPC_PMAC #if defined(CONFIG_PPC_PMAC) || defined(CONFIG_SPARC)
gp->of_node = pci_device_to_OF_node(pdev); gp->of_node = pci_device_to_OF_node(pdev);
#endif #endif
......
...@@ -1025,7 +1025,7 @@ struct gem { ...@@ -1025,7 +1025,7 @@ struct gem {
struct pci_dev *pdev; struct pci_dev *pdev;
struct net_device *dev; struct net_device *dev;
#ifdef CONFIG_PPC_PMAC #if defined(CONFIG_PPC_PMAC) || defined(CONFIG_SPARC)
struct device_node *of_node; struct device_node *of_node;
#endif #endif
}; };
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment