]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
net: phylink: avoid mvneta warning when setting pause parameters
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Thu, 28 Oct 2021 14:55:34 +0000 (15:55 +0100)
committerAndrea Righi <andrea.righi@canonical.com>
Tue, 4 Jan 2022 08:48:27 +0000 (09:48 +0100)
BugLink: https://bugs.launchpad.net/bugs/1951822
[ Upstream commit fd8d9731bcdfb22d28e45bce789bcb211c868c78 ]

mvneta does not support asymetric pause modes, and it flags this by the
lack of AsymPause in the supported field. When setting pause modes, we
check that pause->rx_pause == pause->tx_pause, but only when pause
autoneg is enabled. When pause autoneg is disabled, we still allow
pause->rx_pause != pause->tx_pause, which is incorrect when the MAC
does not support asymetric pause, and causes mvneta to issue a warning.

Fix this by removing the test for pause->autoneg, so we always check
that pause->rx_pause == pause->tx_pause for network devices that do not
support AsymPause.

Fixes: 9525ae83959b ("phylink: add phylink infrastructure")
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Paolo Pisati <paolo.pisati@canonical.com>
drivers/net/phy/phylink.c

index 5a58c77d00022f907e395be0af360586d2a3014c..7ec3105010ac1e4330ff6c2f6471d037c82ea133 100644 (file)
@@ -1727,7 +1727,7 @@ int phylink_ethtool_set_pauseparam(struct phylink *pl,
                return -EOPNOTSUPP;
 
        if (!phylink_test(pl->supported, Asym_Pause) &&
-           !pause->autoneg && pause->rx_pause != pause->tx_pause)
+           pause->rx_pause != pause->tx_pause)
                return -EINVAL;
 
        pause_state = 0;