net: ethernet: support of_get_mac_address new ERR_PTR error

There was NVMEM support added to of_get_mac_address, so it could now
return ERR_PTR encoded error values, so we need to adjust all current
users of of_get_mac_address to this new fact.

While at it, remove superfluous is_valid_ether_addr as the MAC address
returned from of_get_mac_address is always valid and checked by
is_valid_ether_addr anyway.

Fixes: d01f449c00 ("of_net: add NVMEM support to of_get_mac_address")
Signed-off-by: Petr Štetiar <ynezz@true.cz>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Petr Štetiar 2019-05-06 23:27:04 +02:00 committed by David S. Miller
parent 5503a6889f
commit a51645f70f
45 changed files with 45 additions and 45 deletions

View File

@ -1459,7 +1459,7 @@ static int greth_of_probe(struct platform_device *ofdev)
const u8 *addr; const u8 *addr;
addr = of_get_mac_address(ofdev->dev.of_node); addr = of_get_mac_address(ofdev->dev.of_node);
if (addr) { if (!IS_ERR(addr)) {
for (i = 0; i < 6; i++) for (i = 0; i < 6; i++)
macaddr[i] = (unsigned int) addr[i]; macaddr[i] = (unsigned int) addr[i];
} else { } else {

View File

@ -870,7 +870,7 @@ static int emac_probe(struct platform_device *pdev)
/* Read MAC-address from DT */ /* Read MAC-address from DT */
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(ndev->dev_addr, mac_addr, ETH_ALEN); memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
/* Check if the MAC address is valid, if not get a random one */ /* Check if the MAC address is valid, if not get a random one */

View File

@ -1537,7 +1537,7 @@ static int altera_tse_probe(struct platform_device *pdev)
/* get default MAC address from device tree */ /* get default MAC address from device tree */
macaddr = of_get_mac_address(pdev->dev.of_node); macaddr = of_get_mac_address(pdev->dev.of_node);
if (macaddr) if (!IS_ERR(macaddr))
ether_addr_copy(ndev->dev_addr, macaddr); ether_addr_copy(ndev->dev_addr, macaddr);
else else
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -960,7 +960,7 @@ int arc_emac_probe(struct net_device *ndev, int interface)
/* Get MAC address from device tree */ /* Get MAC address from device tree */
mac_addr = of_get_mac_address(dev->of_node); mac_addr = of_get_mac_address(dev->of_node);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(ndev->dev_addr, mac_addr, ETH_ALEN); memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
else else
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -1463,7 +1463,7 @@ static int nb8800_probe(struct platform_device *pdev)
dev->irq = irq; dev->irq = irq;
mac = of_get_mac_address(pdev->dev.of_node); mac = of_get_mac_address(pdev->dev.of_node);
if (mac) if (!IS_ERR(mac))
ether_addr_copy(dev->dev_addr, mac); ether_addr_copy(dev->dev_addr, mac);
if (!is_valid_ether_addr(dev->dev_addr)) if (!is_valid_ether_addr(dev->dev_addr))

View File

@ -2505,7 +2505,7 @@ static int bcm_sysport_probe(struct platform_device *pdev)
/* Initialize netdevice members */ /* Initialize netdevice members */
macaddr = of_get_mac_address(dn); macaddr = of_get_mac_address(dn);
if (!macaddr || !is_valid_ether_addr(macaddr)) { if (IS_ERR(macaddr)) {
dev_warn(&pdev->dev, "using random Ethernet MAC\n"); dev_warn(&pdev->dev, "using random Ethernet MAC\n");
eth_hw_addr_random(dev); eth_hw_addr_random(dev);
} else { } else {

View File

@ -132,7 +132,7 @@ static int bgmac_probe(struct bcma_device *core)
mac = of_get_mac_address(bgmac->dev->of_node); mac = of_get_mac_address(bgmac->dev->of_node);
/* If no MAC address assigned via device tree, check SPROM */ /* If no MAC address assigned via device tree, check SPROM */
if (!mac) { if (IS_ERR_OR_NULL(mac)) {
switch (core->core_unit) { switch (core->core_unit) {
case 0: case 0:
mac = sprom->et0mac; mac = sprom->et0mac;

View File

@ -193,7 +193,7 @@ static int bgmac_probe(struct platform_device *pdev)
bgmac->dma_dev = &pdev->dev; bgmac->dma_dev = &pdev->dev;
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(bgmac->net_dev->dev_addr, mac_addr); ether_addr_copy(bgmac->net_dev->dev_addr, mac_addr);
else else
dev_warn(&pdev->dev, "MAC address not present in device tree\n"); dev_warn(&pdev->dev, "MAC address not present in device tree\n");

View File

@ -3476,7 +3476,7 @@ static int bcmgenet_probe(struct platform_device *pdev)
if (dn) { if (dn) {
macaddr = of_get_mac_address(dn); macaddr = of_get_mac_address(dn);
if (!macaddr) { if (IS_ERR(macaddr)) {
dev_err(&pdev->dev, "can't find MAC address\n"); dev_err(&pdev->dev, "can't find MAC address\n");
err = -EINVAL; err = -EINVAL;
goto err; goto err;

View File

@ -1503,7 +1503,7 @@ static int octeon_mgmt_probe(struct platform_device *pdev)
mac = of_get_mac_address(pdev->dev.of_node); mac = of_get_mac_address(pdev->dev.of_node);
if (mac) if (!IS_ERR(mac))
memcpy(netdev->dev_addr, mac, ETH_ALEN); memcpy(netdev->dev_addr, mac, ETH_ALEN);
else else
eth_hw_addr_random(netdev); eth_hw_addr_random(netdev);

View File

@ -1484,7 +1484,7 @@ static int bgx_init_of_phy(struct bgx *bgx)
break; break;
mac = of_get_mac_address(node); mac = of_get_mac_address(node);
if (mac) if (!IS_ERR(mac))
ether_addr_copy(bgx->lmac[lmac].mac, mac); ether_addr_copy(bgx->lmac[lmac].mac, mac);
SET_NETDEV_DEV(&bgx->lmac[lmac].netdev, &bgx->pdev->dev); SET_NETDEV_DEV(&bgx->lmac[lmac].netdev, &bgx->pdev->dev);

View File

@ -1412,7 +1412,7 @@ static struct dm9000_plat_data *dm9000_parse_dt(struct device *dev)
pdata->flags |= DM9000_PLATF_NO_EEPROM; pdata->flags |= DM9000_PLATF_NO_EEPROM;
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(pdata->dev_addr, mac_addr, sizeof(pdata->dev_addr)); memcpy(pdata->dev_addr, mac_addr, sizeof(pdata->dev_addr));
return pdata; return pdata;

View File

@ -1153,7 +1153,7 @@ static int ethoc_probe(struct platform_device *pdev)
const void *mac; const void *mac;
mac = of_get_mac_address(pdev->dev.of_node); mac = of_get_mac_address(pdev->dev.of_node);
if (mac) if (!IS_ERR(mac))
ether_addr_copy(netdev->dev_addr, mac); ether_addr_copy(netdev->dev_addr, mac);
priv->phy_id = -1; priv->phy_id = -1;
} }

View File

@ -616,7 +616,7 @@ static s32 nps_enet_probe(struct platform_device *pdev)
/* set kernel MAC address to dev */ /* set kernel MAC address to dev */
mac_addr = of_get_mac_address(dev->of_node); mac_addr = of_get_mac_address(dev->of_node);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(ndev->dev_addr, mac_addr); ether_addr_copy(ndev->dev_addr, mac_addr);
else else
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -1655,7 +1655,7 @@ static void fec_get_mac(struct net_device *ndev)
struct device_node *np = fep->pdev->dev.of_node; struct device_node *np = fep->pdev->dev.of_node;
if (np) { if (np) {
const char *mac = of_get_mac_address(np); const char *mac = of_get_mac_address(np);
if (mac) if (!IS_ERR(mac))
iap = (unsigned char *) mac; iap = (unsigned char *) mac;
} }
} }

View File

@ -902,7 +902,7 @@ static int mpc52xx_fec_probe(struct platform_device *op)
* First try to read MAC address from DT * First try to read MAC address from DT
*/ */
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) { if (!IS_ERR(mac_addr)) {
memcpy(ndev->dev_addr, mac_addr, ETH_ALEN); memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
} else { } else {
struct mpc52xx_fec __iomem *fec = priv->fec; struct mpc52xx_fec __iomem *fec = priv->fec;

View File

@ -724,7 +724,7 @@ static int mac_probe(struct platform_device *_of_dev)
/* Get the MAC address */ /* Get the MAC address */
mac_addr = of_get_mac_address(mac_node); mac_addr = of_get_mac_address(mac_node);
if (!mac_addr) { if (IS_ERR(mac_addr)) {
dev_err(dev, "of_get_mac_address(%pOF) failed\n", mac_node); dev_err(dev, "of_get_mac_address(%pOF) failed\n", mac_node);
err = -EINVAL; err = -EINVAL;
goto _return_of_get_parent; goto _return_of_get_parent;

View File

@ -1014,7 +1014,7 @@ static int fs_enet_probe(struct platform_device *ofdev)
spin_lock_init(&fep->tx_lock); spin_lock_init(&fep->tx_lock);
mac_addr = of_get_mac_address(ofdev->dev.of_node); mac_addr = of_get_mac_address(ofdev->dev.of_node);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(ndev->dev_addr, mac_addr, ETH_ALEN); memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
ret = fep->ops->allocate_bd(ndev); ret = fep->ops->allocate_bd(ndev);

View File

@ -872,7 +872,7 @@ static int gfar_of_init(struct platform_device *ofdev, struct net_device **pdev)
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(dev->dev_addr, mac_addr, ETH_ALEN); memcpy(dev->dev_addr, mac_addr, ETH_ALEN);
if (model && !strcasecmp(model, "TSEC")) if (model && !strcasecmp(model, "TSEC"))

View File

@ -3910,7 +3910,7 @@ static int ucc_geth_probe(struct platform_device* ofdev)
} }
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(dev->dev_addr, mac_addr, ETH_ALEN); memcpy(dev->dev_addr, mac_addr, ETH_ALEN);
ugeth->ug_info = ug_info; ugeth->ug_info = ug_info;

View File

@ -870,7 +870,7 @@ static int hisi_femac_drv_probe(struct platform_device *pdev)
phy_modes(phy->interface)); phy_modes(phy->interface));
mac_addr = of_get_mac_address(node); mac_addr = of_get_mac_address(node);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(ndev->dev_addr, mac_addr); ether_addr_copy(ndev->dev_addr, mac_addr);
if (!is_valid_ether_addr(ndev->dev_addr)) { if (!is_valid_ether_addr(ndev->dev_addr)) {
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -1229,7 +1229,7 @@ static int hix5hd2_dev_probe(struct platform_device *pdev)
} }
mac_addr = of_get_mac_address(node); mac_addr = of_get_mac_address(node);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(ndev->dev_addr, mac_addr); ether_addr_copy(ndev->dev_addr, mac_addr);
if (!is_valid_ether_addr(ndev->dev_addr)) { if (!is_valid_ether_addr(ndev->dev_addr)) {
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -478,7 +478,7 @@ static int xrx200_probe(struct platform_device *pdev)
} }
mac = of_get_mac_address(np); mac = of_get_mac_address(np);
if (mac && is_valid_ether_addr(mac)) if (!IS_ERR(mac))
ether_addr_copy(net_dev->dev_addr, mac); ether_addr_copy(net_dev->dev_addr, mac);
else else
eth_hw_addr_random(net_dev); eth_hw_addr_random(net_dev);

View File

@ -2749,7 +2749,7 @@ static int mv643xx_eth_shared_of_add_port(struct platform_device *pdev,
} }
mac_addr = of_get_mac_address(pnp); mac_addr = of_get_mac_address(pnp);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(ppd.mac_addr, mac_addr, ETH_ALEN); memcpy(ppd.mac_addr, mac_addr, ETH_ALEN);
mv643xx_eth_property(pnp, "tx-queue-size", ppd.tx_queue_size); mv643xx_eth_property(pnp, "tx-queue-size", ppd.tx_queue_size);

View File

@ -4563,7 +4563,7 @@ static int mvneta_probe(struct platform_device *pdev)
} }
dt_mac_addr = of_get_mac_address(dn); dt_mac_addr = of_get_mac_address(dn);
if (dt_mac_addr) { if (!IS_ERR(dt_mac_addr)) {
mac_from = "device tree"; mac_from = "device tree";
memcpy(dev->dev_addr, dt_mac_addr, ETH_ALEN); memcpy(dev->dev_addr, dt_mac_addr, ETH_ALEN);
} else { } else {

View File

@ -1461,7 +1461,7 @@ static int pxa168_eth_probe(struct platform_device *pdev)
if (pdev->dev.of_node) if (pdev->dev.of_node)
mac_addr = of_get_mac_address(pdev->dev.of_node); mac_addr = of_get_mac_address(pdev->dev.of_node);
if (mac_addr && is_valid_ether_addr(mac_addr)) { if (!IS_ERR_OR_NULL(mac_addr)) {
ether_addr_copy(dev->dev_addr, mac_addr); ether_addr_copy(dev->dev_addr, mac_addr);
} else { } else {
/* try reading the mac address, if set by the bootloader */ /* try reading the mac address, if set by the bootloader */

View File

@ -4808,7 +4808,7 @@ static struct net_device *sky2_init_netdev(struct sky2_hw *hw, unsigned port,
* 2) from internal registers set by bootloader * 2) from internal registers set by bootloader
*/ */
iap = of_get_mac_address(hw->pdev->dev.of_node); iap = of_get_mac_address(hw->pdev->dev.of_node);
if (iap) if (!IS_ERR(iap))
memcpy(dev->dev_addr, iap, ETH_ALEN); memcpy(dev->dev_addr, iap, ETH_ALEN);
else else
memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8, memcpy_fromio(dev->dev_addr, hw->regs + B2_MAC_1 + port * 8,

View File

@ -2028,7 +2028,7 @@ static int __init mtk_init(struct net_device *dev)
const char *mac_addr; const char *mac_addr;
mac_addr = of_get_mac_address(mac->of_node); mac_addr = of_get_mac_address(mac->of_node);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(dev->dev_addr, mac_addr); ether_addr_copy(dev->dev_addr, mac_addr);
/* If the mac address is invalid, use random mac address */ /* If the mac address is invalid, use random mac address */

View File

@ -425,7 +425,7 @@ static void ks8851_init_mac(struct ks8851_net *ks)
const u8 *mac_addr; const u8 *mac_addr;
mac_addr = of_get_mac_address(ks->spidev->dev.of_node); mac_addr = of_get_mac_address(ks->spidev->dev.of_node);
if (mac_addr) { if (!IS_ERR(mac_addr)) {
memcpy(dev->dev_addr, mac_addr, ETH_ALEN); memcpy(dev->dev_addr, mac_addr, ETH_ALEN);
ks8851_write_mac_addr(dev); ks8851_write_mac_addr(dev);
return; return;

View File

@ -1327,7 +1327,7 @@ static int ks8851_probe(struct platform_device *pdev)
/* overwriting the default MAC address */ /* overwriting the default MAC address */
if (pdev->dev.of_node) { if (pdev->dev.of_node) {
mac = of_get_mac_address(pdev->dev.of_node); mac = of_get_mac_address(pdev->dev.of_node);
if (mac) if (!IS_ERR(mac))
memcpy(ks->mac_addr, mac, ETH_ALEN); memcpy(ks->mac_addr, mac, ETH_ALEN);
} else { } else {
struct ks8851_mll_platform_data *pdata; struct ks8851_mll_platform_data *pdata;

View File

@ -1368,7 +1368,7 @@ static int lpc_eth_drv_probe(struct platform_device *pdev)
if (!is_valid_ether_addr(ndev->dev_addr)) { if (!is_valid_ether_addr(ndev->dev_addr)) {
const char *macaddr = of_get_mac_address(np); const char *macaddr = of_get_mac_address(np);
if (macaddr) if (!IS_ERR(macaddr))
memcpy(ndev->dev_addr, macaddr, ETH_ALEN); memcpy(ndev->dev_addr, macaddr, ETH_ALEN);
} }
if (!is_valid_ether_addr(ndev->dev_addr)) if (!is_valid_ether_addr(ndev->dev_addr))

View File

@ -966,7 +966,7 @@ qca_spi_probe(struct spi_device *spi)
mac = of_get_mac_address(spi->dev.of_node); mac = of_get_mac_address(spi->dev.of_node);
if (mac) if (!IS_ERR(mac))
ether_addr_copy(qca->net_dev->dev_addr, mac); ether_addr_copy(qca->net_dev->dev_addr, mac);
if (!is_valid_ether_addr(qca->net_dev->dev_addr)) { if (!is_valid_ether_addr(qca->net_dev->dev_addr)) {

View File

@ -351,7 +351,7 @@ static int qca_uart_probe(struct serdev_device *serdev)
mac = of_get_mac_address(serdev->dev.of_node); mac = of_get_mac_address(serdev->dev.of_node);
if (mac) if (!IS_ERR(mac))
ether_addr_copy(qca->net_dev->dev_addr, mac); ether_addr_copy(qca->net_dev->dev_addr, mac);
if (!is_valid_ether_addr(qca->net_dev->dev_addr)) { if (!is_valid_ether_addr(qca->net_dev->dev_addr)) {

View File

@ -111,7 +111,7 @@ static void ravb_set_buffer_align(struct sk_buff *skb)
*/ */
static void ravb_read_mac_address(struct net_device *ndev, const u8 *mac) static void ravb_read_mac_address(struct net_device *ndev, const u8 *mac)
{ {
if (mac) { if (!IS_ERR(mac)) {
ether_addr_copy(ndev->dev_addr, mac); ether_addr_copy(ndev->dev_addr, mac);
} else { } else {
u32 mahr = ravb_read(ndev, MAHR); u32 mahr = ravb_read(ndev, MAHR);

View File

@ -3193,7 +3193,7 @@ static struct sh_eth_plat_data *sh_eth_parse_dt(struct device *dev)
pdata->phy_interface = ret; pdata->phy_interface = ret;
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
memcpy(pdata->mac_addr, mac_addr, ETH_ALEN); memcpy(pdata->mac_addr, mac_addr, ETH_ALEN);
pdata->no_ether_link = pdata->no_ether_link =

View File

@ -124,7 +124,7 @@ static int sxgbe_platform_probe(struct platform_device *pdev)
} }
/* Get MAC address if available (DT) */ /* Get MAC address if available (DT) */
if (mac) if (!IS_ERR_OR_NULL(mac))
ether_addr_copy(priv->dev->dev_addr, mac); ether_addr_copy(priv->dev->dev_addr, mac);
/* Get the TX/RX IRQ numbers */ /* Get the TX/RX IRQ numbers */

View File

@ -1599,7 +1599,7 @@ static int ave_probe(struct platform_device *pdev)
ndev->max_mtu = AVE_MAX_ETHFRAME - (ETH_HLEN + ETH_FCS_LEN); ndev->max_mtu = AVE_MAX_ETHFRAME - (ETH_HLEN + ETH_FCS_LEN);
mac_addr = of_get_mac_address(np); mac_addr = of_get_mac_address(np);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(ndev->dev_addr, mac_addr); ether_addr_copy(ndev->dev_addr, mac_addr);
/* if the mac address is invalid, use random mac address */ /* if the mac address is invalid, use random mac address */

View File

@ -4262,7 +4262,7 @@ int stmmac_dvr_probe(struct device *device,
priv->wol_irq = res->wol_irq; priv->wol_irq = res->wol_irq;
priv->lpi_irq = res->lpi_irq; priv->lpi_irq = res->lpi_irq;
if (res->mac) if (!IS_ERR_OR_NULL(res->mac))
memcpy(priv->dev->dev_addr, res->mac, ETH_ALEN); memcpy(priv->dev->dev_addr, res->mac, ETH_ALEN);
dev_set_drvdata(device, priv->dev); dev_set_drvdata(device, priv->dev);

View File

@ -2232,7 +2232,7 @@ static int cpsw_probe_dt(struct cpsw_platform_data *data,
no_phy_slave: no_phy_slave:
mac_addr = of_get_mac_address(slave_node); mac_addr = of_get_mac_address(slave_node);
if (mac_addr) { if (!IS_ERR(mac_addr)) {
memcpy(slave_data->mac_addr, mac_addr, ETH_ALEN); memcpy(slave_data->mac_addr, mac_addr, ETH_ALEN);
} else { } else {
ret = ti_cm_get_macid(&pdev->dev, i, ret = ti_cm_get_macid(&pdev->dev, i,

View File

@ -2037,7 +2037,7 @@ static int netcp_create_interface(struct netcp_device *netcp_device,
devm_release_mem_region(dev, res.start, size); devm_release_mem_region(dev, res.start, size);
} else { } else {
mac_addr = of_get_mac_address(node_interface); mac_addr = of_get_mac_address(node_interface);
if (mac_addr) if (!IS_ERR(mac_addr))
ether_addr_copy(ndev->dev_addr, mac_addr); ether_addr_copy(ndev->dev_addr, mac_addr);
else else
eth_random_addr(ndev->dev_addr); eth_random_addr(ndev->dev_addr);

View File

@ -1164,7 +1164,7 @@ int w5100_probe(struct device *dev, const struct w5100_ops *ops,
INIT_WORK(&priv->setrx_work, w5100_setrx_work); INIT_WORK(&priv->setrx_work, w5100_setrx_work);
INIT_WORK(&priv->restart_work, w5100_restart_work); INIT_WORK(&priv->restart_work, w5100_restart_work);
if (mac_addr) if (!IS_ERR_OR_NULL(mac_addr))
memcpy(ndev->dev_addr, mac_addr, ETH_ALEN); memcpy(ndev->dev_addr, mac_addr, ETH_ALEN);
else else
eth_hw_addr_random(ndev); eth_hw_addr_random(ndev);

View File

@ -1252,7 +1252,7 @@ static int temac_probe(struct platform_device *pdev)
if (temac_np) { if (temac_np) {
/* Retrieve the MAC address */ /* Retrieve the MAC address */
addr = of_get_mac_address(temac_np); addr = of_get_mac_address(temac_np);
if (!addr) { if (IS_ERR(addr)) {
dev_err(&pdev->dev, "could not find MAC address\n"); dev_err(&pdev->dev, "could not find MAC address\n");
return -ENODEV; return -ENODEV;
} }

View File

@ -1596,7 +1596,7 @@ static int axienet_probe(struct platform_device *pdev)
/* Retrieve the MAC address */ /* Retrieve the MAC address */
mac_addr = of_get_mac_address(pdev->dev.of_node); mac_addr = of_get_mac_address(pdev->dev.of_node);
if (!mac_addr) { if (IS_ERR(mac_addr)) {
dev_err(&pdev->dev, "could not find MAC address\n"); dev_err(&pdev->dev, "could not find MAC address\n");
goto free_netdev; goto free_netdev;
} }

View File

@ -1165,7 +1165,7 @@ static int xemaclite_of_probe(struct platform_device *ofdev)
lp->rx_ping_pong = get_bool(ofdev, "xlnx,rx-ping-pong"); lp->rx_ping_pong = get_bool(ofdev, "xlnx,rx-ping-pong");
mac_address = of_get_mac_address(ofdev->dev.of_node); mac_address = of_get_mac_address(ofdev->dev.of_node);
if (mac_address) { if (!IS_ERR(mac_address)) {
/* Set the MAC address. */ /* Set the MAC address. */
memcpy(ndev->dev_addr, mac_address, ETH_ALEN); memcpy(ndev->dev_addr, mac_address, ETH_ALEN);
} else { } else {

View File

@ -560,7 +560,7 @@ int eth_platform_get_mac_address(struct device *dev, u8 *mac_addr)
addr = NULL; addr = NULL;
if (dp) if (dp)
addr = of_get_mac_address(dp); addr = of_get_mac_address(dp);
if (!addr) if (IS_ERR_OR_NULL(addr))
addr = arch_get_platform_mac_address(); addr = arch_get_platform_mac_address();
if (!addr) if (!addr)