OSDN Git Service

wifi: mt76: add memory barrier to SDIO queue kick
authorDeren Wu <deren.wu@mediatek.com>
Sun, 15 Jan 2023 04:44:57 +0000 (12:44 +0800)
committerFelix Fietkau <nbd@nbd.name>
Fri, 3 Feb 2023 13:47:17 +0000 (14:47 +0100)
Ensure the entry has been fully updated before SDIO bus worker access
it. This patch would fix potential memory risk in both mt7663s and
mt7921s.

Fixes: 764dee47e2c1 ("mt76: sdio: move common code in mt76_sdio module")
Signed-off-by: Deren Wu <deren.wu@mediatek.com>
Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/sdio.c

index 228bc7d..4197231 100644 (file)
@@ -562,6 +562,10 @@ mt76s_tx_queue_skb_raw(struct mt76_dev *dev, struct mt76_queue *q,
 
        q->entry[q->head].buf_sz = len;
        q->entry[q->head].skb = skb;
+
+       /* ensure the entry fully updated before bus access */
+       smp_wmb();
+
        q->head = (q->head + 1) % q->ndesc;
        q->queued++;