Commit ddb2d2a8 authored by Jakub Kicinski's avatar Jakub Kicinski

Merge branch 'net-eee-network-driver-cleanups'

Russell King says:

====================
net: eee network driver cleanups

Since commit d1420bb9 ("net: phy: improve generic EEE ethtool
functions") changed phylib to set eee->eee_active and eee->eee_enabled,
overriding anything that drivers have set these to prior to calling
phy_ethtool_get_eee().

Therefore, drivers setting these members becomes redundant, since
phylib overwrites the values they set. This series finishes off
Heiner's work in the referenced commit by removing these redundant
writes in various drivers and any associated code or structure members
that become unnecessary.
====================

Link: https://lore.kernel.org/r/Zb9/O81fVAZw4ANr@shell.armlinux.org.ukSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parents 1e8f1477 3465df55
...@@ -2227,16 +2227,10 @@ EXPORT_SYMBOL(b53_eee_init); ...@@ -2227,16 +2227,10 @@ EXPORT_SYMBOL(b53_eee_init);
int b53_get_mac_eee(struct dsa_switch *ds, int port, struct ethtool_keee *e) int b53_get_mac_eee(struct dsa_switch *ds, int port, struct ethtool_keee *e)
{ {
struct b53_device *dev = ds->priv; struct b53_device *dev = ds->priv;
struct ethtool_keee *p = &dev->ports[port].eee;
u16 reg;
if (is5325(dev) || is5365(dev)) if (is5325(dev) || is5365(dev))
return -EOPNOTSUPP; return -EOPNOTSUPP;
b53_read16(dev, B53_EEE_PAGE, B53_EEE_LPI_INDICATE, &reg);
e->eee_enabled = p->eee_enabled;
e->eee_active = !!(reg & BIT(port));
return 0; return 0;
} }
EXPORT_SYMBOL(b53_get_mac_eee); EXPORT_SYMBOL(b53_get_mac_eee);
......
...@@ -360,7 +360,6 @@ void bcmasp_eee_enable_set(struct bcmasp_intf *intf, bool enable) ...@@ -360,7 +360,6 @@ void bcmasp_eee_enable_set(struct bcmasp_intf *intf, bool enable)
umac_wl(intf, reg, UMC_EEE_CTRL); umac_wl(intf, reg, UMC_EEE_CTRL);
intf->eee.eee_enabled = enable; intf->eee.eee_enabled = enable;
intf->eee.eee_active = enable;
} }
static int bcmasp_get_eee(struct net_device *dev, struct ethtool_keee *e) static int bcmasp_get_eee(struct net_device *dev, struct ethtool_keee *e)
...@@ -371,8 +370,6 @@ static int bcmasp_get_eee(struct net_device *dev, struct ethtool_keee *e) ...@@ -371,8 +370,6 @@ static int bcmasp_get_eee(struct net_device *dev, struct ethtool_keee *e)
if (!dev->phydev) if (!dev->phydev)
return -ENODEV; return -ENODEV;
e->eee_enabled = p->eee_enabled;
e->eee_active = p->eee_active;
e->tx_lpi_enabled = p->tx_lpi_enabled; e->tx_lpi_enabled = p->tx_lpi_enabled;
e->tx_lpi_timer = umac_rl(intf, UMC_EEE_LPI_TIMER); e->tx_lpi_timer = umac_rl(intf, UMC_EEE_LPI_TIMER);
...@@ -399,7 +396,6 @@ static int bcmasp_set_eee(struct net_device *dev, struct ethtool_keee *e) ...@@ -399,7 +396,6 @@ static int bcmasp_set_eee(struct net_device *dev, struct ethtool_keee *e)
} }
umac_wl(intf, e->tx_lpi_timer, UMC_EEE_LPI_TIMER); umac_wl(intf, e->tx_lpi_timer, UMC_EEE_LPI_TIMER);
intf->eee.eee_active = ret >= 0;
intf->eee.tx_lpi_enabled = e->tx_lpi_enabled; intf->eee.tx_lpi_enabled = e->tx_lpi_enabled;
bcmasp_eee_enable_set(intf, true); bcmasp_eee_enable_set(intf, true);
} }
......
...@@ -607,6 +607,7 @@ static void bcmasp_adj_link(struct net_device *dev) ...@@ -607,6 +607,7 @@ static void bcmasp_adj_link(struct net_device *dev)
struct phy_device *phydev = dev->phydev; struct phy_device *phydev = dev->phydev;
u32 cmd_bits = 0, reg; u32 cmd_bits = 0, reg;
int changed = 0; int changed = 0;
bool active;
if (intf->old_link != phydev->link) { if (intf->old_link != phydev->link) {
changed = 1; changed = 1;
...@@ -658,8 +659,8 @@ static void bcmasp_adj_link(struct net_device *dev) ...@@ -658,8 +659,8 @@ static void bcmasp_adj_link(struct net_device *dev)
reg |= cmd_bits; reg |= cmd_bits;
umac_wl(intf, reg, UMC_CMD); umac_wl(intf, reg, UMC_CMD);
intf->eee.eee_active = phy_init_eee(phydev, 0) >= 0; active = phy_init_eee(phydev, 0) >= 0;
bcmasp_eee_enable_set(intf, intf->eee.eee_active); bcmasp_eee_enable_set(intf, active);
} }
reg = rgmii_rl(intf, RGMII_OOB_CNTRL); reg = rgmii_rl(intf, RGMII_OOB_CNTRL);
......
...@@ -1313,7 +1313,6 @@ void bcmgenet_eee_enable_set(struct net_device *dev, bool enable, ...@@ -1313,7 +1313,6 @@ void bcmgenet_eee_enable_set(struct net_device *dev, bool enable,
} }
priv->eee.eee_enabled = enable; priv->eee.eee_enabled = enable;
priv->eee.eee_active = enable;
priv->eee.tx_lpi_enabled = tx_lpi_enabled; priv->eee.tx_lpi_enabled = tx_lpi_enabled;
} }
...@@ -1328,8 +1327,6 @@ static int bcmgenet_get_eee(struct net_device *dev, struct ethtool_keee *e) ...@@ -1328,8 +1327,6 @@ static int bcmgenet_get_eee(struct net_device *dev, struct ethtool_keee *e)
if (!dev->phydev) if (!dev->phydev)
return -ENODEV; return -ENODEV;
e->eee_enabled = p->eee_enabled;
e->eee_active = p->eee_active;
e->tx_lpi_enabled = p->tx_lpi_enabled; e->tx_lpi_enabled = p->tx_lpi_enabled;
e->tx_lpi_timer = bcmgenet_umac_readl(priv, UMAC_EEE_LPI_TIMER); e->tx_lpi_timer = bcmgenet_umac_readl(priv, UMAC_EEE_LPI_TIMER);
...@@ -1340,6 +1337,7 @@ static int bcmgenet_set_eee(struct net_device *dev, struct ethtool_keee *e) ...@@ -1340,6 +1337,7 @@ static int bcmgenet_set_eee(struct net_device *dev, struct ethtool_keee *e)
{ {
struct bcmgenet_priv *priv = netdev_priv(dev); struct bcmgenet_priv *priv = netdev_priv(dev);
struct ethtool_keee *p = &priv->eee; struct ethtool_keee *p = &priv->eee;
bool active;
if (GENET_IS_V1(priv)) if (GENET_IS_V1(priv))
return -EOPNOTSUPP; return -EOPNOTSUPP;
...@@ -1352,9 +1350,9 @@ static int bcmgenet_set_eee(struct net_device *dev, struct ethtool_keee *e) ...@@ -1352,9 +1350,9 @@ static int bcmgenet_set_eee(struct net_device *dev, struct ethtool_keee *e)
if (!p->eee_enabled) { if (!p->eee_enabled) {
bcmgenet_eee_enable_set(dev, false, false); bcmgenet_eee_enable_set(dev, false, false);
} else { } else {
p->eee_active = phy_init_eee(dev->phydev, false) >= 0; active = phy_init_eee(dev->phydev, false) >= 0;
bcmgenet_umac_writel(priv, e->tx_lpi_timer, UMAC_EEE_LPI_TIMER); bcmgenet_umac_writel(priv, e->tx_lpi_timer, UMAC_EEE_LPI_TIMER);
bcmgenet_eee_enable_set(dev, p->eee_active, e->tx_lpi_enabled); bcmgenet_eee_enable_set(dev, active, e->tx_lpi_enabled);
} }
return phy_ethtool_set_eee(dev->phydev, e); return phy_ethtool_set_eee(dev->phydev, e);
......
...@@ -30,6 +30,7 @@ static void bcmgenet_mac_config(struct net_device *dev) ...@@ -30,6 +30,7 @@ static void bcmgenet_mac_config(struct net_device *dev)
struct bcmgenet_priv *priv = netdev_priv(dev); struct bcmgenet_priv *priv = netdev_priv(dev);
struct phy_device *phydev = dev->phydev; struct phy_device *phydev = dev->phydev;
u32 reg, cmd_bits = 0; u32 reg, cmd_bits = 0;
bool active;
/* speed */ /* speed */
if (phydev->speed == SPEED_1000) if (phydev->speed == SPEED_1000)
...@@ -88,9 +89,9 @@ static void bcmgenet_mac_config(struct net_device *dev) ...@@ -88,9 +89,9 @@ static void bcmgenet_mac_config(struct net_device *dev)
} }
bcmgenet_umac_writel(priv, reg, UMAC_CMD); bcmgenet_umac_writel(priv, reg, UMAC_CMD);
priv->eee.eee_active = phy_init_eee(phydev, 0) >= 0; active = phy_init_eee(phydev, 0) >= 0;
bcmgenet_eee_enable_set(dev, bcmgenet_eee_enable_set(dev,
priv->eee.eee_enabled && priv->eee.eee_active, priv->eee.eee_enabled && active,
priv->eee.tx_lpi_enabled); priv->eee.tx_lpi_enabled);
} }
......
...@@ -3139,8 +3139,6 @@ static int fec_enet_eee_mode_set(struct net_device *ndev, bool enable) ...@@ -3139,8 +3139,6 @@ static int fec_enet_eee_mode_set(struct net_device *ndev, bool enable)
} }
p->tx_lpi_enabled = enable; p->tx_lpi_enabled = enable;
p->eee_enabled = enable;
p->eee_active = enable;
writel(sleep_cycle, fep->hwp + FEC_LPI_SLEEP); writel(sleep_cycle, fep->hwp + FEC_LPI_SLEEP);
writel(wake_cycle, fep->hwp + FEC_LPI_WAKE); writel(wake_cycle, fep->hwp + FEC_LPI_WAKE);
...@@ -3160,8 +3158,6 @@ fec_enet_get_eee(struct net_device *ndev, struct ethtool_keee *edata) ...@@ -3160,8 +3158,6 @@ fec_enet_get_eee(struct net_device *ndev, struct ethtool_keee *edata)
if (!netif_running(ndev)) if (!netif_running(ndev))
return -ENETDOWN; return -ENETDOWN;
edata->eee_enabled = p->eee_enabled;
edata->eee_active = p->eee_active;
edata->tx_lpi_timer = p->tx_lpi_timer; edata->tx_lpi_timer = p->tx_lpi_timer;
edata->tx_lpi_enabled = p->tx_lpi_enabled; edata->tx_lpi_enabled = p->tx_lpi_enabled;
......
...@@ -503,7 +503,6 @@ struct sxgbe_priv_data { ...@@ -503,7 +503,6 @@ struct sxgbe_priv_data {
bool tx_path_in_lpi_mode; bool tx_path_in_lpi_mode;
int lpi_irq; int lpi_irq;
int eee_enabled; int eee_enabled;
int eee_active;
int tx_lpi_timer; int tx_lpi_timer;
}; };
......
...@@ -140,8 +140,6 @@ static int sxgbe_get_eee(struct net_device *dev, ...@@ -140,8 +140,6 @@ static int sxgbe_get_eee(struct net_device *dev,
if (!priv->hw_cap.eee) if (!priv->hw_cap.eee)
return -EOPNOTSUPP; return -EOPNOTSUPP;
edata->eee_enabled = priv->eee_enabled;
edata->eee_active = priv->eee_active;
edata->tx_lpi_timer = priv->tx_lpi_timer; edata->tx_lpi_timer = priv->tx_lpi_timer;
return phy_ethtool_get_eee(dev->phydev, edata); return phy_ethtool_get_eee(dev->phydev, edata);
......
...@@ -130,7 +130,6 @@ bool sxgbe_eee_init(struct sxgbe_priv_data * const priv) ...@@ -130,7 +130,6 @@ bool sxgbe_eee_init(struct sxgbe_priv_data * const priv)
if (phy_init_eee(ndev->phydev, true)) if (phy_init_eee(ndev->phydev, true))
return false; return false;
priv->eee_active = 1;
timer_setup(&priv->eee_ctrl_timer, sxgbe_eee_ctrl_timer, 0); timer_setup(&priv->eee_ctrl_timer, sxgbe_eee_ctrl_timer, 0);
priv->eee_ctrl_timer.expires = SXGBE_LPI_TIMER(eee_timer); priv->eee_ctrl_timer.expires = SXGBE_LPI_TIMER(eee_timer);
add_timer(&priv->eee_ctrl_timer); add_timer(&priv->eee_ctrl_timer);
......
...@@ -859,8 +859,6 @@ static int stmmac_ethtool_op_get_eee(struct net_device *dev, ...@@ -859,8 +859,6 @@ static int stmmac_ethtool_op_get_eee(struct net_device *dev,
if (!priv->dma_cap.eee) if (!priv->dma_cap.eee)
return -EOPNOTSUPP; return -EOPNOTSUPP;
edata->eee_enabled = priv->eee_enabled;
edata->eee_active = priv->eee_active;
edata->tx_lpi_timer = priv->tx_lpi_timer; edata->tx_lpi_timer = priv->tx_lpi_timer;
edata->tx_lpi_enabled = priv->tx_lpi_enabled; edata->tx_lpi_enabled = priv->tx_lpi_enabled;
......
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