net: bcmgenet: Remove excessive PHY reset
We are currently issuing multiple PHY resets during a suspend/resume,
first during bcmgenet_power_up() which does a hardware reset, then a
software reset by calling bcmgenet_mii_reset(). This is both unnecessary
and can take as long as 10ms per MDIO transactions while we re-apply
workarounds because we do not yet have MDIO interrupts enabled.
phy_resume() takes care of re-apply our workarounds in case we need any,
and bcmgenet_power_up() does a PHY hardware reset, all of this is more
than enough to guarantee that the PHY operates correctly.
Fixes: 1c1008c793
("net: bcmgenet: add main driver file")
Signed-off-by: Florian Fainelli <f.fainelli@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
2c1bcaffe8
commit
6ac3ce8295
3 changed files with 0 additions and 15 deletions
|
@ -907,9 +907,6 @@ static void bcmgenet_power_up(struct bcmgenet_priv *priv,
|
||||||
}
|
}
|
||||||
|
|
||||||
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
|
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
|
||||||
|
|
||||||
if (mode == GENET_POWER_PASSIVE)
|
|
||||||
bcmgenet_mii_reset(priv->dev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ioctl handle special commands that are not present in ethtool. */
|
/* ioctl handle special commands that are not present in ethtool. */
|
||||||
|
|
|
@ -672,7 +672,6 @@ GENET_IO_MACRO(rbuf, GENET_RBUF_OFF);
|
||||||
int bcmgenet_mii_init(struct net_device *dev);
|
int bcmgenet_mii_init(struct net_device *dev);
|
||||||
int bcmgenet_mii_config(struct net_device *dev, bool init);
|
int bcmgenet_mii_config(struct net_device *dev, bool init);
|
||||||
void bcmgenet_mii_exit(struct net_device *dev);
|
void bcmgenet_mii_exit(struct net_device *dev);
|
||||||
void bcmgenet_mii_reset(struct net_device *dev);
|
|
||||||
void bcmgenet_phy_power_set(struct net_device *dev, bool enable);
|
void bcmgenet_phy_power_set(struct net_device *dev, bool enable);
|
||||||
void bcmgenet_mii_setup(struct net_device *dev);
|
void bcmgenet_mii_setup(struct net_device *dev);
|
||||||
|
|
||||||
|
|
|
@ -163,16 +163,6 @@ void bcmgenet_mii_setup(struct net_device *dev)
|
||||||
phy_print_status(phydev);
|
phy_print_status(phydev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void bcmgenet_mii_reset(struct net_device *dev)
|
|
||||||
{
|
|
||||||
struct bcmgenet_priv *priv = netdev_priv(dev);
|
|
||||||
|
|
||||||
if (priv->phydev) {
|
|
||||||
phy_init_hw(priv->phydev);
|
|
||||||
phy_start_aneg(priv->phydev);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void bcmgenet_phy_power_set(struct net_device *dev, bool enable)
|
void bcmgenet_phy_power_set(struct net_device *dev, bool enable)
|
||||||
{
|
{
|
||||||
struct bcmgenet_priv *priv = netdev_priv(dev);
|
struct bcmgenet_priv *priv = netdev_priv(dev);
|
||||||
|
@ -215,7 +205,6 @@ static void bcmgenet_internal_phy_setup(struct net_device *dev)
|
||||||
reg = bcmgenet_ext_readl(priv, EXT_EXT_PWR_MGMT);
|
reg = bcmgenet_ext_readl(priv, EXT_EXT_PWR_MGMT);
|
||||||
reg |= EXT_PWR_DN_EN_LD;
|
reg |= EXT_PWR_DN_EN_LD;
|
||||||
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
|
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
|
||||||
bcmgenet_mii_reset(dev);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void bcmgenet_moca_phy_setup(struct bcmgenet_priv *priv)
|
static void bcmgenet_moca_phy_setup(struct bcmgenet_priv *priv)
|
||||||
|
|
Loading…
Reference in a new issue