* [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free
@ 2025-05-05 1:07 Daniel Golle
2025-05-05 1:07 ` [PATCH net v2 2/2] net: ethernet: mtk_eth_soc: do not reset PSE when setting FE Daniel Golle
2025-05-06 12:00 ` [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free patchwork-bot+netdevbpf
0 siblings, 2 replies; 3+ messages in thread
From: Daniel Golle @ 2025-05-05 1:07 UTC (permalink / raw)
To: Felix Fietkau, Sean Wang, Lorenzo Bianconi, Andrew Lunn,
David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni,
Matthias Brugger, AngeloGioacchino Del Regno, Elad Yifee, netdev,
linux-kernel, linux-arm-kernel, linux-mediatek
The purpose of resetting the TX queue is to reset the byte and packet
count as well as to clear the software flow control XOFF bit.
MediaTek developers pointed out that netdev_reset_queue would only
resets queue 0 of the network device.
Queues that are not reset may cause unexpected issues.
Packets may stop being sent after reset and "transmit timeout" log may
be displayed.
Import fix from MediaTek's SDK to resolve this issue.
Link: https://git01.mediatek.com/plugins/gitiles/openwrt/feeds/mtk-openwrt-feeds/+/319c0d9905579a46dc448579f892f364f1f84818
Fixes: f63959c7eec31 ("net: ethernet: mtk_eth_soc: implement multi-queue support for per-port queues")
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
---
v2: Use netdev_tx_reset_subqueue()
drivers/net/ethernet/mediatek/mtk_eth_soc.c | 16 ++++++++++++----
1 file changed, 12 insertions(+), 4 deletions(-)
diff --git a/drivers/net/ethernet/mediatek/mtk_eth_soc.c b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
index 8fda4ce80d811..53c39561b6d9a 100644
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
@@ -3186,11 +3186,19 @@ static int mtk_dma_init(struct mtk_eth *eth)
static void mtk_dma_free(struct mtk_eth *eth)
{
const struct mtk_soc_data *soc = eth->soc;
- int i;
+ int i, j, txqs = 1;
+
+ if (MTK_HAS_CAPS(eth->soc->caps, MTK_QDMA))
+ txqs = MTK_QDMA_NUM_QUEUES;
+
+ for (i = 0; i < MTK_MAX_DEVS; i++) {
+ if (!eth->netdev[i])
+ continue;
+
+ for (j = 0; j < txqs; j++)
+ netdev_tx_reset_subqueue(eth->netdev[i], j);
+ }
- for (i = 0; i < MTK_MAX_DEVS; i++)
- if (eth->netdev[i])
- netdev_reset_queue(eth->netdev[i]);
if (!MTK_HAS_CAPS(soc->caps, MTK_SRAM) && eth->scratch_ring) {
dma_free_coherent(eth->dma_dev,
MTK_QDMA_RING_SIZE * soc->tx.desc_size,
--
2.49.0
^ permalink raw reply related [flat|nested] 3+ messages in thread
* [PATCH net v2 2/2] net: ethernet: mtk_eth_soc: do not reset PSE when setting FE
2025-05-05 1:07 [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free Daniel Golle
@ 2025-05-05 1:07 ` Daniel Golle
2025-05-06 12:00 ` [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free patchwork-bot+netdevbpf
1 sibling, 0 replies; 3+ messages in thread
From: Daniel Golle @ 2025-05-05 1:07 UTC (permalink / raw)
To: Felix Fietkau, Sean Wang, Lorenzo Bianconi, Andrew Lunn,
David S. Miller, Eric Dumazet, Jakub Kicinski, Paolo Abeni,
Matthias Brugger, AngeloGioacchino Del Regno, Elad Yifee, netdev,
linux-kernel, linux-arm-kernel, linux-mediatek
From: Frank Wunderlich <frank-w@public-files.de>
Remove redundant PSE reset.
When setting FE register there is no need to reset PSE,
doing so may cause FE to work abnormal.
Link: https://git01.mediatek.com/plugins/gitiles/openwrt/feeds/mtk-openwrt-feeds/+/3a5223473e086a4b54a2b9a44df7d9ddcc2bc75a
Fixes: dee4dd10c79aa ("net: ethernet: mtk_eth_soc: ppe: add support for multiple PPEs")
Signed-off-by: Frank Wunderlich <frank-w@public-files.de>
---
v2: fix commit title
drivers/net/ethernet/mediatek/mtk_eth_soc.c | 3 ---
1 file changed, 3 deletions(-)
diff --git a/drivers/net/ethernet/mediatek/mtk_eth_soc.c b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
index 53c39561b6d9a..22a532695fb0d 100644
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
@@ -3473,9 +3473,6 @@ static int mtk_open(struct net_device *dev)
}
mtk_gdm_config(eth, target_mac->id, gdm_config);
}
- /* Reset and enable PSE */
- mtk_w32(eth, RST_GL_PSE, MTK_RST_GL);
- mtk_w32(eth, 0, MTK_RST_GL);
napi_enable(ð->tx_napi);
napi_enable(ð->rx_napi);
--
2.49.0
^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free
2025-05-05 1:07 [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free Daniel Golle
2025-05-05 1:07 ` [PATCH net v2 2/2] net: ethernet: mtk_eth_soc: do not reset PSE when setting FE Daniel Golle
@ 2025-05-06 12:00 ` patchwork-bot+netdevbpf
1 sibling, 0 replies; 3+ messages in thread
From: patchwork-bot+netdevbpf @ 2025-05-06 12:00 UTC (permalink / raw)
To: Daniel Golle
Cc: nbd, sean.wang, lorenzo, andrew+netdev, davem, edumazet, kuba,
pabeni, matthias.bgg, angelogioacchino.delregno, eladwf, netdev,
linux-kernel, linux-arm-kernel, linux-mediatek
Hello:
This series was applied to netdev/net.git (main)
by Paolo Abeni <pabeni@redhat.com>:
On Mon, 5 May 2025 02:07:32 +0100 you wrote:
> The purpose of resetting the TX queue is to reset the byte and packet
> count as well as to clear the software flow control XOFF bit.
>
> MediaTek developers pointed out that netdev_reset_queue would only
> resets queue 0 of the network device.
>
> Queues that are not reset may cause unexpected issues.
>
> [...]
Here is the summary with links:
- [net,v2,1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free
https://git.kernel.org/netdev/net/c/4db6c75124d8
- [net,v2,2/2] net: ethernet: mtk_eth_soc: do not reset PSE when setting FE
https://git.kernel.org/netdev/net/c/e8716b5b0dff
You are awesome, thank you!
--
Deet-doot-dot, I am a bot.
https://korg.docs.kernel.org/patchwork/pwbot.html
^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2025-05-06 11:59 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-05-05 1:07 [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free Daniel Golle
2025-05-05 1:07 ` [PATCH net v2 2/2] net: ethernet: mtk_eth_soc: do not reset PSE when setting FE Daniel Golle
2025-05-06 12:00 ` [PATCH net v2 1/2] net: ethernet: mtk_eth_soc: reset all TX queues on DMA free patchwork-bot+netdevbpf
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).