mt76: use threaded NAPI
authorFelix Fietkau <nbd@nbd.name>
Sun, 26 Jul 2020 11:09:51 +0000 (13:09 +0200)
committerFelix Fietkau <nbd@nbd.name>
Sun, 11 Apr 2021 22:01:21 +0000 (00:01 +0200)
With threaded NAPI, the rx handler function is no longer bound to the CPU that
fired the interrupt, which significantly helps to spread the workload over
multiple CPUs, especially when multiple devices are using threaded NAPI at the
same time.
Exclude the tx handler from threaded NAPI by using a separate dummy netdev.
The work is small and short-lived enough that it makes more sense to run it in
softirq instead of creating a dedicated thread

Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/dma.c
drivers/net/wireless/mediatek/mt76/mt76.h
drivers/net/wireless/mediatek/mt76/mt7603/dma.c
drivers/net/wireless/mediatek/mt76/mt7615/dma.c
drivers/net/wireless/mediatek/mt76/mt76x02_mmio.c
drivers/net/wireless/mediatek/mt76/mt7915/dma.c
drivers/net/wireless/mediatek/mt76/mt7921/dma.c

index 2f27c43..6273b2c 100644 (file)
@@ -602,7 +602,6 @@ mt76_dma_rx_poll(struct napi_struct *napi, int budget)
        dev = container_of(napi->dev, struct mt76_dev, napi_dev);
        qid = napi - dev->napi;
 
-       local_bh_disable();
        rcu_read_lock();
 
        do {
@@ -612,7 +611,6 @@ mt76_dma_rx_poll(struct napi_struct *napi, int budget)
        } while (cur && done < budget);
 
        rcu_read_unlock();
-       local_bh_enable();
 
        if (done < budget && napi_complete(napi))
                dev->drv->rx_poll_complete(dev, qid);
@@ -626,6 +624,10 @@ mt76_dma_init(struct mt76_dev *dev)
        int i;
 
        init_dummy_netdev(&dev->napi_dev);
+       init_dummy_netdev(&dev->tx_napi_dev);
+       snprintf(dev->napi_dev.name, sizeof(dev->napi_dev.name), "%s",
+                wiphy_name(dev->hw->wiphy));
+       dev->napi_dev.threaded = 1;
 
        mt76_for_each_q_rx(dev, i) {
                netif_napi_add(&dev->napi_dev, &dev->napi[i], mt76_dma_rx_poll,
index 5561f81..4d71ca2 100644 (file)
@@ -637,6 +637,7 @@ struct mt76_dev {
        struct mt76_mcu mcu;
 
        struct net_device napi_dev;
+       struct net_device tx_napi_dev;
        spinlock_t rx_lock;
        struct napi_struct napi[__MT_RXQ_MAX];
        struct sk_buff_head rx_skb[__MT_RXQ_MAX];
index 0086f18..2b62441 100644 (file)
@@ -223,7 +223,7 @@ int mt7603_dma_init(struct mt7603_dev *dev)
        if (ret)
                return ret;
 
-       netif_tx_napi_add(&dev->mt76.napi_dev, &dev->mt76.tx_napi,
+       netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi,
                          mt7603_poll_tx, NAPI_POLL_WEIGHT);
        napi_enable(&dev->mt76.tx_napi);
 
index 25e3069..2e3120e 100644 (file)
@@ -245,7 +245,7 @@ int mt7615_dma_init(struct mt7615_dev *dev)
        if (ret < 0)
                return ret;
 
-       netif_tx_napi_add(&dev->mt76.napi_dev, &dev->mt76.tx_napi,
+       netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi,
                          mt7615_poll_tx, NAPI_POLL_WEIGHT);
        napi_enable(&dev->mt76.tx_napi);
 
index e7a46ac..fc12824 100644 (file)
@@ -230,7 +230,7 @@ int mt76x02_dma_init(struct mt76x02_dev *dev)
        if (ret)
                return ret;
 
-       netif_tx_napi_add(&dev->mt76.napi_dev, &dev->mt76.tx_napi,
+       netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi,
                          mt76x02_poll_tx, NAPI_POLL_WEIGHT);
        napi_enable(&dev->mt76.tx_napi);
 
index bf51304..3c961bf 100644 (file)
@@ -325,7 +325,7 @@ int mt7915_dma_init(struct mt7915_dev *dev)
        if (ret < 0)
                return ret;
 
-       netif_tx_napi_add(&dev->mt76.napi_dev, &dev->mt76.tx_napi,
+       netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi,
                          mt7915_poll_tx, NAPI_POLL_WEIGHT);
        napi_enable(&dev->mt76.tx_napi);
 
index cd96656..60de29a 100644 (file)
@@ -299,7 +299,7 @@ int mt7921_dma_init(struct mt7921_dev *dev)
        if (ret < 0)
                return ret;
 
-       netif_tx_napi_add(&dev->mt76.napi_dev, &dev->mt76.tx_napi,
+       netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi,
                          mt7921_poll_tx, NAPI_POLL_WEIGHT);
        napi_enable(&dev->mt76.tx_napi);