mt76: mt7921s: fix firmware download random fail

To avoid racing problems in chip, mt7921s should reacquire drv-own after
firmware semaphore is released.

Fixes: 78b217580c ("mt76: mt7921s: fix bus hang with wrong privilege")
Signed-off-by: YN Chen <yn.chen@mediatek.com>
Signed-off-by: Deren Wu <deren.wu@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
YN Chen
2022-05-28 09:28:54 +08:00
committed by Felix Fietkau
parent 45b6f9cb8f
commit a55a0c701c

View File

@@ -583,13 +583,6 @@ static int mt7921_load_patch(struct mt7921_dev *dev)
if (ret) if (ret)
dev_err(dev->mt76.dev, "Failed to start patch\n"); dev_err(dev->mt76.dev, "Failed to start patch\n");
if (mt76_is_sdio(&dev->mt76)) {
/* activate again */
ret = __mt7921_mcu_fw_pmctrl(dev);
if (!ret)
ret = __mt7921_mcu_drv_pmctrl(dev);
}
out: out:
sem = mt76_connac_mcu_patch_sem_ctrl(&dev->mt76, false); sem = mt76_connac_mcu_patch_sem_ctrl(&dev->mt76, false);
switch (sem) { switch (sem) {
@@ -600,6 +593,14 @@ out:
dev_err(dev->mt76.dev, "Failed to release patch semaphore\n"); dev_err(dev->mt76.dev, "Failed to release patch semaphore\n");
break; break;
} }
if (!ret && mt76_is_sdio(&dev->mt76)) {
/* activate again */
ret = __mt7921_mcu_fw_pmctrl(dev);
if (!ret)
ret = __mt7921_mcu_drv_pmctrl(dev);
}
release_firmware(fw); release_firmware(fw);
return ret; return ret;