net: phy: add phy_config_inband()
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Tue, 3 Dec 2024 15:31:18 +0000 (15:31 +0000)
committerJakub Kicinski <kuba@kernel.org>
Thu, 5 Dec 2024 03:19:07 +0000 (19:19 -0800)
Add a method to configure the PHY's in-band mode.

Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Link: https://patch.msgid.link/E1tIUru-006IUI-08@rmk-PC.armlinux.org.uk
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/phy/phy.c
include/linux/phy.h

index f42cd658484182041012d41d2b3ac600df256e22..0c228aa1801984df23166256acfe2e579afb0db4 100644 (file)
@@ -1026,6 +1026,38 @@ unsigned int phy_inband_caps(struct phy_device *phydev,
 }
 EXPORT_SYMBOL_GPL(phy_inband_caps);
 
+/**
+ * phy_config_inband - configure the desired PHY in-band mode
+ * @phydev: the phy_device struct
+ * @modes: in-band modes to configure
+ *
+ * Description: disables, enables or enables-with-bypass in-band signalling
+ *   between the PHY and host system.
+ *
+ * Returns: zero on success, or negative errno value.
+ */
+int phy_config_inband(struct phy_device *phydev, unsigned int modes)
+{
+       int err;
+
+       if (!!(modes & LINK_INBAND_DISABLE) +
+           !!(modes & LINK_INBAND_ENABLE) +
+           !!(modes & LINK_INBAND_BYPASS) != 1)
+               return -EINVAL;
+
+       mutex_lock(&phydev->lock);
+       if (!phydev->drv)
+               err = -EIO;
+       else if (!phydev->drv->config_inband)
+               err = -EOPNOTSUPP;
+       else
+               err = phydev->drv->config_inband(phydev, modes);
+       mutex_unlock(&phydev->lock);
+
+       return err;
+}
+EXPORT_SYMBOL(phy_config_inband);
+
 /**
  * _phy_start_aneg - start auto-negotiation for this PHY device
  * @phydev: the phy_device struct
index ccb93d892da9477ed9af855d9d6d51f8c94a1d07..61a1bc81f597fcaaaf5fcc8c837f1039b004cb26 100644 (file)
@@ -982,6 +982,11 @@ struct phy_driver {
        unsigned int (*inband_caps)(struct phy_device *phydev,
                                    phy_interface_t interface);
 
+       /**
+        * @config_inband: configure in-band mode for the PHY
+        */
+       int (*config_inband)(struct phy_device *phydev, unsigned int modes);
+
        /**
         * @get_rate_matching: Get the supported type of rate matching for a
         * particular phy interface. This is used by phy consumers to determine
@@ -1846,6 +1851,7 @@ int phy_start_aneg(struct phy_device *phydev);
 int phy_aneg_done(struct phy_device *phydev);
 unsigned int phy_inband_caps(struct phy_device *phydev,
                             phy_interface_t interface);
+int phy_config_inband(struct phy_device *phydev, unsigned int modes);
 int phy_speed_down(struct phy_device *phydev, bool sync);
 int phy_speed_up(struct phy_device *phydev);
 bool phy_check_valid(int speed, int duplex, unsigned long *features);