[bug report] wifi: mt76: mt7996: Rely on mt7996_sta_link in sta_add/sta_remove callbacks
Lorenzo Bianconi
lorenzo at kernel.org
Fri Mar 21 08:48:11 PDT 2025
> Hello Lorenzo Bianconi,
Hi Dan,
this issue is already fixed by the following patch:
https://lore.kernel.org/linux-wireless/20250320201914.48159-1-qasdev00@gmail.com/T/#u
Regards,
Lorenzo
>
> Commit dd82a9e02c05 ("wifi: mt76: mt7996: Rely on mt7996_sta_link in
> sta_add/sta_remove callbacks") from Mar 11, 2025 (linux-next), leads
> to the following Smatch static checker warning:
>
> drivers/net/wireless/mediatek/mt76/mt7996/main.c:1023 mt7996_mac_sta_add_links()
> error: uninitialized symbol 'err'.
>
> drivers/net/wireless/mediatek/mt76/mt7996/main.c
> 984 static int
> 985 mt7996_mac_sta_add_links(struct mt7996_dev *dev, struct ieee80211_vif *vif,
> 986 struct ieee80211_sta *sta, unsigned long new_links)
> 987 {
> 988 struct mt7996_sta *msta = (struct mt7996_sta *)sta->drv_priv;
> 989 unsigned int link_id;
> 990 int err;
> 991
> 992 for_each_set_bit(link_id, &new_links, IEEE80211_MLD_MAX_NUM_LINKS) {
> 993 struct ieee80211_bss_conf *link_conf;
> 994 struct ieee80211_link_sta *link_sta;
> 995 struct mt7996_vif_link *link;
> 996
> 997 if (rcu_access_pointer(msta->link[link_id]))
> 998 continue;
>
> What about if there are no new links or we hit the continue on every
> iteration.
>
> 999
> 1000 link_conf = link_conf_dereference_protected(vif, link_id);
> 1001 if (!link_conf)
> 1002 goto error_unlink;
>
> error code?
>
> 1003
> 1004 link = mt7996_vif_link(dev, vif, link_id);
> 1005 if (!link)
> 1006 goto error_unlink;
>
> error code?
>
> 1007
> 1008 link_sta = link_sta_dereference_protected(sta, link_id);
> 1009 if (!link_sta)
> 1010 goto error_unlink;
>
> error code?
>
> 1011
> 1012 err = mt7996_mac_sta_init_link(dev, link_conf, link_sta, link,
> 1013 link_id);
> 1014 if (err)
> 1015 goto error_unlink;
> 1016 }
> 1017
> 1018 return 0;
> 1019
> 1020 error_unlink:
> 1021 mt7996_mac_sta_remove_links(dev, sta, new_links);
> 1022
> --> 1023 return err;
> 1024 }
>
> regards,
> dan carpenter
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 228 bytes
Desc: not available
URL: <http://lists.infradead.org/pipermail/linux-mediatek/attachments/20250321/9236ef5e/attachment.sig>
More information about the Linux-mediatek
mailing list