Commit be8c6480 authored by Arnaud Patard's avatar Arnaud Patard Committed by David S. Miller

phy/marvell: fix 88e1121 support

Commit c477d044 added support for RGMII
rx/tx delays except that it ends up clearing rx/tx delays bit for modes
differents that RGMII*ID. Due to this, ethernet is not working anymore
on my guruplug server +. This patch is fixing that.
Signed-off-by: default avatarArnaud Patard <arnaud.patard@rtp-net.org>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 27ab7606
...@@ -196,20 +196,27 @@ static int m88e1121_config_aneg(struct phy_device *phydev) ...@@ -196,20 +196,27 @@ static int m88e1121_config_aneg(struct phy_device *phydev)
MII_88E1121_PHY_MSCR_PAGE); MII_88E1121_PHY_MSCR_PAGE);
if (err < 0) if (err < 0)
return err; return err;
mscr = phy_read(phydev, MII_88E1121_PHY_MSCR_REG) &
MII_88E1121_PHY_MSCR_DELAY_MASK;
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) if ((phydev->interface == PHY_INTERFACE_MODE_RGMII) ||
mscr |= (MII_88E1121_PHY_MSCR_RX_DELAY | (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) ||
MII_88E1121_PHY_MSCR_TX_DELAY); (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) ||
else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)) {
mscr |= MII_88E1121_PHY_MSCR_RX_DELAY;
else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
mscr |= MII_88E1121_PHY_MSCR_TX_DELAY;
err = phy_write(phydev, MII_88E1121_PHY_MSCR_REG, mscr); mscr = phy_read(phydev, MII_88E1121_PHY_MSCR_REG) &
if (err < 0) MII_88E1121_PHY_MSCR_DELAY_MASK;
return err;
if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID)
mscr |= (MII_88E1121_PHY_MSCR_RX_DELAY |
MII_88E1121_PHY_MSCR_TX_DELAY);
else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID)
mscr |= MII_88E1121_PHY_MSCR_RX_DELAY;
else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID)
mscr |= MII_88E1121_PHY_MSCR_TX_DELAY;
err = phy_write(phydev, MII_88E1121_PHY_MSCR_REG, mscr);
if (err < 0)
return err;
}
phy_write(phydev, MII_88E1121_PHY_PAGE, oldpage); phy_write(phydev, MII_88E1121_PHY_PAGE, oldpage);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment