Commit 5ff4c4aa authored by Lorenzo Bianconi's avatar Lorenzo Bianconi Committed by Felix Fietkau

mt76: mt7921: set MT76_RESET during mac reset

Set MT76_RESET during mt7921_mac_reset in order to avoid packet
transmissions. Move tx scheduling at the end of reset routine.
Signed-off-by: default avatarLorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: default avatarFelix Fietkau <nbd@nbd.name>
parent 7f731405
...@@ -1294,6 +1294,7 @@ mt7921_mac_reset(struct mt7921_dev *dev) ...@@ -1294,6 +1294,7 @@ mt7921_mac_reset(struct mt7921_dev *dev)
mt76_wr(dev, MT_WFDMA0_HOST_INT_ENA, 0); mt76_wr(dev, MT_WFDMA0_HOST_INT_ENA, 0);
mt76_wr(dev, MT_PCIE_MAC_INT_ENABLE, 0x0); mt76_wr(dev, MT_PCIE_MAC_INT_ENABLE, 0x0);
set_bit(MT76_RESET, &dev->mphy.state);
set_bit(MT76_MCU_RESET, &dev->mphy.state); set_bit(MT76_MCU_RESET, &dev->mphy.state);
wake_up(&dev->mt76.mcu.wait); wake_up(&dev->mt76.mcu.wait);
skb_queue_purge(&dev->mt76.mcu.res_q); skb_queue_purge(&dev->mt76.mcu.res_q);
...@@ -1309,19 +1310,13 @@ mt7921_mac_reset(struct mt7921_dev *dev) ...@@ -1309,19 +1310,13 @@ mt7921_mac_reset(struct mt7921_dev *dev)
mt7921_tx_token_put(dev); mt7921_tx_token_put(dev);
idr_init(&dev->mt76.token); idr_init(&dev->mt76.token);
err = mt7921_wpdma_reset(dev, true); mt7921_wpdma_reset(dev, true);
if (err)
return err;
mt76_for_each_q_rx(&dev->mt76, i) { mt76_for_each_q_rx(&dev->mt76, i) {
napi_enable(&dev->mt76.napi[i]); napi_enable(&dev->mt76.napi[i]);
napi_schedule(&dev->mt76.napi[i]); napi_schedule(&dev->mt76.napi[i]);
} }
napi_enable(&dev->mt76.tx_napi);
napi_schedule(&dev->mt76.tx_napi);
mt76_worker_enable(&dev->mt76.tx_worker);
clear_bit(MT76_MCU_RESET, &dev->mphy.state); clear_bit(MT76_MCU_RESET, &dev->mphy.state);
mt76_wr(dev, MT_WFDMA0_HOST_INT_ENA, mt76_wr(dev, MT_WFDMA0_HOST_INT_ENA,
...@@ -1331,17 +1326,25 @@ mt7921_mac_reset(struct mt7921_dev *dev) ...@@ -1331,17 +1326,25 @@ mt7921_mac_reset(struct mt7921_dev *dev)
err = mt7921_run_firmware(dev); err = mt7921_run_firmware(dev);
if (err) if (err)
return err; goto out;
err = mt7921_mcu_set_eeprom(dev); err = mt7921_mcu_set_eeprom(dev);
if (err) if (err)
return err; goto out;
err = mt7921_mac_init(dev); err = mt7921_mac_init(dev);
if (err) if (err)
return err; goto out;
err = __mt7921_start(&dev->phy);
out:
clear_bit(MT76_RESET, &dev->mphy.state);
napi_enable(&dev->mt76.tx_napi);
napi_schedule(&dev->mt76.tx_napi);
mt76_worker_enable(&dev->mt76.tx_worker);
return __mt7921_start(&dev->phy); return err;
} }
/* system error recovery */ /* system error recovery */
......
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