phy: make some bits preserved while setup forced mode
authorwangweidong <wangweidong1@huawei.com>
Thu, 14 Apr 2016 07:43:52 +0000 (15:43 +0800)
committerDavid S. Miller <davem@davemloft.net>
Sat, 16 Apr 2016 00:10:00 +0000 (20:10 -0400)
When tested the PHY SGMII Loopback:
1.set the LOOPBACK bit,
2.set the autoneg to AUTONEG_DISABLE, it calls the
genphy_setup_forced which will clear the bit.

The BMCR_LOOPBACK bit should be preserved.

As Florian pointed out that other bits should be preserved too.
So I make the BMCR_ISOLATE and BMCR_PDOWN as well.

Signed-off-by: Weidong Wang <wangweidong1@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/phy/phy_device.c

index e551f3a89cfd0212e381ec274c59f558eb07d2b0..10e39c2fbf81c6587c18b96c98b30e5f31368a72 100644 (file)
@@ -1123,8 +1123,9 @@ static int genphy_config_advert(struct phy_device *phydev)
  */
 int genphy_setup_forced(struct phy_device *phydev)
 {
-       int ctl = 0;
+       int ctl = phy_read(phydev, MII_BMCR);
 
+       ctl &= BMCR_LOOPBACK | BMCR_ISOLATE | BMCR_PDOWN;
        phydev->pause = 0;
        phydev->asym_pause = 0;