mt76: mt7615: fix possible memory leak in mt7615_tm_set_tx_power
authorLorenzo Bianconi <lorenzo@kernel.org>
Fri, 21 Aug 2020 09:19:51 +0000 (11:19 +0200)
committerFelix Fietkau <nbd@nbd.name>
Thu, 24 Sep 2020 16:10:15 +0000 (18:10 +0200)
Fix a memory leak in mt7615_tm_set_tx_power routine if
mt7615_eeprom_get_target_power_index fails.
Moreover do not account req_header twice in mcu skb allocation.

Fixes: 4f0bce1c88882 ("mt76: mt7615: implement testmode support")
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7615/testmode.c

index 1730751133aa2b6760aa2a938e9bda047b254523..2cfa58d49832fa1f79a56e73fcde3a65957bf94d 100644 (file)
@@ -70,7 +70,7 @@ mt7615_tm_set_tx_power(struct mt7615_phy *phy)
        if (dev->mt76.test.state != MT76_TM_STATE_OFF)
                tx_power = dev->mt76.test.tx_power;
 
-       len = sizeof(req_hdr) + MT7615_EE_MAX - MT_EE_NIC_CONF_0;
+       len = MT7615_EE_MAX - MT_EE_NIC_CONF_0;
        skb = mt76_mcu_msg_alloc(&dev->mt76, NULL, sizeof(req_hdr) + len);
        if (!skb)
                return -ENOMEM;
@@ -83,8 +83,10 @@ mt7615_tm_set_tx_power(struct mt7615_phy *phy)
                int index;
 
                ret = mt7615_eeprom_get_target_power_index(dev, chandef->chan, i);
-               if (ret < 0)
+               if (ret < 0) {
+                       dev_kfree_skb(skb);
                        return -EINVAL;
+               }
 
                index = ret - MT_EE_NIC_CONF_0;
                if (tx_power && tx_power[i])