From: Lorenzo Bianconi Date: Mon, 24 Jan 2022 20:03:44 +0000 (+0100) Subject: mt76: mt7921s: fix a possible memory leak in mt7921_load_patch X-Git-Tag: v5.17.2~618 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=b301043384c5c2447357952be9a536c2026d8ad0;p=users%2Fdwmw2%2Flinux.git mt76: mt7921s: fix a possible memory leak in mt7921_load_patch [ Upstream commit 11005b18f453aa192d035d410c11d07edcba5a45 ] Always release fw data at the end of mt7921_load_patch routine. Fixes: 78b217580c509 ("mt76: mt7921s: fix bus hang with wrong privilege") Signed-off-by: Lorenzo Bianconi Signed-off-by: Felix Fietkau Signed-off-by: Sasha Levin --- diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c b/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c index 152e7579f77d4..e82545a7fcc11 100644 --- a/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c +++ b/drivers/net/wireless/mediatek/mt76/mt7921/mcu.c @@ -707,12 +707,8 @@ static int mt7921_load_patch(struct mt7921_dev *dev) if (mt76_is_sdio(&dev->mt76)) { /* activate again */ ret = __mt7921_mcu_fw_pmctrl(dev); - if (ret) - return ret; - - ret = __mt7921_mcu_drv_pmctrl(dev); - if (ret) - return ret; + if (!ret) + ret = __mt7921_mcu_drv_pmctrl(dev); } out: