Message ID | E1qgoNu-007a4g-Ha@rmk-PC.armlinux.org.uk (mailing list archive) |
---|---|
State | Accepted |
Commit | adcbb85508c8bb181704154eec1dfe20554ddfe9 |
Delegated to: | Netdev Maintainers |
Headers | show |
Series | net: phy: avoid race when erroring stopping PHY | expand |
On 9/14/23 08:36, Russell King (Oracle) wrote: > Convert phy_stop() to use the new locked-section and unlocked-section > parts of the PHY state machine. > > Tested-by: Jijie Shao <shaojijie@huawei.com> > Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk> Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c index d78c2cc003ce..93a8676dd8d8 100644 --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c @@ -1467,6 +1467,7 @@ void phy_state_machine(struct work_struct *work) void phy_stop(struct phy_device *phydev) { struct net_device *dev = phydev->attached_dev; + enum phy_state_work state_work; enum phy_state old_state; if (!phy_is_started(phydev) && phydev->state != PHY_DOWN && @@ -1490,9 +1491,10 @@ void phy_stop(struct phy_device *phydev) phydev->state = PHY_HALTED; phy_process_state_change(phydev, old_state); + state_work = _phy_state_machine(phydev); mutex_unlock(&phydev->lock); - phy_state_machine(&phydev->state_queue.work); + _phy_state_machine_post_work(phydev, state_work); phy_stop_machine(phydev); /* Cannot call flush_scheduled_work() here as desired because