Skip to content

Commit 6ac3ce8

Browse files
ffainellidavem330
authored andcommitted
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: 1c1008c ("net: bcmgenet: add main driver file") Signed-off-by: Florian Fainelli <f.fainelli@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 2c1bcaf commit 6ac3ce8

File tree

3 files changed

+0
-15
lines changed

3 files changed

+0
-15
lines changed

drivers/net/ethernet/broadcom/genet/bcmgenet.c

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -907,9 +907,6 @@ static void bcmgenet_power_up(struct bcmgenet_priv *priv,
907907
}
908908

909909
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
910-
911-
if (mode == GENET_POWER_PASSIVE)
912-
bcmgenet_mii_reset(priv->dev);
913910
}
914911

915912
/* ioctl handle special commands that are not present in ethtool. */

drivers/net/ethernet/broadcom/genet/bcmgenet.h

Lines changed: 0 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -672,7 +672,6 @@ GENET_IO_MACRO(rbuf, GENET_RBUF_OFF);
672672
int bcmgenet_mii_init(struct net_device *dev);
673673
int bcmgenet_mii_config(struct net_device *dev, bool init);
674674
void bcmgenet_mii_exit(struct net_device *dev);
675-
void bcmgenet_mii_reset(struct net_device *dev);
676675
void bcmgenet_phy_power_set(struct net_device *dev, bool enable);
677676
void bcmgenet_mii_setup(struct net_device *dev);
678677

drivers/net/ethernet/broadcom/genet/bcmmii.c

Lines changed: 0 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -163,16 +163,6 @@ void bcmgenet_mii_setup(struct net_device *dev)
163163
phy_print_status(phydev);
164164
}
165165

166-
void bcmgenet_mii_reset(struct net_device *dev)
167-
{
168-
struct bcmgenet_priv *priv = netdev_priv(dev);
169-
170-
if (priv->phydev) {
171-
phy_init_hw(priv->phydev);
172-
phy_start_aneg(priv->phydev);
173-
}
174-
}
175-
176166
void bcmgenet_phy_power_set(struct net_device *dev, bool enable)
177167
{
178168
struct bcmgenet_priv *priv = netdev_priv(dev);
@@ -215,7 +205,6 @@ static void bcmgenet_internal_phy_setup(struct net_device *dev)
215205
reg = bcmgenet_ext_readl(priv, EXT_EXT_PWR_MGMT);
216206
reg |= EXT_PWR_DN_EN_LD;
217207
bcmgenet_ext_writel(priv, reg, EXT_EXT_PWR_MGMT);
218-
bcmgenet_mii_reset(dev);
219208
}
220209

221210
static void bcmgenet_moca_phy_setup(struct bcmgenet_priv *priv)

0 commit comments

Comments
 (0)