mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-10 06:52:53 +00:00
45 lines
1.2 KiB
Diff
45 lines
1.2 KiB
Diff
|
From: Felix Fietkau <nbd@nbd.name>
|
||
|
Date: Thu, 27 Aug 2020 09:44:43 +0200
|
||
|
Subject: [PATCH] net: ethernet: mtk_eth_soc: unmap rx data before calling
|
||
|
build_skb
|
||
|
|
||
|
Since build_skb accesses the data area (for initializing shinfo), dma unmap
|
||
|
needs to happen before that call
|
||
|
|
||
|
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||
|
---
|
||
|
|
||
|
--- a/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||
|
+++ b/drivers/net/ethernet/mediatek/mtk_eth_soc.c
|
||
|
@@ -1293,17 +1293,18 @@ static int mtk_poll_rx(struct napi_struc
|
||
|
goto release_desc;
|
||
|
}
|
||
|
|
||
|
+ dma_unmap_single(eth->dev, trxd.rxd1,
|
||
|
+ ring->buf_size, DMA_FROM_DEVICE);
|
||
|
+
|
||
|
/* receive data */
|
||
|
skb = build_skb(data, ring->frag_size);
|
||
|
if (unlikely(!skb)) {
|
||
|
- skb_free_frag(new_data);
|
||
|
+ skb_free_frag(data);
|
||
|
netdev->stats.rx_dropped++;
|
||
|
- goto release_desc;
|
||
|
+ goto skip_rx;
|
||
|
}
|
||
|
skb_reserve(skb, NET_SKB_PAD + NET_IP_ALIGN);
|
||
|
|
||
|
- dma_unmap_single(eth->dev, trxd.rxd1,
|
||
|
- ring->buf_size, DMA_FROM_DEVICE);
|
||
|
pktlen = RX_DMA_GET_PLEN0(trxd.rxd2);
|
||
|
skb->dev = netdev;
|
||
|
skb_put(skb, pktlen);
|
||
|
@@ -1321,6 +1322,7 @@ static int mtk_poll_rx(struct napi_struc
|
||
|
skb_record_rx_queue(skb, 0);
|
||
|
napi_gro_receive(napi, skb);
|
||
|
|
||
|
+skip_rx:
|
||
|
ring->data[idx] = new_data;
|
||
|
rxd->rxd1 = (unsigned int)dma_addr;
|
||
|
|