]> git.ipfire.org Git - thirdparty/openwrt.git/commitdiff
ipq806x: add patch fixing regression from stmmac TX timer 13480/head
authorChristian Marangi <ansuelsmth@gmail.com>
Mon, 18 Sep 2023 14:36:34 +0000 (16:36 +0200)
committerChristian Marangi <ansuelsmth@gmail.com>
Sat, 30 Sep 2023 14:55:09 +0000 (16:55 +0200)
Add patch fixing regression from stmmac TX timer.

Refer to the single patch for extensive details on the problem.

This should restore original performance before 4.19 kernel.

Fixes: #11676
Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
target/linux/ipq806x/patches-6.1/700-01-net-introduce-napi_is_scheduled-helper.patch
target/linux/ipq806x/patches-6.1/700-02-net-stmmac-move-TX-timer-arm-after-DMA-enable.patch [new file with mode: 0644]
target/linux/ipq806x/patches-6.1/700-03-net-stmmac-improve-TX-timer-arm-logic.patch [moved from target/linux/ipq806x/patches-6.1/700-02-net-stmmac-improve-TX-timer-arm-logic.patch with 93% similarity]
target/linux/ipq806x/patches-6.1/700-04-net-stmmac-increase-TX-coalesce-timer-to-5ms.patch [moved from target/linux/ipq806x/patches-6.1/700-03-net-stmmac-increase-TX-coalesce-timer-to-5ms.patch with 91% similarity]

index 813ec97abcef5802910b25c152dc798a9f47b468..9694bf1144fd413bd87457aa65b271a58d831943 100644 (file)
@@ -1,7 +1,7 @@
 From b5532bdc6d09e6e789417f0c7a0b665b57b0e7be Mon Sep 17 00:00:00 2001
 From: Christian Marangi <ansuelsmth@gmail.com>
 Date: Mon, 18 Sep 2023 14:21:56 +0200
-Subject: [PATCH 1/3] net: introduce napi_is_scheduled helper
+Subject: [PATCH 1/4] net: introduce napi_is_scheduled helper
 
 We currently have napi_if_scheduled_mark_missed that can be used to
 check if napi is scheduled but that does more thing than simply checking
