net: phy: introduce genphy_c45_pma_baset1_setup_master_slave()
authorOleksij Rempel <o.rempel@pengutronix.de>
Fri, 6 May 2022 04:23:52 +0000 (06:23 +0200)
committerDavid S. Miller <davem@davemloft.net>
Mon, 9 May 2022 11:09:29 +0000 (12:09 +0100)
Move baset1 specific part of genphy_c45_pma_setup_forced() code to
separate function to make it reusable by PHY drivers.

Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/phy/phy-c45.c
include/linux/phy.h

index 0014aa6e73c0e6c02ba8ef113198206e7e7eff7e..ffa2d5cd09fc646be6c70726656f3a0f36fd4c15 100644 (file)
@@ -70,6 +70,35 @@ int genphy_c45_pma_suspend(struct phy_device *phydev)
 }
 EXPORT_SYMBOL_GPL(genphy_c45_pma_suspend);
 
+/**
+ * genphy_c45_pma_baset1_setup_master_slave - configures forced master/slave
+ * role of BaseT1 devices.
+ * @phydev: target phy_device struct
+ */
+int genphy_c45_pma_baset1_setup_master_slave(struct phy_device *phydev)
+{
+       int ctl = 0;
+
+       switch (phydev->master_slave_set) {
+       case MASTER_SLAVE_CFG_MASTER_PREFERRED:
+       case MASTER_SLAVE_CFG_MASTER_FORCE:
+               ctl = MDIO_PMA_PMD_BT1_CTRL_CFG_MST;
+               break;
+       case MASTER_SLAVE_CFG_SLAVE_FORCE:
+       case MASTER_SLAVE_CFG_SLAVE_PREFERRED:
+       case MASTER_SLAVE_CFG_UNKNOWN:
+       case MASTER_SLAVE_CFG_UNSUPPORTED:
+               break;
+       default:
+               phydev_warn(phydev, "Unsupported Master/Slave mode\n");
+               return -EOPNOTSUPP;
+       }
+
+       return phy_modify_mmd(phydev, MDIO_MMD_PMAPMD, MDIO_PMA_PMD_BT1_CTRL,
+                            MDIO_PMA_PMD_BT1_CTRL_CFG_MST, ctl);
+}
+EXPORT_SYMBOL_GPL(genphy_c45_pma_baset1_setup_master_slave);
+
 /**
  * genphy_c45_pma_setup_forced - configures a forced speed
  * @phydev: target phy_device struct
@@ -141,25 +170,7 @@ int genphy_c45_pma_setup_forced(struct phy_device *phydev)
                return ret;
 
        if (genphy_c45_baset1_able(phydev)) {
-               int ctl = 0;
-
-               switch (phydev->master_slave_set) {
-               case MASTER_SLAVE_CFG_MASTER_PREFERRED:
-               case MASTER_SLAVE_CFG_MASTER_FORCE:
-                       ctl = MDIO_PMA_PMD_BT1_CTRL_CFG_MST;
-                       break;
-               case MASTER_SLAVE_CFG_SLAVE_FORCE:
-               case MASTER_SLAVE_CFG_SLAVE_PREFERRED:
-               case MASTER_SLAVE_CFG_UNKNOWN:
-               case MASTER_SLAVE_CFG_UNSUPPORTED:
-                       break;
-               default:
-                       phydev_warn(phydev, "Unsupported Master/Slave mode\n");
-                       return -EOPNOTSUPP;
-               }
-
-               ret = phy_modify_mmd(phydev, MDIO_MMD_PMAPMD, MDIO_PMA_PMD_BT1_CTRL,
-                                    MDIO_PMA_PMD_BT1_CTRL_CFG_MST, ctl);
+               ret = genphy_c45_pma_baset1_setup_master_slave(phydev);
                if (ret < 0)
                        return ret;
        }
index 2d12054932ba95ac0d1db6cd37d70a42573b6287..d3f924d3b235457790edc268d2fb05668cb5e71a 100644 (file)
@@ -1614,6 +1614,7 @@ int genphy_c45_read_link(struct phy_device *phydev);
 int genphy_c45_read_lpa(struct phy_device *phydev);
 int genphy_c45_read_pma(struct phy_device *phydev);
 int genphy_c45_pma_setup_forced(struct phy_device *phydev);
+int genphy_c45_pma_baset1_setup_master_slave(struct phy_device *phydev);
 int genphy_c45_an_config_aneg(struct phy_device *phydev);
 int genphy_c45_an_disable_aneg(struct phy_device *phydev);
 int genphy_c45_read_mdix(struct phy_device *phydev);