mt76: mt76u: resume all rx queue in mt76u_resume_rx
authorLorenzo Bianconi <lorenzo@kernel.org>
Wed, 15 Jan 2020 10:58:52 +0000 (11:58 +0100)
committerFelix Fietkau <nbd@nbd.name>
Fri, 14 Feb 2020 09:06:05 +0000 (10:06 +0100)
Resume all possible rx queues after suspend. This is a preliminary patch
to support mt7663u devices

Co-developed-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/usb.c

index f80380c674a18916f573004e3fe93962c92d3bf7..d85268c6df70d9232f405bd07bf732a0fd5e4f6b 100644 (file)
@@ -680,13 +680,24 @@ EXPORT_SYMBOL_GPL(mt76u_stop_rx);
 
 int mt76u_resume_rx(struct mt76_dev *dev)
 {
-       struct mt76_queue *q = &dev->q_rx[MT_RXQ_MAIN];
-       int i;
+       struct mt76_queue *q;
+       int i, j, err;
 
-       for (i = 0; i < q->ndesc; i++)
-               usb_unpoison_urb(q->entry[i].urb);
+       for (i = 0; i < __MT_RXQ_MAX; i++) {
+               q = &dev->q_rx[i];
 
-       return mt76u_submit_rx_buffers(dev, MT_RXQ_MAIN);
+               if (!q->ndesc)
+                       continue;
+
+               for (j = 0; j < q->ndesc; j++)
+                       usb_unpoison_urb(q->entry[j].urb);
+
+               err = mt76u_submit_rx_buffers(dev, i);
+               if (err < 0)
+                       return err;
+       }
+
+       return 0;
 }
 EXPORT_SYMBOL_GPL(mt76u_resume_rx);