Skip to content

Commit

Permalink
net: phy: marvell: consolidate RGMII delay code
Browse files Browse the repository at this point in the history
The same code is repeated for different PHY versions. Put it into a
help and call when needed.

Signed-off-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
  • Loading branch information
Andrew Lunn authored and David S. Miller committed Aug 1, 2017
1 parent 3438634 commit 6111159
Showing 1 changed file with 22 additions and 32 deletions.
54 changes: 22 additions & 32 deletions drivers/net/phy/marvell.c
Original file line number Diff line number Diff line change
Expand Up @@ -61,13 +61,6 @@
#define MII_M1011_PHY_SCR_AUTO_CROSS 0x0060

#define MII_M1145_PHY_EXT_SR 0x1b
#define MII_M1145_PHY_EXT_CR 0x14
#define MII_M1145_RGMII_RX_DELAY 0x0080
#define MII_M1145_RGMII_TX_DELAY 0x0002
#define MII_M1145_HWCFG_MODE_SGMII_NO_CLK 0x4
#define MII_M1145_HWCFG_MODE_MASK 0xf
#define MII_M1145_HWCFG_FIBER_COPPER_AUTO 0x8000

#define MII_M1145_HWCFG_MODE_SGMII_NO_CLK 0x4
#define MII_M1145_HWCFG_MODE_MASK 0xf
#define MII_M1145_HWCFG_FIBER_COPPER_AUTO 0x8000
Expand All @@ -76,8 +69,8 @@
#define MII_M1111_PHY_LED_DIRECT 0x4100
#define MII_M1111_PHY_LED_COMBINE 0x411c
#define MII_M1111_PHY_EXT_CR 0x14
#define MII_M1111_RX_DELAY 0x80
#define MII_M1111_TX_DELAY 0x2
#define MII_M1111_RGMII_RX_DELAY BIT(7)
#define MII_M1111_RGMII_TX_DELAY BIT(1)
#define MII_M1111_PHY_EXT_SR 0x1b

#define MII_M1111_HWCFG_MODE_MASK 0xf
Expand Down Expand Up @@ -700,26 +693,33 @@ static int m88e3016_config_init(struct phy_device *phydev)
return marvell_config_init(phydev);
}

static int m88e1111_config_init_rgmii(struct phy_device *phydev)
static int m88e1111_config_init_rgmii_delays(struct phy_device *phydev)
{
int err;
int temp;

temp = phy_read(phydev, MII_M1111_PHY_EXT_CR);
if (temp < 0)
return temp;

if (phydev->interface == PHY_INTERFACE_MODE_RGMII_ID) {
temp |= (MII_M1111_RX_DELAY | MII_M1111_TX_DELAY);
temp |= (MII_M1111_RGMII_RX_DELAY | MII_M1111_RGMII_TX_DELAY);
} else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID) {
temp &= ~MII_M1111_TX_DELAY;
temp |= MII_M1111_RX_DELAY;
temp &= ~MII_M1111_RGMII_TX_DELAY;
temp |= MII_M1111_RGMII_RX_DELAY;
} else if (phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID) {
temp &= ~MII_M1111_RX_DELAY;
temp |= MII_M1111_TX_DELAY;
temp &= ~MII_M1111_RGMII_RX_DELAY;
temp |= MII_M1111_RGMII_TX_DELAY;
}

err = phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
return phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
}

static int m88e1111_config_init_rgmii(struct phy_device *phydev)
{
int temp;
int err;

err = m88e1111_config_init_rgmii_delays(phydev);
if (err < 0)
return err;

Expand Down Expand Up @@ -760,16 +760,11 @@ static int m88e1111_config_init_sgmii(struct phy_device *phydev)

static int m88e1111_config_init_rtbi(struct phy_device *phydev)
{
int err;
int temp;
int err;

temp = phy_read(phydev, MII_M1111_PHY_EXT_CR);
if (temp < 0)
return temp;

temp |= (MII_M1111_RX_DELAY | MII_M1111_TX_DELAY);
err = phy_write(phydev, MII_M1111_PHY_EXT_CR, temp);
if (err < 0)
err = m88e1111_config_init_rgmii_delays(phydev);
if (err)
return err;

temp = phy_read(phydev, MII_M1111_PHY_EXT_SR);
Expand Down Expand Up @@ -969,15 +964,10 @@ static int m88e1149_config_init(struct phy_device *phydev)

static int m88e1145_config_init_rgmii(struct phy_device *phydev)
{
int temp;
int err;
int temp = phy_read(phydev, MII_M1145_PHY_EXT_CR);

if (temp < 0)
return temp;

temp |= (MII_M1145_RGMII_RX_DELAY | MII_M1145_RGMII_TX_DELAY);

err = phy_write(phydev, MII_M1145_PHY_EXT_CR, temp);
err = m88e1111_config_init_rgmii_delays(phydev);
if (err < 0)
return err;

Expand Down

0 comments on commit 6111159

Please sign in to comment.