From: Tejas Bhumkar Date: Fri, 15 Sep 2023 04:50:43 +0000 (+0530) Subject: net: phy: xilinx-gmii2rgmii: Removed hardcoded phy address 0 for bridge X-Git-Tag: v2025.01-rc5-pxa1908~847^2~5^2~15 X-Git-Url: http://git.dujemihanovic.xyz/posts?a=commitdiff_plain;h=e31d707d8b591973560cb656d152a154993b1d74;p=u-boot.git net: phy: xilinx-gmii2rgmii: Removed hardcoded phy address 0 for bridge Current code expects bridge phy address at 0 which is not correct expectation because bridge phy address is configurable. That's why update the code to read reg property to figure it out where bridge is and use it in phy creation code. Signed-off-by: Tejas Bhumkar Signed-off-by: Michal Simek Link: https://lore.kernel.org/r/20230915045043.4167628-1-tejas.arvind.bhumkar@amd.com --- diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c index d50fd505e5..63b3e46f10 100644 --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c @@ -807,7 +807,10 @@ static struct phy_device *phy_connect_gmii2rgmii(struct mii_dev *bus, ofnode_for_each_subnode(node, dev_ofnode(dev)) { node = ofnode_by_compatible(node, "xlnx,gmii-to-rgmii-1.0"); if (ofnode_valid(node)) { - phydev = phy_device_create(bus, 0, + int gmiirgmii_phyaddr; + + gmiirgmii_phyaddr = ofnode_read_u32_default(node, "reg", 0); + phydev = phy_device_create(bus, gmiirgmii_phyaddr, PHY_GMII2RGMII_ID, false); if (phydev) phydev->node = node;