diff --git a/[refs] b/[refs] index 2621cee204d2..9974a955f960 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: b4efc5610980bc4b65a6cb49b939cf5f7dfa2723 +refs/heads/master: aace495933a981274b6491d71b915165a61defdc diff --git a/trunk/drivers/net/smsc911x.c b/trunk/drivers/net/smsc911x.c index ccdd196f5297..6a9f51d1d9f2 100644 --- a/trunk/drivers/net/smsc911x.c +++ b/trunk/drivers/net/smsc911x.c @@ -2071,6 +2071,9 @@ static int __devinit smsc911x_drv_probe(struct platform_device *pdev) if (is_valid_ether_addr(dev->dev_addr)) { smsc911x_set_hw_mac_address(pdata, dev->dev_addr); SMSC_TRACE(PROBE, "MAC Address is specified by configuration"); + } else if (is_valid_ether_addr(pdata->config.mac)) { + memcpy(dev->dev_addr, pdata->config.mac, 6); + SMSC_TRACE(PROBE, "MAC Address specified by platform data"); } else { /* Try reading mac address from device. if EEPROM is present * it will already have been set */ diff --git a/trunk/include/linux/smsc911x.h b/trunk/include/linux/smsc911x.h index 5241e4fb4eca..7144e8aa1e41 100644 --- a/trunk/include/linux/smsc911x.h +++ b/trunk/include/linux/smsc911x.h @@ -30,6 +30,7 @@ struct smsc911x_platform_config { unsigned int irq_type; unsigned int flags; phy_interface_t phy_interface; + unsigned char mac[6]; }; /* Constants for platform_device irq polarity configuration */