Use either USXGMII or XFI in aquantia_set_proto and drop XGMII as a valid
protocol configuration.  The PHY doesn't support it, it's just used as an
alias for one of the other two protocols.

Signed-off-by: Florin Chiculita <florinlaurentiu.chicul...@nxp.com>
Signed-off-by: Alex Marginean <alexandru.margin...@nxp.com>
---

Depends on:
https://patchwork.ozlabs.org/project/uboot/list/?series=142879

 drivers/net/phy/aquantia.c | 17 +++++++++--------
 1 file changed, 9 insertions(+), 8 deletions(-)

diff --git a/drivers/net/phy/aquantia.c b/drivers/net/phy/aquantia.c
index 7817d3cb8d..2af09907a1 100644
--- a/drivers/net/phy/aquantia.c
+++ b/drivers/net/phy/aquantia.c
@@ -303,30 +303,29 @@ struct {
                                           AQUANTIA_VND1_GSTART_RATE_1G},
        [PHY_INTERFACE_MODE_SGMII_2500] = {0x144, AQUANTIA_VND1_GSYSCFG_2_5G,
                                           AQUANTIA_VND1_GSTART_RATE_2_5G},
-       [PHY_INTERFACE_MODE_XGMII] =      {0x100, AQUANTIA_VND1_GSYSCFG_10G,
-                                          AQUANTIA_VND1_GSTART_RATE_10G},
        [PHY_INTERFACE_MODE_XFI] =        {0x100, AQUANTIA_VND1_GSYSCFG_10G,
                                           AQUANTIA_VND1_GSTART_RATE_10G},
        [PHY_INTERFACE_MODE_USXGMII] =    {0x080, AQUANTIA_VND1_GSYSCFG_10G,
                                           AQUANTIA_VND1_GSTART_RATE_10G},
 };
 
-static int aquantia_set_proto(struct phy_device *phydev)
+static int aquantia_set_proto(struct phy_device *phydev,
+                             phy_interface_t interface)
 {
        int i;
 
-       if (!aquantia_syscfg[phydev->interface].cnt)
+       if (!aquantia_syscfg[interface].cnt)
                return 0;
 
        /* set the default rate to enable the SI link */
        phy_write(phydev, MDIO_MMD_VEND1, AQUANTIA_VND1_GSTART_RATE,
-                 aquantia_syscfg[phydev->interface].start_rate);
+                 aquantia_syscfg[interface].start_rate);
 
        /* set selected protocol for all relevant line side link speeds */
-       for (i = 0; i <= aquantia_syscfg[phydev->interface].cnt; i++)
+       for (i = 0; i <= aquantia_syscfg[interface].cnt; i++)
                phy_write(phydev, MDIO_MMD_VEND1,
                          AQUANTIA_VND1_GSYSCFG_BASE + i,
-                         aquantia_syscfg[phydev->interface].syscfg);
+                         aquantia_syscfg[interface].syscfg);
        return 0;
 }
 
@@ -429,6 +428,8 @@ int aquantia_config(struct phy_device *phydev)
         * on FW config
         */
        if (interface == PHY_INTERFACE_MODE_XGMII) {
+               debug("use XFI or USXGMII SI protos, XGMII is not valid\n");
+
                reg_val1 = phy_read(phydev, MDIO_MMD_PHYXS,
                                    AQUANTIA_SYSTEM_INTERFACE_SR);
                if ((reg_val1 & AQUANTIA_SI_IN_USE_MASK) == AQUANTIA_SI_USXGMII)
@@ -451,7 +452,7 @@ int aquantia_config(struct phy_device *phydev)
                mdelay(10);
 
                /* configure protocol based on phydev->interface */
-               aquantia_set_proto(phydev);
+               aquantia_set_proto(phydev, interface);
                /* apply custom configuration based on DT */
                aquantia_dts_config(phydev);
 
-- 
2.17.1

Reply via email to