123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142 |
- From f9ec5723c3dbfcede9c7b0dcdf85e401ce16316c Mon Sep 17 00:00:00 2001
- From: Christian Marangi <[email protected]>
- Date: Sat, 23 Jul 2022 16:29:29 +0200
- Subject: [PATCH 1/5] net: ethernet: stmicro: stmmac: move queue reset to
- dedicated functions
- Move queue reset to dedicated functions. This aside from a simple
- cleanup is also required to allocate a dma conf without resetting the tx
- queue while the device is temporarily detached as now the reset is not
- part of the dma init function and can be done later in the code flow.
- Signed-off-by: Christian Marangi <[email protected]>
- Signed-off-by: Jakub Kicinski <[email protected]>
- ---
- .../net/ethernet/stmicro/stmmac/stmmac_main.c | 59 ++++++++++---------
- 1 file changed, 31 insertions(+), 28 deletions(-)
- --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
- +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
- @@ -130,6 +130,9 @@ static irqreturn_t stmmac_mac_interrupt(
- static irqreturn_t stmmac_safety_interrupt(int irq, void *dev_id);
- static irqreturn_t stmmac_msi_intr_tx(int irq, void *data);
- static irqreturn_t stmmac_msi_intr_rx(int irq, void *data);
- +static void stmmac_reset_rx_queue(struct stmmac_priv *priv, u32 queue);
- +static void stmmac_reset_tx_queue(struct stmmac_priv *priv, u32 queue);
- +static void stmmac_reset_queues_param(struct stmmac_priv *priv);
- static void stmmac_tx_timer_arm(struct stmmac_priv *priv, u32 queue);
- static void stmmac_flush_tx_descriptors(struct stmmac_priv *priv, int queue);
-
- @@ -1713,9 +1716,6 @@ static int __init_dma_rx_desc_rings(stru
- return -ENOMEM;
- }
-
- - rx_q->cur_rx = 0;
- - rx_q->dirty_rx = 0;
- -
- /* Setup the chained descriptor addresses */
- if (priv->mode == STMMAC_CHAIN_MODE) {
- if (priv->extend_desc)
- @@ -1821,12 +1821,6 @@ static int __init_dma_tx_desc_rings(stru
- tx_q->tx_skbuff[i] = NULL;
- }
-
- - tx_q->dirty_tx = 0;
- - tx_q->cur_tx = 0;
- - tx_q->mss = 0;
- -
- - netdev_tx_reset_queue(netdev_get_tx_queue(priv->dev, queue));
- -
- return 0;
- }
-
- @@ -2695,10 +2689,7 @@ static void stmmac_tx_err(struct stmmac_
- stmmac_stop_tx_dma(priv, chan);
- dma_free_tx_skbufs(priv, chan);
- stmmac_clear_tx_descriptors(priv, chan);
- - tx_q->dirty_tx = 0;
- - tx_q->cur_tx = 0;
- - tx_q->mss = 0;
- - netdev_tx_reset_queue(netdev_get_tx_queue(priv->dev, chan));
- + stmmac_reset_tx_queue(priv, chan);
- stmmac_init_tx_chan(priv, priv->ioaddr, priv->plat->dma_cfg,
- tx_q->dma_tx_phy, chan);
- stmmac_start_tx_dma(priv, chan);
- @@ -3783,6 +3774,8 @@ static int stmmac_open(struct net_device
- }
- }
-
- + stmmac_reset_queues_param(priv);
- +
- ret = stmmac_hw_setup(dev, true);
- if (ret < 0) {
- netdev_err(priv->dev, "%s: Hw setup failed\n", __func__);
- @@ -6412,6 +6405,7 @@ void stmmac_enable_rx_queue(struct stmma
- return;
- }
-
- + stmmac_reset_rx_queue(priv, queue);
- stmmac_clear_rx_descriptors(priv, queue);
-
- stmmac_init_rx_chan(priv, priv->ioaddr, priv->plat->dma_cfg,
- @@ -6473,6 +6467,7 @@ void stmmac_enable_tx_queue(struct stmma
- return;
- }
-
- + stmmac_reset_tx_queue(priv, queue);
- stmmac_clear_tx_descriptors(priv, queue);
-
- stmmac_init_tx_chan(priv, priv->ioaddr, priv->plat->dma_cfg,
- @@ -7400,6 +7395,25 @@ int stmmac_suspend(struct device *dev)
- }
- EXPORT_SYMBOL_GPL(stmmac_suspend);
-
- +static void stmmac_reset_rx_queue(struct stmmac_priv *priv, u32 queue)
- +{
- + struct stmmac_rx_queue *rx_q = &priv->rx_queue[queue];
- +
- + rx_q->cur_rx = 0;
- + rx_q->dirty_rx = 0;
- +}
- +
- +static void stmmac_reset_tx_queue(struct stmmac_priv *priv, u32 queue)
- +{
- + struct stmmac_tx_queue *tx_q = &priv->tx_queue[queue];
- +
- + tx_q->cur_tx = 0;
- + tx_q->dirty_tx = 0;
- + tx_q->mss = 0;
- +
- + netdev_tx_reset_queue(netdev_get_tx_queue(priv->dev, queue));
- +}
- +
- /**
- * stmmac_reset_queues_param - reset queue parameters
- * @priv: device pointer
- @@ -7410,22 +7424,11 @@ static void stmmac_reset_queues_param(st
- u32 tx_cnt = priv->plat->tx_queues_to_use;
- u32 queue;
-
- - for (queue = 0; queue < rx_cnt; queue++) {
- - struct stmmac_rx_queue *rx_q = &priv->rx_queue[queue];
- + for (queue = 0; queue < rx_cnt; queue++)
- + stmmac_reset_rx_queue(priv, queue);
-
- - rx_q->cur_rx = 0;
- - rx_q->dirty_rx = 0;
- - }
- -
- - for (queue = 0; queue < tx_cnt; queue++) {
- - struct stmmac_tx_queue *tx_q = &priv->tx_queue[queue];
- -
- - tx_q->cur_tx = 0;
- - tx_q->dirty_tx = 0;
- - tx_q->mss = 0;
- -
- - netdev_tx_reset_queue(netdev_get_tx_queue(priv->dev, queue));
- - }
- + for (queue = 0; queue < tx_cnt; queue++)
- + stmmac_reset_tx_queue(priv, queue);
- }
-
- /**
|