On Tue, Jan 05, 2021 at 05:58:21PM +0100, Heiner Kallweit wrote: > On 05.01.2021 17:11, Marek Vasut wrote: > > @@ -1021,8 +1022,17 @@ void phy_stop(struct phy_device *phydev) > > if (phydev->sfp_bus) > > sfp_upstream_stop(phydev->sfp_bus); > > > > + old_state = phydev->state; > > phydev->state = PHY_HALTED; > > > > + if (old_state != phydev->state) { > > This check shouldn't be needed because it shouldn't happen that > phy_stop() is called from status PHY_HALTED. In this case the > WARN() a few lines above would have fired already.
That is incorrect. If an error happens with the phy, phy_error() will be called, which sets phydev->state = PHY_HALTED. If you then subsequently take the interface down, phy_stop() will be called, but phydev->state will be set to PHY_HALTED. This is a long standing bug since you changed the code, and I think is something I've reported previously, since I've definitely encountered it. -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 40Mbps down 10Mbps up. Decent connectivity at last!