]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
mt76: mt76x02u: fix possible memory leak in __mt76x02u_mcu_send_msg
authorLorenzo Bianconi <lorenzo@kernel.org>
Tue, 17 May 2022 16:37:07 +0000 (18:37 +0200)
committerStefan Bader <stefan.bader@canonical.com>
Mon, 17 Oct 2022 09:56:22 +0000 (11:56 +0200)
BugLink: https://bugs.launchpad.net/bugs/1990162
[ Upstream commit cffd93411575afd987788e2ec3cb8eaff70f0215 ]

Free the skb if mt76u_bulk_msg fails in __mt76x02u_mcu_send_msg routine.

Fixes: 4c89ff2c74e39 ("mt76: split __mt76u_mcu_send_msg and mt76u_mcu_send_msg routines")
Co-developed-by: Gergo Koteles <soyer@irl.hu>
Signed-off-by: Gergo Koteles <soyer@irl.hu>
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Signed-off-by: Felix Fietkau <nbd@nbd.name>
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
drivers/net/wireless/mediatek/mt76/mt76x02_usb_mcu.c

index 2953df7d8388d0c41e665af5c02bb847b2756e7e..c6c16fe8ee859dd3ae433d42ab3f7ef1fc3ff693 100644 (file)
@@ -108,7 +108,7 @@ __mt76x02u_mcu_send_msg(struct mt76_dev *dev, struct sk_buff *skb,
        ret = mt76u_bulk_msg(dev, skb->data, skb->len, NULL, 500,
                             MT_EP_OUT_INBAND_CMD);
        if (ret)
-               return ret;
+               goto out;
 
        if (wait_resp)
                ret = mt76x02u_mcu_wait_resp(dev, seq);