]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
net: stmmac: qcom-ethqos: fix qcom_ethqos_serdes_powerup()
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Fri, 6 Feb 2026 17:19:21 +0000 (17:19 +0000)
committerJakub Kicinski <kuba@kernel.org>
Wed, 11 Feb 2026 04:22:05 +0000 (20:22 -0800)
Add cleanup for failure paths in qcom_ethqos_serdes_powerup(). This
was missing calling phy_exit() and phy_power_off() at appropriate
failure points.

Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>
Tested-by: Mohd Ayaan Anwar <mohd.anwar@oss.qualcomm.com>
Reviewed-by: Mohd Ayaan Anwar <mohd.anwar@oss.qualcomm.com>
Link: https://patch.msgid.link/E1voPUH-000000083ji-25FH@rmk-PC.armlinux.org.uk
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/stmicro/stmmac/dwmac-qcom-ethqos.c

index 869f924f3cde2dada1b8298e9491c454788771a5..af8204c0e188ca8eaa9f31abeddda607f273b4a3 100644 (file)
@@ -659,10 +659,18 @@ static int qcom_ethqos_serdes_powerup(struct net_device *ndev, void *priv)
                return ret;
 
        ret = phy_power_on(ethqos->serdes_phy);
-       if (ret)
+       if (ret) {
+               phy_exit(ethqos->serdes_phy);
                return ret;
+       }
 
-       return phy_set_speed(ethqos->serdes_phy, ethqos->serdes_speed);
+       ret = phy_set_speed(ethqos->serdes_phy, ethqos->serdes_speed);
+       if (ret) {
+               phy_power_off(ethqos->serdes_phy);
+               phy_exit(ethqos->serdes_phy);
+       }
+
+       return ret;
 }
 
 static void qcom_ethqos_serdes_powerdown(struct net_device *ndev, void *priv)