]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
wifi: mt76: sdio: fix the deadlock caused by sdio->stat_work
authorSean Wang <sean.wang@mediatek.com>
Thu, 21 Jul 2022 22:39:35 +0000 (06:39 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 24 Oct 2022 07:57:09 +0000 (09:57 +0200)
[ Upstream commit e5d78fd998be94fb459a3d625df7367849b997b8 ]

Because wake_work and sdio->stat_work share the same workqueue mt76->wq,
if sdio->stat_work cannot acquire the mutex lock such as that was possibly
held up by [mt7615, mt7921]_mutex_acquire. Additionally, if
[mt7615, mt7921]_mutex_acquire was called by sdio->stat_work self, the wake
would be blocked by itself. Thus, we move the stat_work into
ieee80211_workqueue instead to break the deadlock.

Fixes: d39b52e31aa6 ("mt76: introduce mt76_sdio module")
Co-developed-by: YN Chen <YN.Chen@mediatek.com>
Signed-off-by: YN Chen <YN.Chen@mediatek.com>
Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/net/wireless/mediatek/mt76/sdio.c

index def7f325f5c546e7062debe70b504b9a08f3e0d0..574687ca93a9b59d81ef92671625a3f899e3c37c 100644 (file)
@@ -483,7 +483,7 @@ static void mt76s_status_worker(struct mt76_worker *w)
                if (dev->drv->tx_status_data &&
                    !test_and_set_bit(MT76_READING_STATS, &dev->phy.state) &&
                    !test_bit(MT76_STATE_SUSPEND, &dev->phy.state))
-                       queue_work(dev->wq, &dev->sdio.stat_work);
+                       ieee80211_queue_work(dev->hw, &dev->sdio.stat_work);
        } while (nframes > 0);
 
        if (resched)
@@ -510,7 +510,7 @@ static void mt76s_tx_status_data(struct work_struct *work)
        }
 
        if (count && test_bit(MT76_STATE_RUNNING, &dev->phy.state))
-               queue_work(dev->wq, &sdio->stat_work);
+               ieee80211_queue_work(dev->hw, &sdio->stat_work);
        else
                clear_bit(MT76_READING_STATS, &dev->phy.state);
 }