diff --git a/target/linux/ipq806x/patches-6.1/700-02-net-stmmac-move-TX-timer-arm-after-DMA-enable.patch b/target/linux/ipq806x/patches-6.1/700-02-net-stmmac-move-TX-timer-arm-after-DMA-enable.patch
new file mode 100644 (file)
index 0000000..2b52398
--- /dev/null
@@ -0,0 +1,89 @@
+From fb04db35447d1e8ff557c8e57139164cecab7de5 Mon Sep 17 00:00:00 2001
+From: Christian Marangi <ansuelsmth@gmail.com>
+Date: Wed, 27 Sep 2023 15:38:31 +0200
+Subject: [PATCH 2/4] net: stmmac: move TX timer arm after DMA enable
+
+Move TX timer arm call after DMA interrupt is enabled again.
+
+The TX timer arm function changed logic and now is skipped if a napi is
+already scheduled. By moving the TX timer arm call after DMA is enabled,
+we permit to correctly skip if a DMA interrupt has been fired and a napi
+has been scheduled again.
+
+Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
+---
+ .../net/ethernet/stmicro/stmmac/stmmac_main.c | 19 +++++++++++++++----
+ 1 file changed, 15 insertions(+), 4 deletions(-)
+
+--- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
++++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
+@@ -2529,7 +2529,8 @@ static void stmmac_bump_dma_threshold(st
+  * @queue: TX queue index
+  * Description: it reclaims the transmit resources after transmission completes.
+  */
+-static int stmmac_tx_clean(struct stmmac_priv *priv, int budget, u32 queue)
++static int stmmac_tx_clean(struct stmmac_priv *priv, int budget, u32 queue,
++                         bool *pending_packets)
+ {
+       struct stmmac_tx_queue *tx_q = &priv->dma_conf.tx_queue[queue];
+       unsigned int bytes_compl = 0, pkts_compl = 0;
+@@ -2692,7 +2693,7 @@ static int stmmac_tx_clean(struct stmmac
+       /* We still have pending packets, let's call for a new scheduling */
+       if (tx_q->dirty_tx != tx_q->cur_tx)
+-              stmmac_tx_timer_arm(priv, queue);
++              *pending_packets = true;
+       __netif_tx_unlock_bh(netdev_get_tx_queue(priv->dev, queue));
+@@ -5474,12 +5475,13 @@ static int stmmac_napi_poll_tx(struct na
+       struct stmmac_channel *ch =
+               container_of(napi, struct stmmac_channel, tx_napi);
+       struct stmmac_priv *priv = ch->priv_data;
++      bool pending_packets = false;
+       u32 chan = ch->index;
+       int work_done;
+       priv->xstats.napi_poll++;
+-      work_done = stmmac_tx_clean(priv, budget, chan);
++      work_done = stmmac_tx_clean(priv, budget, chan, &pending_packets);
+       work_done = min(work_done, budget);
+       if (work_done < budget && napi_complete_done(napi, work_done)) {
+@@ -5490,6 +5492,10 @@ static int stmmac_napi_poll_tx(struct na
+               spin_unlock_irqrestore(&ch->lock, flags);
+       }
++      /* TX still have packet to handle, check if we need to arm tx timer */
++      if (pending_packets)
++              stmmac_tx_timer_arm(priv, chan);
++
+       return work_done;
+ }
+@@ -5499,11 +5505,12 @@ static int stmmac_napi_poll_rxtx(struct
+               container_of(napi, struct stmmac_channel, rxtx_napi);
+       struct stmmac_priv *priv = ch->priv_data;
+       int rx_done, tx_done, rxtx_done;
++      bool tx_pending_packets = false;
+       u32 chan = ch->index;
+       priv->xstats.napi_poll++;
+-      tx_done = stmmac_tx_clean(priv, budget, chan);
++      tx_done = stmmac_tx_clean(priv, budget, chan, &tx_pending_packets);
+       tx_done = min(tx_done, budget);
+       rx_done = stmmac_rx_zc(priv, budget, chan);
+@@ -5528,6 +5535,10 @@ static int stmmac_napi_poll_rxtx(struct
+               spin_unlock_irqrestore(&ch->lock, flags);
+       }
++      /* TX still have packet to handle, check if we need to arm tx timer */
++      if (tx_pending_packets)
++              stmmac_tx_timer_arm(priv, chan);
++
+       return min(rxtx_done, budget - 1);
+ }
similarity index 93%
rename from target/linux/ipq806x/patches-6.1/700-02-net-stmmac-improve-TX-timer-arm-logic.patch
rename to target/linux/ipq806x/patches-6.1/700-03-net-stmmac-improve-TX-timer-arm-logic.patch
index 0f2f366fa94b7adeb4685e01686e3a26222bb218..6160b95e605b24feed754fff0693a15b5d9d0150 100644 (file)
@@ -1,7 +1,7 @@
-From 26e872db0f14c09ab57486b538ecc3a24c579df2 Mon Sep 17 00:00:00 2001
+From cd40cd8b1ca4a6f531c6c3fd78b306e5014f9c04 Mon Sep 17 00:00:00 2001
 From: Christian Marangi <ansuelsmth@gmail.com>
 Date: Mon, 18 Sep 2023 14:39:01 +0200
-Subject: [PATCH 2/3] net: stmmac: improve TX timer arm logic
+Subject: [PATCH 3/4] net: stmmac: improve TX timer arm logic
 
 There is currently a problem with the TX timer getting armed multiple
 unnecessary times causing big performance regression on some device that
@@ -45,7 +45,7 @@ Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
 
 --- a/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
 +++ b/drivers/net/ethernet/stmicro/stmmac/stmmac_main.c
-@@ -2974,13 +2974,25 @@ static void stmmac_tx_timer_arm(struct s
+@@ -2975,13 +2975,25 @@ static void stmmac_tx_timer_arm(struct s
  {
        struct stmmac_tx_queue *tx_q = &priv->dma_conf.tx_queue[queue];
        u32 tx_coal_timer = priv->tx_coal_timer[queue];
similarity index 91%
rename from target/linux/ipq806x/patches-6.1/700-03-net-stmmac-increase-TX-coalesce-timer-to-5ms.patch
rename to target/linux/ipq806x/patches-6.1/700-04-net-stmmac-increase-TX-coalesce-timer-to-5ms.patch
index f86c16ec81b2b19b9dc0d2c540c6a596473a4e94..3f9770209725ff579a728a5e04e5347c54ccbad8 100644 (file)
@@ -1,7 +1,7 @@
-From 13e24b0c4318b8b4d0a0fde7e5e7ccb982821c63 Mon Sep 17 00:00:00 2001
+From 95281ab33fbaa1e974bceb20cfb0f5c92934f2b3 Mon Sep 17 00:00:00 2001
 From: Christian Marangi <ansuelsmth@gmail.com>
 Date: Mon, 18 Sep 2023 15:11:13 +0200
-Subject: [PATCH 3/3] net: stmmac: increase TX coalesce timer to 5ms
+Subject: [PATCH 4/4] net: stmmac: increase TX coalesce timer to 5ms
 
 Commit 8fce33317023 ("net: stmmac: Rework coalesce timer and fix
 multi-queue races") decreased the TX coalesce timer from 40ms to 1ms.