]> 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>
Wed, 29 Oct 2025 13:01:19 +0000 (14:01 +0100)
[ 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 8926011604e398147376d60ec7579f757451d544..9cd6dac03363087915cd71904f6be4046239b93a 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 19fed56b6ee3fdd7d22b5168efcc2aa61059616c..ebb8b3e5b9a8829b152290d2e32de1d414d22aa8 100644 (file)
@@ -1636,6 +1636,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;