]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
amd-xgbe: Avoid spurious link down messages during interface toggle
authorRaju Rangoju <Raju.Rangoju@amd.com>
Fri, 10 Oct 2025 06:51:42 +0000 (12:21 +0530)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 23 Oct 2025 14:20:29 +0000 (16:20 +0200)
[ Upstream commit 2616222e423398bb374ffcb5d23dea4ba2c3e524 ]

During interface toggle operations (ifdown/ifup), the driver currently
resets the local helper variable 'phy_link' to -1. This causes the link
state machine to incorrectly interpret the state as a link change event,
resulting in spurious "Link is down" messages being logged when the
interface is brought back up.

Preserve the phy_link state across interface toggles to avoid treating
the -1 sentinel value as a legitimate link state transition.

Fixes: 88131a812b16 ("amd-xgbe: Perform phy connect/disconnect at dev open/stop")
Signed-off-by: Raju Rangoju <Raju.Rangoju@amd.com>
Reviewed-by: Dawid Osuchowski <dawid.osuchowski@linux.intel.com>
Link: https://patch.msgid.link/20251010065142.1189310-1-Raju.Rangoju@amd.com
Signed-off-by: Paolo Abeni <pabeni@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/ethernet/amd/xgbe/xgbe-drv.c
drivers/net/ethernet/amd/xgbe/xgbe-mdio.c

index 8bc49259d71af1cd2db782bd0a20d6dc0242cf43..32a6d52614242c9ff38b234cbc2de6161ba7214a 100644 (file)
@@ -1172,7 +1172,6 @@ static void xgbe_free_rx_data(struct xgbe_prv_data *pdata)
 
 static int xgbe_phy_reset(struct xgbe_prv_data *pdata)
 {
-       pdata->phy_link = -1;
        pdata->phy_speed = SPEED_UNKNOWN;
 
        return pdata->phy_if.phy_reset(pdata);
index ed76a8df6ec6ed940e180662fb6ca3062d8b37bd..75e9cb3fc7aa66abaddd06967e304e25c5425a49 100644 (file)
@@ -1664,6 +1664,7 @@ static int xgbe_phy_init(struct xgbe_prv_data *pdata)
                pdata->phy.duplex = DUPLEX_FULL;
        }
 
+       pdata->phy_link = 0;
        pdata->phy.link = 0;
 
        pdata->phy.pause_autoneg = pdata->pause_autoneg;