mt76: move tx tasklet to struct mt76_dev
authorFelix Fietkau <nbd@nbd.name>
Wed, 13 Mar 2019 19:17:45 +0000 (20:17 +0100)
committerFelix Fietkau <nbd@nbd.name>
Wed, 1 May 2019 11:03:58 +0000 (13:03 +0200)
Allows it to be scheduled from core code

Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt76.h
drivers/net/wireless/mediatek/mt76/mt7603/core.c
drivers/net/wireless/mediatek/mt76/mt7603/dma.c
drivers/net/wireless/mediatek/mt76/mt7603/mac.c
drivers/net/wireless/mediatek/mt76/mt7603/mt7603.h
drivers/net/wireless/mediatek/mt76/mt76x0/usb.c
drivers/net/wireless/mediatek/mt76/mt76x02_mmio.c
drivers/net/wireless/mediatek/mt76/mt76x2/usb.c
drivers/net/wireless/mediatek/mt76/usb.c

index 176faaac8748bd3d6dc7aa09388a6e835775f8b0..c35305ad2d12784ac1e636b30867b0acdf28a942 100644 (file)
@@ -386,7 +386,6 @@ struct mt76_usb {
        u8 data[32];
 
        struct tasklet_struct rx_tasklet;
-       struct tasklet_struct tx_tasklet;
        struct delayed_work stat_work;
 
        u8 out_ep[__MT_EP_OUT_MAX];
@@ -448,6 +447,8 @@ struct mt76_dev {
        const struct mt76_queue_ops *queue_ops;
        int tx_dma_idx[4];
 
+       struct tasklet_struct tx_tasklet;
+
        wait_queue_head_t tx_wait;
        struct sk_buff_head status_list;
 
index 4668c573f74a0da9bf88e5ea78f055c416203c5e..0d06ff67ce44c10e2e33b05e8ea02d8e035174dd 100644 (file)
@@ -35,7 +35,7 @@ irqreturn_t mt7603_irq_handler(int irq, void *dev_instance)
 
        if (intr & MT_INT_TX_DONE_ALL) {
                mt7603_irq_disable(dev, MT_INT_TX_DONE_ALL);
-               tasklet_schedule(&dev->tx_tasklet);
+               tasklet_schedule(&dev->mt76.tx_tasklet);
        }
 
        if (intr & MT_INT_RX_DONE(0)) {
index 37cedfcedce4c8f4ae2739edd39ce9292a07903e..f7e3566c96fd00b45332c8cb8e5e03c6de8aca79 100644 (file)
@@ -164,7 +164,7 @@ int mt7603_dma_init(struct mt7603_dev *dev)
        init_waitqueue_head(&dev->mt76.mmio.mcu.wait);
        skb_queue_head_init(&dev->mt76.mmio.mcu.res_q);
 
-       tasklet_init(&dev->tx_tasklet, mt7603_tx_tasklet, (unsigned long)dev);
+       tasklet_init(&dev->mt76.tx_tasklet, mt7603_tx_tasklet, (unsigned long)dev);
 
        mt76_clear(dev, MT_WPDMA_GLO_CFG,
                   MT_WPDMA_GLO_CFG_TX_DMA_EN |
@@ -224,6 +224,6 @@ void mt7603_dma_cleanup(struct mt7603_dev *dev)
                   MT_WPDMA_GLO_CFG_RX_DMA_EN |
                   MT_WPDMA_GLO_CFG_TX_WRITEBACK_DONE);
 
-       tasklet_kill(&dev->tx_tasklet);
+       tasklet_kill(&dev->mt76.tx_tasklet);
        mt76_dma_cleanup(&dev->mt76);
 }
index 47f5005ea48a6dc65e7e016825c39b08d04ff5de..52956bf8a979c62531b066ecc5fdd370738421af 100644 (file)
@@ -1277,7 +1277,7 @@ static void mt7603_mac_watchdog_reset(struct mt7603_dev *dev)
        /* lock/unlock all queues to ensure that no tx is pending */
        mt76_txq_schedule_all(&dev->mt76);
 
-       tasklet_disable(&dev->tx_tasklet);
+       tasklet_disable(&dev->mt76.tx_tasklet);
        tasklet_disable(&dev->pre_tbtt_tasklet);
        napi_disable(&dev->mt76.napi[0]);
        napi_disable(&dev->mt76.napi[1]);
@@ -1324,8 +1324,8 @@ skip_dma_reset:
        clear_bit(MT76_RESET, &dev->mt76.state);
        mutex_unlock(&dev->mt76.mutex);
 
-       tasklet_enable(&dev->tx_tasklet);
-       tasklet_schedule(&dev->tx_tasklet);
+       tasklet_enable(&dev->mt76.tx_tasklet);
+       tasklet_schedule(&dev->mt76.tx_tasklet);
 
        tasklet_enable(&dev->pre_tbtt_tasklet);
        mt7603_beacon_set_timer(dev, -1, beacon_int);
index c355e36966dd825a437eb109543892faa18dcee7..36875ff4c3bc3abe7ec058d650003ed3bf9be080 100644 (file)
@@ -145,7 +145,6 @@ struct mt7603_dev {
        unsigned int reset_cause[__RESET_CAUSE_MAX];
 
        struct delayed_work mac_work;
-       struct tasklet_struct tx_tasklet;
        struct tasklet_struct pre_tbtt_tasklet;
 };
 
index 1ef00e971cfaffc9b3a299341d1b9bd56c915325..db2c3c6c2c66cff678bccf606978b4ed36651680 100644 (file)
@@ -332,7 +332,7 @@ static int __maybe_unused mt76x0_resume(struct usb_interface *usb_intf)
                goto err;
 
        tasklet_enable(&usb->rx_tasklet);
-       tasklet_enable(&usb->tx_tasklet);
+       tasklet_enable(&dev->mt76.tx_tasklet);
 
        ret = mt76x0u_init_hardware(dev);
        if (ret)
index 705c0939d10be47f6f504ad053fc2b2fd04e9cda..958b2a3e48786538ba8ad562ac5d0545d196c929 100644 (file)
@@ -180,7 +180,8 @@ int mt76x02_dma_init(struct mt76x02_dev *dev)
        if (!status_fifo)
                return -ENOMEM;
 
-       tasklet_init(&dev->tx_tasklet, mt76x02_tx_tasklet, (unsigned long) dev);
+       tasklet_init(&dev->mt76.tx_tasklet, mt76x02_tx_tasklet,
+                    (unsigned long) dev);
        tasklet_init(&dev->pre_tbtt_tasklet, mt76x02_pre_tbtt_tasklet,
                     (unsigned long)dev);
 
@@ -250,7 +251,7 @@ irqreturn_t mt76x02_irq_handler(int irq, void *dev_instance)
 
        if (intr & MT_INT_TX_DONE_ALL) {
                mt76x02_irq_disable(dev, MT_INT_TX_DONE_ALL);
-               tasklet_schedule(&dev->tx_tasklet);
+               tasklet_schedule(&dev->mt76.tx_tasklet);
        }
 
        if (intr & MT_INT_RX_DONE(0)) {
@@ -276,7 +277,7 @@ irqreturn_t mt76x02_irq_handler(int irq, void *dev_instance)
 
        if (intr & MT_INT_TX_STAT) {
                mt76x02_mac_poll_tx_status(dev, true);
-               tasklet_schedule(&dev->tx_tasklet);
+               tasklet_schedule(&dev->mt76.tx_tasklet);
        }
 
        if (intr & MT_INT_GPTIMER) {
@@ -306,7 +307,7 @@ static void mt76x02_dma_enable(struct mt76x02_dev *dev)
 
 void mt76x02_dma_cleanup(struct mt76x02_dev *dev)
 {
-       tasklet_kill(&dev->tx_tasklet);
+       tasklet_kill(&dev->mt76.tx_tasklet);
        mt76_dma_cleanup(&dev->mt76);
 }
 EXPORT_SYMBOL_GPL(mt76x02_dma_cleanup);
@@ -425,7 +426,7 @@ static void mt76x02_watchdog_reset(struct mt76x02_dev *dev)
        set_bit(MT76_RESET, &dev->mt76.state);
 
        tasklet_disable(&dev->pre_tbtt_tasklet);
-       tasklet_disable(&dev->tx_tasklet);
+       tasklet_disable(&dev->mt76.tx_tasklet);
 
        for (i = 0; i < ARRAY_SIZE(dev->mt76.napi); i++)
                napi_disable(&dev->mt76.napi[i]);
@@ -478,8 +479,8 @@ static void mt76x02_watchdog_reset(struct mt76x02_dev *dev)
 
        clear_bit(MT76_RESET, &dev->mt76.state);
 
-       tasklet_enable(&dev->tx_tasklet);
-       tasklet_schedule(&dev->tx_tasklet);
+       tasklet_enable(&dev->mt76.tx_tasklet);
+       tasklet_schedule(&dev->mt76.tx_tasklet);
 
        tasklet_enable(&dev->pre_tbtt_tasklet);
 
index d08bb964966b108f19ae36b86a901d0afb4231bd..d1bddd5931bd31b0b26ec3aabe6009ccedd71f95 100644 (file)
@@ -124,7 +124,7 @@ static int __maybe_unused mt76x2u_resume(struct usb_interface *intf)
                goto err;
 
        tasklet_enable(&usb->rx_tasklet);
-       tasklet_enable(&usb->tx_tasklet);
+       tasklet_enable(&dev->mt76.tx_tasklet);
 
        err = mt76x2u_init_hardware(dev);
        if (err < 0)
index d93dadce95abc33e36dff8eab80a2273f6e4442d..15aeda0582e77d40557059b6eabd5e5a4c3750e3 100644 (file)
@@ -702,7 +702,7 @@ static void mt76u_complete_tx(struct urb *urb)
                dev_err(dev->dev, "tx urb failed: %d\n", urb->status);
        e->done = true;
 
-       tasklet_schedule(&dev->usb.tx_tasklet);
+       tasklet_schedule(&dev->tx_tasklet);
 }
 
 static int
@@ -843,7 +843,7 @@ static void mt76u_stop_tx(struct mt76_dev *dev)
 void mt76u_stop_queues(struct mt76_dev *dev)
 {
        tasklet_disable(&dev->usb.rx_tasklet);
-       tasklet_disable(&dev->usb.tx_tasklet);
+       tasklet_disable(&dev->tx_tasklet);
 
        mt76u_stop_rx(dev);
        mt76u_stop_tx(dev);
@@ -898,7 +898,7 @@ int mt76u_init(struct mt76_dev *dev,
        struct mt76_usb *usb = &dev->usb;
 
        tasklet_init(&usb->rx_tasklet, mt76u_rx_tasklet, (unsigned long)dev);
-       tasklet_init(&usb->tx_tasklet, mt76u_tx_tasklet, (unsigned long)dev);
+       tasklet_init(&dev->tx_tasklet, mt76u_tx_tasklet, (unsigned long)dev);
        INIT_DELAYED_WORK(&usb->stat_work, mt76u_tx_status_data);
        skb_queue_head_init(&dev->rx_skb[MT_RXQ_MAIN]);