]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
wifi: mt76: mt7925: extend mt7925_mcu_uni_bss_ps for per-link BSS
authorSean Wang <sean.wang@mediatek.com>
Thu, 13 Jun 2024 03:02:15 +0000 (20:02 -0700)
committerFelix Fietkau <nbd@nbd.name>
Tue, 9 Jul 2024 21:01:52 +0000 (23:01 +0200)
Extend mt7925_mcu_uni_bss_ps with per-link BSS 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: 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-22-sean.wang@kernel.org
Signed-off-by: Felix Fietkau <nbd@nbd.name>
drivers/net/wireless/mediatek/mt76/mt7925/main.c
drivers/net/wireless/mediatek/mt76/mt7925/mcu.c
drivers/net/wireless/mediatek/mt76/mt7925/mt7925.h

index bba17e51a0235008f5ec6b071731f26a8c3b8391..cd20b85109b96cbc4c25eb7fafa3cb39e4bdd239 100644 (file)
@@ -1383,7 +1383,7 @@ static void mt7925_vif_cfg_changed(struct ieee80211_hw *hw,
        }
 
        if (changed & BSS_CHANGED_PS)
-               mt7925_mcu_uni_bss_ps(dev, vif);
+               mt7925_mcu_uni_bss_ps(dev, &vif->bss_conf);
 
        mt792x_mutex_release(dev);
 }
index 8950df09a02561952539cacd623d598620c357e1..7624ec23e0646d88a60dea8d73c1203562ed625a 100644 (file)
@@ -1243,9 +1243,10 @@ int mt7925_mcu_set_eeprom(struct mt792x_dev *dev)
 }
 EXPORT_SYMBOL_GPL(mt7925_mcu_set_eeprom);
 
-int mt7925_mcu_uni_bss_ps(struct mt792x_dev *dev, struct ieee80211_vif *vif)
+int mt7925_mcu_uni_bss_ps(struct mt792x_dev *dev,
+                         struct ieee80211_bss_conf *link_conf)
 {
-       struct mt792x_vif *mvif = (struct mt792x_vif *)vif->drv_priv;
+       struct mt792x_bss_conf *mconf = mt792x_link_conf_to_mconf(link_conf);
        struct {
                struct {
                        u8 bss_idx;
@@ -1264,16 +1265,16 @@ int mt7925_mcu_uni_bss_ps(struct mt792x_dev *dev, struct ieee80211_vif *vif)
                } __packed ps;
        } __packed ps_req = {
                .hdr = {
-                       .bss_idx = mvif->bss_conf.mt76.idx,
+                       .bss_idx = mconf->mt76.idx,
                },
                .ps = {
                        .tag = cpu_to_le16(UNI_BSS_INFO_PS),
                        .len = cpu_to_le16(sizeof(struct ps_tlv)),
-                       .ps_state = vif->cfg.ps ? 2 : 0,
+                       .ps_state = link_conf->vif->cfg.ps ? 2 : 0,
                },
        };
 
-       if (vif->type != NL80211_IFTYPE_STATION)
+       if (link_conf->vif->type != NL80211_IFTYPE_STATION)
                return -EOPNOTSUPP;
 
        return mt76_mcu_send_msg(&dev->mt76, MCU_UNI_CMD(BSS_INFO_UPDATE),
index 8ab2bb01ba733f4a3055a7fe9346eaa3751f411f..ef37951f69d537231627905708a2041bcd3e08c1 100644 (file)
@@ -242,7 +242,8 @@ int mt7925_mcu_uni_rx_ba(struct mt792x_dev *dev,
                         bool enable);
 void mt7925_scan_work(struct work_struct *work);
 void mt7925_roc_work(struct work_struct *work);
-int mt7925_mcu_uni_bss_ps(struct mt792x_dev *dev, struct ieee80211_vif *vif);
+int mt7925_mcu_uni_bss_ps(struct mt792x_dev *dev,
+                         struct ieee80211_bss_conf *link_conf);
 void mt7925_coredump_work(struct work_struct *work);
 int mt7925_get_txpwr_info(struct mt792x_dev *dev, u8 band_idx,
                          struct mt7925_txpwr *txpwr);