net: phy: force phy suspend when calling phy_stop
authorJian Shen <shenjian15@huawei.com>
Wed, 28 Aug 2019 01:34:47 +0000 (09:34 +0800)
committerDavid S. Miller <davem@davemloft.net>
Wed, 28 Aug 2019 23:16:27 +0000 (16:16 -0700)
Some ethernet drivers may call phy_start() and phy_stop() from
ndo_open() and ndo_close() respectively.

When network cable is unconnected, and operate like below:
step 1: ifconfig ethX up -> ndo_open -> phy_start ->start
autoneg, and phy is no link.
step 2: ifconfig ethX down -> ndo_close -> phy_stop -> just stop
phy state machine.

This patch forces phy suspend even phydev->link is off.

Signed-off-by: Jian Shen <shenjian15@huawei.com>
Reviewed-by: Heiner Kallweit <hkallweit1@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/phy/phy.c

index f3adea9ef4000b0c4bbc6a69d880107fea3249dd..0acd5b49f45020057763ef8fac3d294c6e55d6b2 100644 (file)
@@ -911,8 +911,8 @@ void phy_state_machine(struct work_struct *work)
                if (phydev->link) {
                        phydev->link = 0;
                        phy_link_down(phydev, true);
-                       do_suspend = true;
                }
+               do_suspend = true;
                break;
        }