1 From: Lorenzo Bianconi <lorenzo@kernel.org>
2 Date: Mon, 18 Sep 2023 12:29:14 +0200
3 Subject: [PATCH] net: ethernet: mtk_wed: refactor mtk_wed_check_wfdma_rx_fill
6 Refactor mtk_wed_check_wfdma_rx_fill() in order to be reused adding HW
7 receive offload support for MT7988 SoC.
9 Co-developed-by: Sujuan Chen <sujuan.chen@mediatek.com>
10 Signed-off-by: Sujuan Chen <sujuan.chen@mediatek.com>
11 Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
12 Signed-off-by: Paolo Abeni <pabeni@redhat.com>
15 --- a/drivers/net/ethernet/mediatek/mtk_wed.c
16 +++ b/drivers/net/ethernet/mediatek/mtk_wed.c
17 @@ -586,22 +586,15 @@ mtk_wed_set_512_support(struct mtk_wed_d
21 -#define MTK_WFMDA_RX_DMA_EN BIT(2)
23 -mtk_wed_check_wfdma_rx_fill(struct mtk_wed_device *dev, int idx)
25 +mtk_wed_check_wfdma_rx_fill(struct mtk_wed_device *dev,
26 + struct mtk_wed_ring *ring)
31 - if (!(dev->rx_ring[idx].flags & MTK_WED_RING_CONFIGURED))
32 - return; /* queue is not configured by mt76 */
34 for (i = 0; i < 3; i++) {
36 + u32 cur_idx = readl(ring->wpdma + MTK_WED_RING_OFS_CPU_IDX);
38 - cur_idx = wed_r32(dev,
39 - MTK_WED_WPDMA_RING_RX_DATA(idx) +
40 - MTK_WED_RING_OFS_CPU_IDX);
41 if (cur_idx == MTK_WED_RX_RING_SIZE - 1)
44 @@ -610,12 +603,10 @@ mtk_wed_check_wfdma_rx_fill(struct mtk_w
47 dev_err(dev->hw->dev, "rx dma enable failed\n");
52 - val = wifi_r32(dev, dev->wlan.wpdma_rx_glo - dev->wlan.phy_base) |
53 - MTK_WFMDA_RX_DMA_EN;
54 - wifi_w32(dev, dev->wlan.wpdma_rx_glo - dev->wlan.phy_base, val);
59 @@ -1546,6 +1537,7 @@ mtk_wed_configure_irq(struct mtk_wed_dev
60 wed_w32(dev, MTK_WED_INT_MASK, irq_mask);
63 +#define MTK_WFMDA_RX_DMA_EN BIT(2)
65 mtk_wed_dma_enable(struct mtk_wed_device *dev)
67 @@ -1633,8 +1625,26 @@ mtk_wed_dma_enable(struct mtk_wed_device
68 wdma_set(dev, MTK_WDMA_WRBK_TX_CFG, MTK_WDMA_WRBK_TX_CFG_WRBK_EN);
71 - for (i = 0; i < MTK_WED_RX_QUEUES; i++)
72 - mtk_wed_check_wfdma_rx_fill(dev, i);
73 + for (i = 0; i < MTK_WED_RX_QUEUES; i++) {
74 + struct mtk_wed_ring *ring = &dev->rx_ring[i];
77 + if (!(ring->flags & MTK_WED_RING_CONFIGURED))
78 + continue; /* queue is not configured by mt76 */
80 + if (mtk_wed_check_wfdma_rx_fill(dev, ring)) {
81 + dev_err(dev->hw->dev,
82 + "rx_ring(%d) dma enable failed\n", i);
87 + dev->wlan.wpdma_rx_glo -
88 + dev->wlan.phy_base) | MTK_WFMDA_RX_DMA_EN;
90 + dev->wlan.wpdma_rx_glo - dev->wlan.phy_base,