blob: 4454f5fad0f22cbf2f6777ece5f0f28fbc54610f [file] [log] [blame]
b.liue9582032025-04-17 19:18:16 +08001From: Felix Fietkau <nbd@nbd.name>
2Date: Thu, 27 Aug 2020 09:44:43 +0200
3Subject: [PATCH] net: ethernet: mtk_eth_soc: unmap rx data before calling
4 build_skb
5
6Since build_skb accesses the data area (for initializing shinfo), dma unmap
7needs to happen before that call
8
9Signed-off-by: Felix Fietkau <nbd@nbd.name>
10---
11
12--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
13+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
14@@ -1328,17 +1328,18 @@ static int mtk_poll_rx(struct napi_struc
15 goto release_desc;
16 }
17
18+ dma_unmap_single(eth->dev, trxd.rxd1,
19+ ring->buf_size, DMA_FROM_DEVICE);
20+
21 /* receive data */
22 skb = build_skb(data, ring->frag_size);
23 if (unlikely(!skb)) {
24- skb_free_frag(new_data);
25+ skb_free_frag(data);
26 netdev->stats.rx_dropped++;
27- goto release_desc;
28+ goto skip_rx;
29 }
30 skb_reserve(skb, NET_SKB_PAD + NET_IP_ALIGN);
31
32- dma_unmap_single(eth->dev, trxd.rxd1,
33- ring->buf_size, DMA_FROM_DEVICE);
34 pktlen = RX_DMA_GET_PLEN0(trxd.rxd2);
35 skb->dev = netdev;
36 skb_put(skb, pktlen);
37@@ -1356,6 +1357,7 @@ static int mtk_poll_rx(struct napi_struc
38 skb_record_rx_queue(skb, 0);
39 napi_gro_receive(napi, skb);
40
41+skip_rx:
42 ring->data[idx] = new_data;
43 rxd->rxd1 = (unsigned int)dma_addr;
44