Commit d878d3dc authored by Lorenzo Bianconi's avatar Lorenzo Bianconi Committed by Felix Fietkau

wifi: mt76: mt7915: get rid of wed rx_buf_ring page_frag_cache

Since wed rx_buf_ring page_frag_cache is no longer used in a hot path,
remove it and rely on page allocation APIs in
mt7915_mmio_wed_init_rx_buf() and mt7915_mmio_wed_release_rx_buf()
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
parent 47180ecf
...@@ -594,10 +594,13 @@ static void mt7915_mmio_wed_offload_disable(struct mtk_wed_device *wed) ...@@ -594,10 +594,13 @@ static void mt7915_mmio_wed_offload_disable(struct mtk_wed_device *wed)
static void mt7915_mmio_wed_release_rx_buf(struct mtk_wed_device *wed) static void mt7915_mmio_wed_release_rx_buf(struct mtk_wed_device *wed)
{ {
struct mt7915_dev *dev; struct mt7915_dev *dev;
struct page *page; u32 length;
int i; int i;
dev = container_of(wed, struct mt7915_dev, mt76.mmio.wed); dev = container_of(wed, struct mt7915_dev, mt76.mmio.wed);
length = SKB_DATA_ALIGN(NET_SKB_PAD + wed->wlan.rx_size +
sizeof(struct skb_shared_info));
for (i = 0; i < dev->mt76.rx_token_size; i++) { for (i = 0; i < dev->mt76.rx_token_size; i++) {
struct mt76_txwi_cache *t; struct mt76_txwi_cache *t;
...@@ -607,18 +610,11 @@ static void mt7915_mmio_wed_release_rx_buf(struct mtk_wed_device *wed) ...@@ -607,18 +610,11 @@ static void mt7915_mmio_wed_release_rx_buf(struct mtk_wed_device *wed)
dma_unmap_single(dev->mt76.dma_dev, t->dma_addr, dma_unmap_single(dev->mt76.dma_dev, t->dma_addr,
wed->wlan.rx_size, DMA_FROM_DEVICE); wed->wlan.rx_size, DMA_FROM_DEVICE);
skb_free_frag(t->ptr); __free_pages(virt_to_page(t->ptr), get_order(length));
t->ptr = NULL; t->ptr = NULL;
mt76_put_rxwi(&dev->mt76, t); mt76_put_rxwi(&dev->mt76, t);
} }
if (!wed->rx_buf_ring.rx_page.va)
return;
page = virt_to_page(wed->rx_buf_ring.rx_page.va);
__page_frag_cache_drain(page, wed->rx_buf_ring.rx_page.pagecnt_bias);
memset(&wed->rx_buf_ring.rx_page, 0, sizeof(wed->rx_buf_ring.rx_page));
} }
static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size) static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size)
...@@ -635,19 +631,20 @@ static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size) ...@@ -635,19 +631,20 @@ static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size)
for (i = 0; i < size; i++) { for (i = 0; i < size; i++) {
struct mt76_txwi_cache *t = mt76_get_rxwi(&dev->mt76); struct mt76_txwi_cache *t = mt76_get_rxwi(&dev->mt76);
dma_addr_t phy_addr; dma_addr_t phy_addr;
struct page *page;
int token; int token;
void *ptr; void *ptr;
ptr = page_frag_alloc(&wed->rx_buf_ring.rx_page, length, page = __dev_alloc_pages(GFP_KERNEL, get_order(length));
GFP_KERNEL); if (!page)
if (!ptr)
goto unmap; goto unmap;
ptr = page_address(page);
phy_addr = dma_map_single(dev->mt76.dma_dev, ptr, phy_addr = dma_map_single(dev->mt76.dma_dev, ptr,
wed->wlan.rx_size, wed->wlan.rx_size,
DMA_TO_DEVICE); DMA_TO_DEVICE);
if (unlikely(dma_mapping_error(dev->mt76.dev, phy_addr))) { if (unlikely(dma_mapping_error(dev->mt76.dev, phy_addr))) {
skb_free_frag(ptr); __free_pages(page, get_order(length));
goto unmap; goto unmap;
} }
...@@ -656,7 +653,7 @@ static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size) ...@@ -656,7 +653,7 @@ static u32 mt7915_mmio_wed_init_rx_buf(struct mtk_wed_device *wed, int size)
if (token < 0) { if (token < 0) {
dma_unmap_single(dev->mt76.dma_dev, phy_addr, dma_unmap_single(dev->mt76.dma_dev, phy_addr,
wed->wlan.rx_size, DMA_TO_DEVICE); wed->wlan.rx_size, DMA_TO_DEVICE);
skb_free_frag(ptr); __free_pages(page, get_order(length));
goto unmap; goto unmap;
} }
......
...@@ -103,7 +103,6 @@ struct mtk_wed_device { ...@@ -103,7 +103,6 @@ struct mtk_wed_device {
struct { struct {
int size; int size;
struct page_frag_cache rx_page;
struct mtk_rxbm_desc *desc; struct mtk_rxbm_desc *desc;
dma_addr_t desc_phys; dma_addr_t desc_phys;
} rx_buf_ring; } rx_buf_ring;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment