]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: mt76: mt7996: Overwrite unspecified link_id in mt7996_tx()
authorLorenzo Bianconi <lorenzo@kernel.org>
Tue, 8 Jul 2025 07:12:04 +0000 (09:12 +0200)
committerFelix Fietkau <nbd@nbd.name>
Mon, 15 Sep 2025 07:47:38 +0000 (09:47 +0200)
Set link_id to msta or mvif primary value if it is set to
IEEE80211_LINK_UNSPECIFIED by mac80211 in mt7996_tx routine.

Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Link: https://patch.msgid.link/20250708-mt7996-mlo-fixes-v2-v1-1-f2682818a8a3@kernel.org
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7996/main.c

index 84f731b387d20aae35477e59ca5c6496f894dd40..35fdd3104f216ce345c76af8ca7ebbc6b0a0715f 100644 (file)
@@ -1221,21 +1221,30 @@ static void mt7996_tx(struct ieee80211_hw *hw,
        struct mt76_wcid *wcid = &dev->mt76.global_wcid;
        u8 link_id = u32_get_bits(info->control.flags,
                                  IEEE80211_TX_CTRL_MLO_LINK);
+       struct mt7996_sta *msta;
+       struct mt7996_vif *mvif;
 
        rcu_read_lock();
 
-       if (vif) {
-               struct mt7996_vif *mvif = (void *)vif->drv_priv;
+       msta = control->sta ? (void *)control->sta->drv_priv : NULL;
+       mvif = vif ? (void *)vif->drv_priv : NULL;
+
+       /* Use primary link_id if the value from mac80211 is set to
+        * IEEE80211_LINK_UNSPECIFIED.
+        */
+       if (link_id == IEEE80211_LINK_UNSPECIFIED) {
+               if (msta)
+                       link_id = msta->deflink_id;
+               else if (mvif)
+                       link_id = mvif->mt76.deflink_id;
+       }
+
+       if (mvif) {
                struct mt76_vif_link *mlink = &mvif->deflink.mt76;
 
                if (link_id < IEEE80211_LINK_UNSPECIFIED)
                        mlink = rcu_dereference(mvif->mt76.link[link_id]);
 
-               if (!mlink) {
-                       ieee80211_free_txskb(hw, skb);
-                       goto unlock;
-               }
-
                if (mlink->wcid)
                        wcid = mlink->wcid;
 
@@ -1254,8 +1263,7 @@ static void mt7996_tx(struct ieee80211_hw *hw,
                goto unlock;
        }
 
-       if (control->sta && link_id < IEEE80211_LINK_UNSPECIFIED) {
-               struct mt7996_sta *msta = (void *)control->sta->drv_priv;
+       if (msta && link_id < IEEE80211_LINK_UNSPECIFIED) {
                struct mt7996_sta_link *msta_link;
 
                msta_link = rcu_dereference(msta->link[link_id]);