[PATCH] net: phy: handle state correctly in phy_stop_machine

From: Zach Brown
Date: Wed Mar 22 2017 - 16:30:13 EST


From: Nathan Sullivan <nathan.sullivan@xxxxxx>

If the PHY is halted on stop, then do not set the state to PHY_UP. This
ensures the phy will be restarted later in phy_start when the machine is
started again.

Signed-off-by: Nathan Sullivan <nathan.sullivan@xxxxxx>
Signed-off-by: Brad Mouring <brad.mouring@xxxxxx>
Acked-by: Xander Huff <xander.huff@xxxxxx>
Acked-by: Kyle Roeschley <kyle.roeschley@xxxxxx>
---
drivers/net/phy/phy.c | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c
index 7cc1b7d..fe2d4c4 100644
--- a/drivers/net/phy/phy.c
+++ b/drivers/net/phy/phy.c
@@ -678,7 +678,7 @@ void phy_stop_machine(struct phy_device *phydev)
cancel_delayed_work_sync(&phydev->state_queue);

mutex_lock(&phydev->lock);
- if (phydev->state > PHY_UP)
+ if (phydev->state > PHY_UP && phydev->state != PHY_HALTED)
phydev->state = PHY_UP;
mutex_unlock(&phydev->lock);
}
--
2.7.4