mt76: mt7615: fix potential memory leak in mcu message handler
authorSean Wang <sean.wang@mediatek.com>
Tue, 7 Jul 2020 19:16:48 +0000 (03:16 +0800)
committerFelix Fietkau <nbd@nbd.name>
Tue, 21 Jul 2020 17:01:18 +0000 (19:01 +0200)
Fix potential memory leak in mcu message handler on error condition.

Fixes: 0e6a29e477f3 ("mt76: mt7615: add support to read temperature from mcu")
Acked-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7615/mcu.c

index 2e9e0002331e44ffb596578acba9a81324d470f3..83e29ee7b08bea1cd5f27019a4ec7cb123afea54 100644 (file)
@@ -183,8 +183,10 @@ mt7615_mcu_parse_response(struct mt7615_dev *dev, int cmd,
        struct mt7615_mcu_rxd *rxd = (struct mt7615_mcu_rxd *)skb->data;
        int ret = 0;
 
-       if (seq != rxd->seq)
-               return -EAGAIN;
+       if (seq != rxd->seq) {
+               ret = -EAGAIN;
+               goto out;
+       }
 
        switch (cmd) {
        case MCU_CMD_PATCH_SEM_CONTROL:
@@ -215,6 +217,7 @@ mt7615_mcu_parse_response(struct mt7615_dev *dev, int cmd,
        default:
                break;
        }
+out:
        dev_kfree_skb(skb);
 
        return ret;