aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
authorFeng Jiang <jiangfeng@kylinos.cn>2025-04-02 14:24:15 +0800
committerFelix Fietkau <nbd@nbd.name>2025-05-22 12:57:32 +0200
commit7e1fcf687c2fb22ad25cf3fae322a37452f5f560 (patch)
tree1a1a9a2900204bf23f7e334b70742cd242870fd7
parentwifi: mt76: mt7996: remove duplicate check in mt7996_mcu_sta_mld_setup_tlv() (diff)
downloadwireguard-linux-7e1fcf687c2fb22ad25cf3fae322a37452f5f560.tar.xz
wireguard-linux-7e1fcf687c2fb22ad25cf3fae322a37452f5f560.zip
wifi: mt76: scan: Fix 'mlink' dereferenced before IS_ERR_OR_NULL check
Reported-by: kernel test robot <lkp@intel.com> Reported-by: Dan Carpenter <dan.carpenter@linaro.org> Closes: https://lore.kernel.org/r/202504011739.HvUKtUUe-lkp@intel.com/ Fixes: 3ba20af886d1 ("wifi: mt76: scan: set vif offchannel link for scanning/roc") Signed-off-by: Feng Jiang <jiangfeng@kylinos.cn> Link: https://patch.msgid.link/20250402062415.25434-1-jiangfeng@kylinos.cn Signed-off-by: Felix Fietkau <nbd@nbd.name>
Diffstat (limited to '')
-rw-r--r--drivers/net/wireless/mediatek/mt76/channel.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/net/wireless/mediatek/mt76/channel.c b/drivers/net/wireless/mediatek/mt76/channel.c
index e7b839e74290..cc2d888e3f17 100644
--- a/drivers/net/wireless/mediatek/mt76/channel.c
+++ b/drivers/net/wireless/mediatek/mt76/channel.c
@@ -302,11 +302,13 @@ void mt76_put_vif_phy_link(struct mt76_phy *phy, struct ieee80211_vif *vif,
struct mt76_vif_link *mlink)
{
struct mt76_dev *dev = phy->dev;
- struct mt76_vif_data *mvif = mlink->mvif;
+ struct mt76_vif_data *mvif;
if (IS_ERR_OR_NULL(mlink) || !mlink->offchannel)
return;
+ mvif = mlink->mvif;
+
rcu_assign_pointer(mvif->offchannel_link, NULL);
dev->drv->vif_link_remove(phy, vif, &vif->bss_conf, mlink);
kfree(mlink);