mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-18 14:25:25 +00:00
net: dsa: Do not clobber PHY link outside of state machine
Calling phy_read_status() means that we may call into genphy_read_status() which in turn will use genphy_update_link() which can make changes to phydev->link outside of the state machine's state transitions. This is an invalid behavior that is now caught as of 811a919135b9 ("phy state machine: failsafe leave invalid RUNNING state") Reported-by: Zefir Kurtisi <zefir.kurtisi@neratec.com> Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Reviewed-by: Andrew Lunn <andrew@lunn.ch> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
6136c8fe53
commit
e69e462610
@ -684,14 +684,10 @@ dsa_slave_get_link_ksettings(struct net_device *dev,
|
|||||||
struct ethtool_link_ksettings *cmd)
|
struct ethtool_link_ksettings *cmd)
|
||||||
{
|
{
|
||||||
struct dsa_slave_priv *p = netdev_priv(dev);
|
struct dsa_slave_priv *p = netdev_priv(dev);
|
||||||
int err;
|
int err = -EOPNOTSUPP;
|
||||||
|
|
||||||
err = -EOPNOTSUPP;
|
if (p->phy != NULL)
|
||||||
if (p->phy != NULL) {
|
|
||||||
err = phy_read_status(p->phy);
|
|
||||||
if (err == 0)
|
|
||||||
err = phy_ethtool_ksettings_get(p->phy, cmd);
|
err = phy_ethtool_ksettings_get(p->phy, cmd);
|
||||||
}
|
|
||||||
|
|
||||||
return err;
|
return err;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user