Commit ebb0531b authored by David S. Miller's avatar David S. Miller

Merge branch 'mvneta-next'

Ezequiel Garcia says:

====================
net: ethernet: marvell: Assorted fixes

New round for this assorted fixes and clean-up series. There is more room for
clean-ups, and I'll start preparing more patches once these are accepted.

This series consists of cleanups and minor improvements on mvneta, mv643xx_eth
and mvmdio drivers. None of the patches imply any functionality change, except
for the patch six "Change the number of default rx queues to one".

This patch reduces the driver's allocated resources and makes the multiqueue
path in the poll function not get taken. The previous patchset contains more
details:

  http://permalink.gmane.org/gmane.linux.network/315015

As usual, any feedback on this will be well received!

Changes from v2:

  * Rebased on today's net-next and dropped patch
    "net: mvneta: Factorize feature setting", merged in the recent
    TSO series.

  * As per Sergei suggestion, used devm_kcalloc or devm_kmalloc_array
    when suitable.

Changes from v1:

  * Added two more clean-up patches to the series.

  * Added Sebastian's Acked-by's.

  * Fixed extra empty line in "net: mv643xx_eth: Simplify
    mv643xx_eth_adjust_link()" as pointed out by David Miller.
====================
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parents ece80490 dc03e21a
...@@ -1167,8 +1167,9 @@ static void txq_set_fixed_prio_mode(struct tx_queue *txq) ...@@ -1167,8 +1167,9 @@ static void txq_set_fixed_prio_mode(struct tx_queue *txq)
/* mii management interface *************************************************/ /* mii management interface *************************************************/
static void mv643xx_adjust_pscr(struct mv643xx_eth_private *mp) static void mv643xx_eth_adjust_link(struct net_device *dev)
{ {
struct mv643xx_eth_private *mp = netdev_priv(dev);
u32 pscr = rdlp(mp, PORT_SERIAL_CONTROL); u32 pscr = rdlp(mp, PORT_SERIAL_CONTROL);
u32 autoneg_disable = FORCE_LINK_PASS | u32 autoneg_disable = FORCE_LINK_PASS |
DISABLE_AUTO_NEG_SPEED_GMII | DISABLE_AUTO_NEG_SPEED_GMII |
...@@ -1544,7 +1545,7 @@ mv643xx_eth_set_settings(struct net_device *dev, struct ethtool_cmd *cmd) ...@@ -1544,7 +1545,7 @@ mv643xx_eth_set_settings(struct net_device *dev, struct ethtool_cmd *cmd)
ret = phy_ethtool_sset(mp->phy, cmd); ret = phy_ethtool_sset(mp->phy, cmd);
if (!ret) if (!ret)
mv643xx_adjust_pscr(mp); mv643xx_eth_adjust_link(dev);
return ret; return ret;
} }
...@@ -2473,7 +2474,7 @@ static int mv643xx_eth_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd) ...@@ -2473,7 +2474,7 @@ static int mv643xx_eth_ioctl(struct net_device *dev, struct ifreq *ifr, int cmd)
ret = phy_mii_ioctl(mp->phy, ifr, cmd); ret = phy_mii_ioctl(mp->phy, ifr, cmd);
if (!ret) if (!ret)
mv643xx_adjust_pscr(mp); mv643xx_eth_adjust_link(dev);
return ret; return ret;
} }
...@@ -2871,13 +2872,6 @@ static void set_params(struct mv643xx_eth_private *mp, ...@@ -2871,13 +2872,6 @@ static void set_params(struct mv643xx_eth_private *mp,
mp->txq_count = pd->tx_queue_count ? : 1; mp->txq_count = pd->tx_queue_count ? : 1;
} }
static void mv643xx_eth_adjust_link(struct net_device *dev)
{
struct mv643xx_eth_private *mp = netdev_priv(dev);
mv643xx_adjust_pscr(mp);
}
static struct phy_device *phy_scan(struct mv643xx_eth_private *mp, static struct phy_device *phy_scan(struct mv643xx_eth_private *mp,
int phy_addr) int phy_addr)
{ {
......
...@@ -195,11 +195,10 @@ static int orion_mdio_probe(struct platform_device *pdev) ...@@ -195,11 +195,10 @@ static int orion_mdio_probe(struct platform_device *pdev)
return -ENODEV; return -ENODEV;
} }
bus = mdiobus_alloc_size(sizeof(struct orion_mdio_dev)); bus = devm_mdiobus_alloc_size(&pdev->dev,
if (!bus) { sizeof(struct orion_mdio_dev));
dev_err(&pdev->dev, "Cannot allocate MDIO bus\n"); if (!bus)
return -ENOMEM; return -ENOMEM;
}
bus->name = "orion_mdio_bus"; bus->name = "orion_mdio_bus";
bus->read = orion_mdio_read; bus->read = orion_mdio_read;
...@@ -208,11 +207,10 @@ static int orion_mdio_probe(struct platform_device *pdev) ...@@ -208,11 +207,10 @@ static int orion_mdio_probe(struct platform_device *pdev)
dev_name(&pdev->dev)); dev_name(&pdev->dev));
bus->parent = &pdev->dev; bus->parent = &pdev->dev;
bus->irq = kmalloc(sizeof(int) * PHY_MAX_ADDR, GFP_KERNEL); bus->irq = devm_kmalloc_array(&pdev->dev, PHY_MAX_ADDR, sizeof(int),
if (!bus->irq) { GFP_KERNEL);
mdiobus_free(bus); if (!bus->irq)
return -ENOMEM; return -ENOMEM;
}
for (i = 0; i < PHY_MAX_ADDR; i++) for (i = 0; i < PHY_MAX_ADDR; i++)
bus->irq[i] = PHY_POLL; bus->irq[i] = PHY_POLL;
...@@ -264,8 +262,6 @@ static int orion_mdio_probe(struct platform_device *pdev) ...@@ -264,8 +262,6 @@ static int orion_mdio_probe(struct platform_device *pdev)
out_mdio: out_mdio:
if (!IS_ERR(dev->clk)) if (!IS_ERR(dev->clk))
clk_disable_unprepare(dev->clk); clk_disable_unprepare(dev->clk);
kfree(bus->irq);
mdiobus_free(bus);
return ret; return ret;
} }
...@@ -276,8 +272,6 @@ static int orion_mdio_remove(struct platform_device *pdev) ...@@ -276,8 +272,6 @@ static int orion_mdio_remove(struct platform_device *pdev)
writel(0, dev->regs + MVMDIO_ERR_INT_MASK); writel(0, dev->regs + MVMDIO_ERR_INT_MASK);
mdiobus_unregister(bus); mdiobus_unregister(bus);
kfree(bus->irq);
mdiobus_free(bus);
if (!IS_ERR(dev->clk)) if (!IS_ERR(dev->clk))
clk_disable_unprepare(dev->clk); clk_disable_unprepare(dev->clk);
......
...@@ -283,9 +283,6 @@ struct mvneta_port { ...@@ -283,9 +283,6 @@ struct mvneta_port {
u32 cause_rx_tx; u32 cause_rx_tx;
struct napi_struct napi; struct napi_struct napi;
/* Napi weight */
int weight;
/* Core clock */ /* Core clock */
struct clk *clk; struct clk *clk;
u8 mcast_count[256]; u8 mcast_count[256];
...@@ -451,7 +448,10 @@ struct mvneta_rx_queue { ...@@ -451,7 +448,10 @@ struct mvneta_rx_queue {
int next_desc_to_proc; int next_desc_to_proc;
}; };
static int rxq_number = 8; /* The hardware supports eight (8) rx queues, but we are only allowing
* the first one to be used. Therefore, let's just allocate one queue.
*/
static int rxq_number = 1;
static int txq_number = 8; static int txq_number = 8;
static int rxq_def; static int rxq_def;
...@@ -1654,9 +1654,9 @@ static int mvneta_tx_frag_process(struct mvneta_port *pp, struct sk_buff *skb, ...@@ -1654,9 +1654,9 @@ static int mvneta_tx_frag_process(struct mvneta_port *pp, struct sk_buff *skb,
struct mvneta_tx_queue *txq) struct mvneta_tx_queue *txq)
{ {
struct mvneta_tx_desc *tx_desc; struct mvneta_tx_desc *tx_desc;
int i; int i, nr_frags = skb_shinfo(skb)->nr_frags;
for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) { for (i = 0; i < nr_frags; i++) {
skb_frag_t *frag = &skb_shinfo(skb)->frags[i]; skb_frag_t *frag = &skb_shinfo(skb)->frags[i];
void *addr = page_address(frag->page.p) + frag->page_offset; void *addr = page_address(frag->page.p) + frag->page_offset;
...@@ -1673,20 +1673,16 @@ static int mvneta_tx_frag_process(struct mvneta_port *pp, struct sk_buff *skb, ...@@ -1673,20 +1673,16 @@ static int mvneta_tx_frag_process(struct mvneta_port *pp, struct sk_buff *skb,
goto error; goto error;
} }
if (i == (skb_shinfo(skb)->nr_frags - 1)) { if (i == nr_frags - 1) {
/* Last descriptor */ /* Last descriptor */
tx_desc->command = MVNETA_TXD_L_DESC | MVNETA_TXD_Z_PAD; tx_desc->command = MVNETA_TXD_L_DESC | MVNETA_TXD_Z_PAD;
txq->tx_skb[txq->txq_put_index] = skb; txq->tx_skb[txq->txq_put_index] = skb;
mvneta_txq_inc_put(txq);
} else { } else {
/* Descriptor in the middle: Not First, Not Last */ /* Descriptor in the middle: Not First, Not Last */
tx_desc->command = 0; tx_desc->command = 0;
txq->tx_skb[txq->txq_put_index] = NULL; txq->tx_skb[txq->txq_put_index] = NULL;
mvneta_txq_inc_put(txq);
} }
mvneta_txq_inc_put(txq);
} }
return 0; return 0;
...@@ -2137,7 +2133,7 @@ static void mvneta_tx_reset(struct mvneta_port *pp) ...@@ -2137,7 +2133,7 @@ static void mvneta_tx_reset(struct mvneta_port *pp)
{ {
int queue; int queue;
/* free the skb's in the hal tx ring */ /* free the skb's in the tx ring */
for (queue = 0; queue < txq_number; queue++) for (queue = 0; queue < txq_number; queue++)
mvneta_txq_done_force(pp, &pp->txqs[queue]); mvneta_txq_done_force(pp, &pp->txqs[queue]);
...@@ -2429,24 +2425,28 @@ static int mvneta_change_mtu(struct net_device *dev, int mtu) ...@@ -2429,24 +2425,28 @@ static int mvneta_change_mtu(struct net_device *dev, int mtu)
return 0; return 0;
/* The interface is running, so we have to force a /* The interface is running, so we have to force a
* reallocation of the RXQs * reallocation of the queues
*/ */
mvneta_stop_dev(pp); mvneta_stop_dev(pp);
mvneta_cleanup_txqs(pp); mvneta_cleanup_txqs(pp);
mvneta_cleanup_rxqs(pp); mvneta_cleanup_rxqs(pp);
pp->pkt_size = MVNETA_RX_PKT_SIZE(pp->dev->mtu); pp->pkt_size = MVNETA_RX_PKT_SIZE(dev->mtu);
pp->frag_size = SKB_DATA_ALIGN(MVNETA_RX_BUF_SIZE(pp->pkt_size)) + pp->frag_size = SKB_DATA_ALIGN(MVNETA_RX_BUF_SIZE(pp->pkt_size)) +
SKB_DATA_ALIGN(sizeof(struct skb_shared_info)); SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
ret = mvneta_setup_rxqs(pp); ret = mvneta_setup_rxqs(pp);
if (ret) { if (ret) {
netdev_err(pp->dev, "unable to setup rxqs after MTU change\n"); netdev_err(dev, "unable to setup rxqs after MTU change\n");
return ret; return ret;
} }
mvneta_setup_txqs(pp); ret = mvneta_setup_txqs(pp);
if (ret) {
netdev_err(dev, "unable to setup txqs after MTU change\n");
return ret;
}
mvneta_start_dev(pp); mvneta_start_dev(pp);
mvneta_port_up(pp); mvneta_port_up(pp);
...@@ -2473,22 +2473,19 @@ static void mvneta_get_mac_addr(struct mvneta_port *pp, unsigned char *addr) ...@@ -2473,22 +2473,19 @@ static void mvneta_get_mac_addr(struct mvneta_port *pp, unsigned char *addr)
static int mvneta_set_mac_addr(struct net_device *dev, void *addr) static int mvneta_set_mac_addr(struct net_device *dev, void *addr)
{ {
struct mvneta_port *pp = netdev_priv(dev); struct mvneta_port *pp = netdev_priv(dev);
u8 *mac = addr + 2; struct sockaddr *sockaddr = addr;
int i; int ret;
if (netif_running(dev))
return -EBUSY;
ret = eth_prepare_mac_addr_change(dev, addr);
if (ret < 0)
return ret;
/* Remove previous address table entry */ /* Remove previous address table entry */
mvneta_mac_addr_set(pp, dev->dev_addr, -1); mvneta_mac_addr_set(pp, dev->dev_addr, -1);
/* Set new addr in hw */ /* Set new addr in hw */
mvneta_mac_addr_set(pp, mac, rxq_def); mvneta_mac_addr_set(pp, sockaddr->sa_data, rxq_def);
/* Set addr in the device */
for (i = 0; i < ETH_ALEN; i++)
dev->dev_addr[i] = mac[i];
eth_commit_mac_addr_change(dev, addr);
return 0; return 0;
} }
...@@ -2583,8 +2580,6 @@ static int mvneta_open(struct net_device *dev) ...@@ -2583,8 +2580,6 @@ static int mvneta_open(struct net_device *dev)
struct mvneta_port *pp = netdev_priv(dev); struct mvneta_port *pp = netdev_priv(dev);
int ret; int ret;
mvneta_mac_addr_set(pp, dev->dev_addr, rxq_def);
pp->pkt_size = MVNETA_RX_PKT_SIZE(pp->dev->mtu); pp->pkt_size = MVNETA_RX_PKT_SIZE(pp->dev->mtu);
pp->frag_size = SKB_DATA_ALIGN(MVNETA_RX_BUF_SIZE(pp->pkt_size)) + pp->frag_size = SKB_DATA_ALIGN(MVNETA_RX_BUF_SIZE(pp->pkt_size)) +
SKB_DATA_ALIGN(sizeof(struct skb_shared_info)); SKB_DATA_ALIGN(sizeof(struct skb_shared_info));
...@@ -2788,7 +2783,7 @@ const struct ethtool_ops mvneta_eth_tool_ops = { ...@@ -2788,7 +2783,7 @@ const struct ethtool_ops mvneta_eth_tool_ops = {
}; };
/* Initialize hw */ /* Initialize hw */
static int mvneta_init(struct mvneta_port *pp, int phy_addr) static int mvneta_init(struct device *dev, struct mvneta_port *pp)
{ {
int queue; int queue;
...@@ -2798,7 +2793,7 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr) ...@@ -2798,7 +2793,7 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr)
/* Set port default values */ /* Set port default values */
mvneta_defaults_set(pp); mvneta_defaults_set(pp);
pp->txqs = kzalloc(txq_number * sizeof(struct mvneta_tx_queue), pp->txqs = devm_kcalloc(dev, txq_number, sizeof(struct mvneta_tx_queue),
GFP_KERNEL); GFP_KERNEL);
if (!pp->txqs) if (!pp->txqs)
return -ENOMEM; return -ENOMEM;
...@@ -2811,12 +2806,10 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr) ...@@ -2811,12 +2806,10 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr)
txq->done_pkts_coal = MVNETA_TXDONE_COAL_PKTS; txq->done_pkts_coal = MVNETA_TXDONE_COAL_PKTS;
} }
pp->rxqs = kzalloc(rxq_number * sizeof(struct mvneta_rx_queue), pp->rxqs = devm_kcalloc(dev, rxq_number, sizeof(struct mvneta_rx_queue),
GFP_KERNEL); GFP_KERNEL);
if (!pp->rxqs) { if (!pp->rxqs)
kfree(pp->txqs);
return -ENOMEM; return -ENOMEM;
}
/* Create Rx descriptor rings */ /* Create Rx descriptor rings */
for (queue = 0; queue < rxq_number; queue++) { for (queue = 0; queue < rxq_number; queue++) {
...@@ -2830,12 +2823,6 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr) ...@@ -2830,12 +2823,6 @@ static int mvneta_init(struct mvneta_port *pp, int phy_addr)
return 0; return 0;
} }
static void mvneta_deinit(struct mvneta_port *pp)
{
kfree(pp->txqs);
kfree(pp->rxqs);
}
/* platform glue : initialize decoding windows */ /* platform glue : initialize decoding windows */
static void mvneta_conf_mbus_windows(struct mvneta_port *pp, static void mvneta_conf_mbus_windows(struct mvneta_port *pp,
const struct mbus_dram_target_info *dram) const struct mbus_dram_target_info *dram)
...@@ -2918,7 +2905,6 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -2918,7 +2905,6 @@ static int mvneta_probe(struct platform_device *pdev)
struct resource *res; struct resource *res;
struct device_node *dn = pdev->dev.of_node; struct device_node *dn = pdev->dev.of_node;
struct device_node *phy_node; struct device_node *phy_node;
u32 phy_addr;
struct mvneta_port *pp; struct mvneta_port *pp;
struct net_device *dev; struct net_device *dev;
const char *dt_mac_addr; const char *dt_mac_addr;
...@@ -2979,8 +2965,6 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -2979,8 +2965,6 @@ static int mvneta_probe(struct platform_device *pdev)
dev->ethtool_ops = &mvneta_eth_tool_ops; dev->ethtool_ops = &mvneta_eth_tool_ops;
pp = netdev_priv(dev); pp = netdev_priv(dev);
pp->weight = MVNETA_RX_POLL_WEIGHT;
pp->phy_node = phy_node; pp->phy_node = phy_node;
pp->phy_interface = phy_mode; pp->phy_interface = phy_mode;
...@@ -3027,23 +3011,21 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -3027,23 +3011,21 @@ static int mvneta_probe(struct platform_device *pdev)
pp->dev = dev; pp->dev = dev;
SET_NETDEV_DEV(dev, &pdev->dev); SET_NETDEV_DEV(dev, &pdev->dev);
err = mvneta_init(pp, phy_addr); err = mvneta_init(&pdev->dev, pp);
if (err < 0) { if (err < 0)
dev_err(&pdev->dev, "can't init eth hal\n");
goto err_free_stats; goto err_free_stats;
}
err = mvneta_port_power_up(pp, phy_mode); err = mvneta_port_power_up(pp, phy_mode);
if (err < 0) { if (err < 0) {
dev_err(&pdev->dev, "can't power up port\n"); dev_err(&pdev->dev, "can't power up port\n");
goto err_deinit; goto err_free_stats;
} }
dram_target_info = mv_mbus_dram_info(); dram_target_info = mv_mbus_dram_info();
if (dram_target_info) if (dram_target_info)
mvneta_conf_mbus_windows(pp, dram_target_info); mvneta_conf_mbus_windows(pp, dram_target_info);
netif_napi_add(dev, &pp->napi, mvneta_poll, pp->weight); netif_napi_add(dev, &pp->napi, mvneta_poll, MVNETA_RX_POLL_WEIGHT);
dev->features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO; dev->features = NETIF_F_SG | NETIF_F_IP_CSUM | NETIF_F_TSO;
dev->hw_features |= dev->features; dev->hw_features |= dev->features;
...@@ -3053,7 +3035,7 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -3053,7 +3035,7 @@ static int mvneta_probe(struct platform_device *pdev)
err = register_netdev(dev); err = register_netdev(dev);
if (err < 0) { if (err < 0) {
dev_err(&pdev->dev, "failed to register\n"); dev_err(&pdev->dev, "failed to register\n");
goto err_deinit; goto err_free_stats;
} }
netdev_info(dev, "Using %s mac address %pM\n", mac_from, netdev_info(dev, "Using %s mac address %pM\n", mac_from,
...@@ -3063,8 +3045,6 @@ static int mvneta_probe(struct platform_device *pdev) ...@@ -3063,8 +3045,6 @@ static int mvneta_probe(struct platform_device *pdev)
return 0; return 0;
err_deinit:
mvneta_deinit(pp);
err_free_stats: err_free_stats:
free_percpu(pp->stats); free_percpu(pp->stats);
err_clk: err_clk:
...@@ -3083,7 +3063,6 @@ static int mvneta_remove(struct platform_device *pdev) ...@@ -3083,7 +3063,6 @@ static int mvneta_remove(struct platform_device *pdev)
struct mvneta_port *pp = netdev_priv(dev); struct mvneta_port *pp = netdev_priv(dev);
unregister_netdev(dev); unregister_netdev(dev);
mvneta_deinit(pp);
clk_disable_unprepare(pp->clk); clk_disable_unprepare(pp->clk);
free_percpu(pp->stats); free_percpu(pp->stats);
irq_dispose_mapping(dev->irq); irq_dispose_mapping(dev->irq);
......
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