Commit 2cee73ce authored by Paul Fertser's avatar Paul Fertser Committed by Paolo Abeni

net: ftgmac100: support getting MAC address from NVMEM

Make use of of_get_ethdev_address() to support reading MAC address not
only from the usual DT nodes but also from an NVMEM provider (e.g. using
a dedicated area in an FRU EEPROM).
Signed-off-by: default avatarPaul Fertser <fercerpav@gmail.com>
Link: https://lore.kernel.org/r/20230713095743.30517-1-fercerpav@gmail.comSigned-off-by: default avatarPaolo Abeni <pabeni@redhat.com>
parent 60cc1f7d
...@@ -177,16 +177,20 @@ static void ftgmac100_write_mac_addr(struct ftgmac100 *priv, const u8 *mac) ...@@ -177,16 +177,20 @@ static void ftgmac100_write_mac_addr(struct ftgmac100 *priv, const u8 *mac)
iowrite32(laddr, priv->base + FTGMAC100_OFFSET_MAC_LADR); iowrite32(laddr, priv->base + FTGMAC100_OFFSET_MAC_LADR);
} }
static void ftgmac100_initial_mac(struct ftgmac100 *priv) static int ftgmac100_initial_mac(struct ftgmac100 *priv)
{ {
u8 mac[ETH_ALEN]; u8 mac[ETH_ALEN];
unsigned int m; unsigned int m;
unsigned int l; unsigned int l;
int err;
if (!device_get_ethdev_address(priv->dev, priv->netdev)) { err = of_get_ethdev_address(priv->dev->of_node, priv->netdev);
if (err == -EPROBE_DEFER)
return err;
if (!err) {
dev_info(priv->dev, "Read MAC address %pM from device tree\n", dev_info(priv->dev, "Read MAC address %pM from device tree\n",
priv->netdev->dev_addr); priv->netdev->dev_addr);
return; return 0;
} }
m = ioread32(priv->base + FTGMAC100_OFFSET_MAC_MADR); m = ioread32(priv->base + FTGMAC100_OFFSET_MAC_MADR);
...@@ -207,6 +211,8 @@ static void ftgmac100_initial_mac(struct ftgmac100 *priv) ...@@ -207,6 +211,8 @@ static void ftgmac100_initial_mac(struct ftgmac100 *priv)
dev_info(priv->dev, "Generated random MAC address %pM\n", dev_info(priv->dev, "Generated random MAC address %pM\n",
priv->netdev->dev_addr); priv->netdev->dev_addr);
} }
return 0;
} }
static int ftgmac100_set_mac_addr(struct net_device *dev, void *p) static int ftgmac100_set_mac_addr(struct net_device *dev, void *p)
...@@ -1843,7 +1849,9 @@ static int ftgmac100_probe(struct platform_device *pdev) ...@@ -1843,7 +1849,9 @@ static int ftgmac100_probe(struct platform_device *pdev)
priv->aneg_pause = true; priv->aneg_pause = true;
/* MAC address from chip or random one */ /* MAC address from chip or random one */
ftgmac100_initial_mac(priv); err = ftgmac100_initial_mac(priv);
if (err)
goto err_phy_connect;
np = pdev->dev.of_node; np = pdev->dev.of_node;
if (np && (of_device_is_compatible(np, "aspeed,ast2400-mac") || if (np && (of_device_is_compatible(np, "aspeed,ast2400-mac") ||
......
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