]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: usb: lan78xx: port link settings to phylink API
authorOleksij Rempel <o.rempel@pengutronix.de>
Wed, 18 Jun 2025 12:26:00 +0000 (14:26 +0200)
committerJakub Kicinski <kuba@kernel.org>
Thu, 19 Jun 2025 22:37:06 +0000 (15:37 -0700)
Refactor lan78xx_get_link_ksettings and lan78xx_set_link_ksettings to
use the phylink API (phylink_ethtool_ksettings_get and
phylink_ethtool_ksettings_set) instead of directly interfacing with the
PHY. This change simplifies the code and ensures better integration with
the phylink framework for link management.

Additionally, the explicit calls to usb_autopm_get_interface() and
usb_autopm_put_interface() have been removed. These were originally
needed to manage USB power management during register accesses. However,
lan78xx_mdiobus_read() and lan78xx_mdiobus_write() already handle USB
auto power management internally, ensuring that the interface remains
active when necessary. Since there are no other direct register accesses
in these functions that require explicit power management handling, the
extra calls have become redundant and are no longer needed.

Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
Reviewed-by: Maxime Chevallier <maxime.chevallier@bootlin.com>
Reviewed-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Link: https://patch.msgid.link/20250618122602.3156678-5-o.rempel@pengutronix.de
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/usb/lan78xx.c

index 9bb1d2527d0ca4ea566b0ec276d4e55b60015c2c..8df0a2323fb9a5dd5c0d528c0f78ba81d6b136db 100644 (file)
@@ -1866,46 +1866,16 @@ static int lan78xx_get_link_ksettings(struct net_device *net,
                                      struct ethtool_link_ksettings *cmd)
 {
        struct lan78xx_net *dev = netdev_priv(net);
-       struct phy_device *phydev = net->phydev;
-       int ret;
-
-       ret = usb_autopm_get_interface(dev->intf);
-       if (ret < 0)
-               return ret;
 
-       phy_ethtool_ksettings_get(phydev, cmd);
-
-       usb_autopm_put_interface(dev->intf);
-
-       return ret;
+       return phylink_ethtool_ksettings_get(dev->phylink, cmd);
 }
 
 static int lan78xx_set_link_ksettings(struct net_device *net,
                                      const struct ethtool_link_ksettings *cmd)
 {
        struct lan78xx_net *dev = netdev_priv(net);
-       struct phy_device *phydev = net->phydev;
-       int ret = 0;
-       int temp;
-
-       ret = usb_autopm_get_interface(dev->intf);
-       if (ret < 0)
-               return ret;
-
-       /* change speed & duplex */
-       ret = phy_ethtool_ksettings_set(phydev, cmd);
 
-       if (!cmd->base.autoneg) {
-               /* force link down */
-               temp = phy_read(phydev, MII_BMCR);
-               phy_write(phydev, MII_BMCR, temp | BMCR_LOOPBACK);
-               mdelay(1);
-               phy_write(phydev, MII_BMCR, temp);
-       }
-
-       usb_autopm_put_interface(dev->intf);
-
-       return ret;
+       return phylink_ethtool_ksettings_set(dev->phylink, cmd);
 }
 
 static void lan78xx_get_pause(struct net_device *net,