]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: mt76: mt7925: extend mt7925_mcu_sta_hdr_trans_tlv for per-link STA
authorSean Wang <sean.wang@mediatek.com>
Thu, 13 Jun 2024 03:02:32 +0000 (20:02 -0700)
committerFelix Fietkau <nbd@nbd.name>
Tue, 9 Jul 2024 21:01:57 +0000 (23:01 +0200)
Extend mt7925_mcu_sta_hdr_trans_tlv with per-link STA configuration.

The patch we created is a prerequisite to enable the MLO function in the
driver. It is purely a refactoring patch so the functionality should
remain unchanged.

Co-developed-by: Ming Yen Hsieh <mingyen.hsieh@mediatek.com>
Signed-off-by: Ming Yen Hsieh <mingyen.hsieh@mediatek.com>
Co-developed-by: Deren Wu <deren.wu@mediatek.com>
Signed-off-by: Deren Wu <deren.wu@mediatek.com>
Signed-off-by: Sean Wang <sean.wang@mediatek.com>
Link: https://patch.msgid.link/20240613030241.5771-39-sean.wang@kernel.org
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7925/mcu.c

index bf2afaf4c0dca3830051e86dd67807fb34038b3a..901a5d1f4f04ca97edeaa70a3e079d981b2436c3 100644 (file)
@@ -847,7 +847,7 @@ EXPORT_SYMBOL_GPL(mt7925_run_firmware);
 static void
 mt7925_mcu_sta_hdr_trans_tlv(struct sk_buff *skb,
                             struct ieee80211_vif *vif,
-                            struct ieee80211_sta *sta)
+                            struct ieee80211_link_sta *link_sta)
 {
        struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
        struct sta_rec_hdr_trans *hdr_trans;
@@ -863,8 +863,8 @@ mt7925_mcu_sta_hdr_trans_tlv(struct sk_buff *skb,
        else
                hdr_trans->from_ds = true;
 
-       if (sta)
-               wcid = (struct mt76_wcid *)sta->drv_priv;
+       if (link_sta)
+               wcid = (struct mt76_wcid *)link_sta->sta->drv_priv;
        else
                wcid = &mvif->sta.deflink.wcid;
 
@@ -883,6 +883,7 @@ int mt7925_mcu_wtbl_update_hdr_trans(struct mt792x_dev *dev,
                                     struct ieee80211_sta *sta)
 {
        struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
+       struct ieee80211_link_sta *link_sta = sta ? &sta->deflink : NULL;
        struct mt792x_sta *msta;
        struct sk_buff *skb;
 
@@ -895,7 +896,7 @@ int mt7925_mcu_wtbl_update_hdr_trans(struct mt792x_dev *dev,
                return PTR_ERR(skb);
 
        /* starec hdr trans */
-       mt7925_mcu_sta_hdr_trans_tlv(skb, vif, sta);
+       mt7925_mcu_sta_hdr_trans_tlv(skb, vif, link_sta);
        return mt76_mcu_skb_send_msg(&dev->mt76, skb,
                                     MCU_WMWA_UNI_CMD(STA_REC_UPDATE), true);
 }
@@ -1664,12 +1665,8 @@ mt7925_mcu_sta_cmd(struct mt76_phy *phy,
                mt7925_mcu_sta_mld_tlv(skb, info->vif, info->link_sta->sta);
        }
 
-       if (info->enable) {
-               struct ieee80211_sta *sta = info->link_sta ?
-                       info->link_sta->sta : NULL;
-
-               mt7925_mcu_sta_hdr_trans_tlv(skb, info->vif, sta);
-       }
+       if (info->enable)
+               mt7925_mcu_sta_hdr_trans_tlv(skb, info->vif, info->link_sta);
 
        return mt76_mcu_skb_send_msg(dev, skb, info->cmd, true);
 }