From: Felix Fietkau Date: Sat, 10 Dec 2022 12:22:32 +0000 (+0100) Subject: mt76: update to the latest version X-Git-Url: http://git.lede-project.org./?a=commitdiff_plain;h=a75a7981621a14adb3a11d1af66b72320b13c5ef;p=openwrt%2Fstaging%2Fmans0n.git mt76: update to the latest version ec46d7486ab9 sync with upstream 2575de3aea33 wifi: mt76: mt7921: introduce chanctx support 473cebb3c3e1 wifi: mt76: fix bandwidth 80MHz link fail in 6GHz band de3e77227f62 wifi: mt76: mt7996: add driver for MediaTek Wi-Fi 7 (802.11be) devices f0c191a9f6cd wifi: mt76: mt7996: add missing argument in mt7996_queue_rx_skb() d3838a52df62 wifi: mt76: mt7996: enable use_cts_prot support 98492dff3bec wifi: mt76: mt7996: enable ack signal support 2a41e7a82f86 wifi: mt76: mt7996: add support to configure spatial reuse parameter set 194cb3392829 mt76: mt7915: add missing of_node_put() f91d6f3b73ac wifi: mt76: mt7921s: fix slab-out-of-bounds access in sdio host 1ce4970d799f wifi: mt76: mt7915: fix mt7915_rate_txpower_get() resource leaks 379f3fc0fc43 wifi: mt76: mt7996: fix insecure data handling of mt7996_mcu_ie_countdown() 233c272f0f86 wifi: mt76: mt7996: fix insecure data handling of mt7996_mcu_rx_radar_detected() 5616c4cc1d5d wifi: mt76: mt7996: fix integer handling issue of mt7996_rf_regval_set() f9598e6d4c2c wifi: mt76: mt7915: split mcu chan_mib array up b252d94bd763 wifi: mt76: mt7915: check return value before accessing free_block_num f1cc3696d725 wifi: mt76: mt7996: check return value before accessing free_block_num b94ba58fa698 wifi: mt76: mt7915: check the correctness of event data 35843a1670c0 wifi: mt76: mt7915: drop always true condition of __mt7915_reg_addr() 01a256c1dc41 wifi: mt76: mt7996: drop always true condition of __mt7996_reg_addr() 5185bbab8953 wifi: mt76: mt7996: fix endianness warning in mt7996_mcu_sta_he_tlv eeb6949c4d06 wifi: mt76: mt76x0: fix oob access in mt76x0_phy_get_target_power 063823aba978 wifi: mt76: mt7921: add support to update fw capability with MTFG table a44109267e4e wifi: mt76: mt7996: fix unintended sign extension of mt7996_hw_queue_read() be5dbb781068 wifi: mt76: mt7915: fix unintended sign extension of mt7915_hw_queue_read() adf9042b6f63 wifi: mt76: fix coverity uninit_use_in_call in mt76_connac2_reverse_frag0_hdr_trans() 551201379efe wifi: mt76: move leds field in leds struct 14fbb6d6e85e wifi: mt76: move leds struct in mt76_phy 81edc468fc62 wifi: mt76: mt7915: enable per-phy led support bbad827e447f wifi: mt76: mt7615: enable per-phy led support 8e7e7e52fc09 wifi: mt76: dma: do not increment queue head if mt76_dma_add_buf fails 95c66d651133 wifi: mt76: handle possible mt76_rx_token_consume failures 52d04463a66e wifi: mt76: dma: rely on queue page_frag_cache for wed rx queues 7fae1de12ae7 wifi: mt76: mt7921: resource leaks at mt7921_check_offload_capability() Signed-off-by: Felix Fietkau --- diff --git a/package/kernel/mt76/Makefile b/package/kernel/mt76/Makefile index 0125cc4479..cb1f8743bc 100644 --- a/package/kernel/mt76/Makefile +++ b/package/kernel/mt76/Makefile @@ -8,9 +8,9 @@ PKG_LICENSE_FILES:= PKG_SOURCE_URL:=https://github.com/openwrt/mt76 PKG_SOURCE_PROTO:=git -PKG_SOURCE_DATE:=2022-12-01 -PKG_SOURCE_VERSION:=cdd7229e769b65d12284ea9ebcd1cff01d3bf228 -PKG_MIRROR_HASH:=b509fd2757775bffbc6daf41408d54c6c5aeb557774710712b5288315da94a9e +PKG_SOURCE_DATE:=2022-12-09 +PKG_SOURCE_VERSION:=7fae1de12ae7832a6095fd2df198f41fabd5223d +PKG_MIRROR_HASH:=c2bf2f23265d5e181c275a62a64f487b190f19b43fc4c584b62b9e6c16e992ef PKG_MAINTAINER:=Felix Fietkau PKG_USE_NINJA:=0 diff --git a/package/kernel/mt76/patches/100-sync_upstream.patch b/package/kernel/mt76/patches/100-sync_upstream.patch deleted file mode 100644 index ae3c83a85c..0000000000 --- a/package/kernel/mt76/patches/100-sync_upstream.patch +++ /dev/null @@ -1,1608 +0,0 @@ -From ec46d7486ab91786fbfe77edd306911b7c543334 Mon Sep 17 00:00:00 2001 -From: Felix Fietkau -Date: Tue, 11 Oct 2022 17:58:31 +0200 -Subject: [PATCH] sync with upstream - -Signed-off-by: Felix Fietkau ---- - debugfs.c | 28 ++++++++ - dma.c | 2 +- - eeprom.c | 1 - - mac80211.c | 4 +- - mt7603/beacon.c | 2 +- - mt7603/dma.c | 4 +- - mt7603/mac.c | 16 +++-- - mt7603/main.c | 9 +-- - mt7615/dma.c | 4 +- - mt7615/main.c | 7 +- - mt7615/mcu.c | 8 +-- - mt7615/soc.c | 3 +- - mt76_connac_mcu.c | 101 ++++++++++++++-------------- - mt76x02.h | 5 +- - mt76x02_beacon.c | 2 +- - mt76x02_mac.c | 6 +- - mt76x02_mmio.c | 4 +- - mt76x02_util.c | 5 +- - mt76x2/pci.c | 2 +- - mt7915/Kconfig | 1 + - mt7915/debugfs.c | 4 +- - mt7915/dma.c | 4 +- - mt7915/init.c | 3 +- - mt7915/mac.c | 2 +- - mt7915/main.c | 11 +-- - mt7915/mcu.c | 166 +++++++++++++++++++++++----------------------- - mt7915/soc.c | 1 + - mt7921/dma.c | 4 +- - mt7921/init.c | 4 +- - mt7921/mac.c | 2 +- - mt7921/main.c | 18 ++--- - mt7921/mcu.c | 6 +- - mt7921/pci_mac.c | 2 +- - tx.c | 11 ++- - usb.c | 2 +- - 35 files changed, 250 insertions(+), 204 deletions(-) - -diff --git a/debugfs.c b/debugfs.c -index b7aa8727ad1e..11b8153544a0 100644 ---- a/debugfs.c -+++ b/debugfs.c -@@ -25,6 +25,32 @@ mt76_reg_get(void *data, u64 *val) - DEFINE_DEBUGFS_ATTRIBUTE(fops_regval, mt76_reg_get, mt76_reg_set, - "0x%08llx\n"); - -+static int -+mt76_napi_threaded_set(void *data, u64 val) -+{ -+ struct mt76_dev *dev = data; -+ -+ if (!mt76_is_mmio(dev)) -+ return -EOPNOTSUPP; -+ -+ if (dev->napi_dev.threaded != val) -+ return dev_set_threaded(&dev->napi_dev, val); -+ -+ return 0; -+} -+ -+static int -+mt76_napi_threaded_get(void *data, u64 *val) -+{ -+ struct mt76_dev *dev = data; -+ -+ *val = dev->napi_dev.threaded; -+ return 0; -+} -+ -+DEFINE_DEBUGFS_ATTRIBUTE(fops_napi_threaded, mt76_napi_threaded_get, -+ mt76_napi_threaded_set, "%llu\n"); -+ - int mt76_queues_read(struct seq_file *s, void *data) - { - struct mt76_dev *dev = dev_get_drvdata(s->private); -@@ -90,6 +116,8 @@ mt76_register_debugfs_fops(struct mt76_phy *phy, - debugfs_create_bool("led_active_low", 0600, dir, &dev->led_al); - debugfs_create_u32("regidx", 0600, dir, &dev->debugfs_reg); - debugfs_create_file_unsafe("regval", 0600, dir, dev, fops); -+ debugfs_create_file_unsafe("napi_threaded", 0600, dir, dev, -+ &fops_napi_threaded); - debugfs_create_blob("eeprom", 0400, dir, &dev->eeprom); - if (dev->otp.data) - debugfs_create_blob("otp", 0400, dir, &dev->otp); -diff --git a/dma.c b/dma.c -index ae22b9592ead..8dca8d2447b7 100644 ---- a/dma.c -+++ b/dma.c -@@ -895,7 +895,7 @@ mt76_dma_init(struct mt76_dev *dev, - dev->napi_dev.threaded = 1; - - mt76_for_each_q_rx(dev, i) { -- netif_napi_add(&dev->napi_dev, &dev->napi[i], poll, 64); -+ netif_napi_add(&dev->napi_dev, &dev->napi[i], poll); - mt76_dma_rx_fill(dev, &dev->q_rx[i]); - napi_enable(&dev->napi[i]); - } -diff --git a/eeprom.c b/eeprom.c -index 25f677601034..0a88048b8976 100644 ---- a/eeprom.c -+++ b/eeprom.c -@@ -106,7 +106,6 @@ void - mt76_eeprom_override(struct mt76_phy *phy) - { - struct mt76_dev *dev = phy->dev; -- - struct device_node *np = dev->dev->of_node; - - of_get_mac_address(np, phy->macaddr); -diff --git a/mac80211.c b/mac80211.c -index acac04eff0d6..fc608b369b3c 100644 ---- a/mac80211.c -+++ b/mac80211.c -@@ -1482,7 +1482,7 @@ EXPORT_SYMBOL_GPL(mt76_get_sar_power); - static void - __mt76_csa_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { -- if (vif->csa_active && ieee80211_beacon_cntdwn_is_complete(vif)) -+ if (vif->bss_conf.csa_active && ieee80211_beacon_cntdwn_is_complete(vif)) - ieee80211_csa_finish(vif); - } - -@@ -1504,7 +1504,7 @@ __mt76_csa_check(void *priv, u8 *mac, struct ieee80211_vif *vif) - { - struct mt76_dev *dev = priv; - -- if (!vif->csa_active) -+ if (!vif->bss_conf.csa_active) - return; - - dev->csa_complete |= ieee80211_beacon_cntdwn_is_complete(vif); -diff --git a/mt7603/beacon.c b/mt7603/beacon.c -index 5807cf2cf862..b65b0a88c1de 100644 ---- a/mt7603/beacon.c -+++ b/mt7603/beacon.c -@@ -20,7 +20,7 @@ mt7603_update_beacon_iter(void *priv, u8 *mac, struct ieee80211_vif *vif) - if (!(mdev->beacon_mask & BIT(mvif->idx))) - return; - -- skb = ieee80211_beacon_get(mt76_hw(dev), vif); -+ skb = ieee80211_beacon_get(mt76_hw(dev), vif, 0); - if (!skb) - return; - -diff --git a/mt7603/dma.c b/mt7603/dma.c -index 06a9e6ecce60..03ba11a61c90 100644 ---- a/mt7603/dma.c -+++ b/mt7603/dma.c -@@ -223,8 +223,8 @@ int mt7603_dma_init(struct mt7603_dev *dev) - if (ret) - return ret; - -- netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -- mt7603_poll_tx, NAPI_POLL_WEIGHT); -+ netif_napi_add_tx(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -+ mt7603_poll_tx); - napi_enable(&dev->mt76.tx_napi); - - return 0; -diff --git a/mt7603/mac.c b/mt7603/mac.c -index b025e3553006..70a7f84af028 100644 ---- a/mt7603/mac.c -+++ b/mt7603/mac.c -@@ -326,19 +326,21 @@ void mt7603_wtbl_update_cap(struct mt7603_dev *dev, struct ieee80211_sta *sta) - - addr = mt7603_wtbl1_addr(idx); - -- ampdu_density = sta->ht_cap.ampdu_density; -+ ampdu_density = sta->deflink.ht_cap.ampdu_density; - if (ampdu_density < IEEE80211_HT_MPDU_DENSITY_4) - ampdu_density = IEEE80211_HT_MPDU_DENSITY_4; - - val = mt76_rr(dev, addr + 2 * 4); - val &= MT_WTBL1_W2_KEY_TYPE | MT_WTBL1_W2_ADMISSION_CONTROL; -- val |= FIELD_PREP(MT_WTBL1_W2_AMPDU_FACTOR, sta->ht_cap.ampdu_factor) | -- FIELD_PREP(MT_WTBL1_W2_MPDU_DENSITY, sta->ht_cap.ampdu_density) | -+ val |= FIELD_PREP(MT_WTBL1_W2_AMPDU_FACTOR, -+ sta->deflink.ht_cap.ampdu_factor) | -+ FIELD_PREP(MT_WTBL1_W2_MPDU_DENSITY, -+ sta->deflink.ht_cap.ampdu_density) | - MT_WTBL1_W2_TXS_BAF_REPORT; - -- if (sta->ht_cap.cap) -+ if (sta->deflink.ht_cap.cap) - val |= MT_WTBL1_W2_HT; -- if (sta->vht_cap.cap) -+ if (sta->deflink.vht_cap.cap) - val |= MT_WTBL1_W2_VHT; - - mt76_wr(dev, addr + 2 * 4, val); -@@ -347,9 +349,9 @@ void mt7603_wtbl_update_cap(struct mt7603_dev *dev, struct ieee80211_sta *sta) - val = mt76_rr(dev, addr + 9 * 4); - val &= ~(MT_WTBL2_W9_SHORT_GI_20 | MT_WTBL2_W9_SHORT_GI_40 | - MT_WTBL2_W9_SHORT_GI_80); -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_20) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_20) - val |= MT_WTBL2_W9_SHORT_GI_20; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_40) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_40) - val |= MT_WTBL2_W9_SHORT_GI_40; - mt76_wr(dev, addr + 9 * 4, val); - } -diff --git a/mt7603/main.c b/mt7603/main.c -index 91425b454cae..ca50feb0b3a9 100644 ---- a/mt7603/main.c -+++ b/mt7603/main.c -@@ -297,7 +297,7 @@ mt7603_configure_filter(struct ieee80211_hw *hw, unsigned int changed_flags, - - static void - mt7603_bss_info_changed(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -- struct ieee80211_bss_conf *info, u32 changed) -+ struct ieee80211_bss_conf *info, u64 changed) - { - struct mt7603_dev *dev = hw->priv; - struct mt7603_vif *mvif = (struct mt7603_vif *)vif->drv_priv; -@@ -305,7 +305,7 @@ mt7603_bss_info_changed(struct ieee80211_hw *hw, struct ieee80211_vif *vif, - mutex_lock(&dev->mt76.mutex); - - if (changed & (BSS_CHANGED_ASSOC | BSS_CHANGED_BSSID)) { -- if (info->assoc || info->ibss_joined) { -+ if (vif->cfg.assoc || vif->cfg.ibss_joined) { - mt76_wr(dev, MT_BSSID0(mvif->idx), - get_unaligned_le32(info->bssid)); - mt76_wr(dev, MT_BSSID1(mvif->idx), -@@ -527,7 +527,8 @@ mt7603_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, - } - - static int --mt7603_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u16 queue, -+mt7603_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ unsigned int link_id, u16 queue, - const struct ieee80211_tx_queue_params *params) - { - struct mt7603_dev *dev = hw->priv; -@@ -657,7 +658,7 @@ mt7603_sta_rate_tbl_update(struct ieee80211_hw *hw, struct ieee80211_vif *vif, - mt7603_wtbl_set_rates(dev, msta, NULL, msta->rates); - msta->rate_probe = false; - mt7603_wtbl_set_smps(dev, msta, -- sta->smps_mode == IEEE80211_SMPS_DYNAMIC); -+ sta->deflink.smps_mode == IEEE80211_SMPS_DYNAMIC); - spin_unlock_bh(&dev->mt76.lock); - } - -diff --git a/mt7615/dma.c b/mt7615/dma.c -index ec729dbe1cd8..f1914431ff7f 100644 ---- a/mt7615/dma.c -+++ b/mt7615/dma.c -@@ -281,8 +281,8 @@ int mt7615_dma_init(struct mt7615_dev *dev) - if (ret < 0) - return ret; - -- netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -- mt7615_poll_tx, NAPI_POLL_WEIGHT); -+ netif_napi_add_tx(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -+ mt7615_poll_tx); - napi_enable(&dev->mt76.tx_napi); - - mt76_poll(dev, MT_WPDMA_GLO_CFG, -diff --git a/mt7615/main.c b/mt7615/main.c -index 0d80003c6f17..ab4c1b4478aa 100644 ---- a/mt7615/main.c -+++ b/mt7615/main.c -@@ -473,7 +473,8 @@ static int mt7615_config(struct ieee80211_hw *hw, u32 changed) - } - - static int --mt7615_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u16 queue, -+mt7615_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ unsigned int link_id, u16 queue, - const struct ieee80211_tx_queue_params *params) - { - struct mt76_vif *mvif = (struct mt76_vif *)vif->drv_priv; -@@ -555,7 +556,7 @@ static void mt7615_configure_filter(struct ieee80211_hw *hw, - static void mt7615_bss_info_changed(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, - struct ieee80211_bss_conf *info, -- u32 changed) -+ u64 changed) - { - struct mt7615_dev *dev = mt7615_hw_dev(hw); - struct mt7615_phy *phy = mt7615_hw_phy(hw); -@@ -598,7 +599,7 @@ static void mt7615_bss_info_changed(struct ieee80211_hw *hw, - } - - if (changed & BSS_CHANGED_ASSOC) -- mt7615_mac_set_beacon_filter(phy, vif, info->assoc); -+ mt7615_mac_set_beacon_filter(phy, vif, vif->cfg.assoc); - - mt7615_mutex_release(dev); - } -diff --git a/mt7615/mcu.c b/mt7615/mcu.c -index 81579a1422d4..83f30305414d 100644 ---- a/mt7615/mcu.c -+++ b/mt7615/mcu.c -@@ -352,7 +352,7 @@ out: - static void - mt7615_mcu_csa_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { -- if (vif->csa_active) -+ if (vif->bss_conf.csa_active) - ieee80211_csa_finish(vif); - } - -@@ -698,7 +698,7 @@ mt7615_mcu_add_beacon_offload(struct mt7615_dev *dev, - if (!enable) - goto out; - -- skb = ieee80211_beacon_get_template(hw, vif, &offs); -+ skb = ieee80211_beacon_get_template(hw, vif, &offs, 0); - if (!skb) - return -EINVAL; - -@@ -1073,7 +1073,7 @@ mt7615_mcu_uni_add_beacon_offload(struct mt7615_dev *dev, - if (!enable) - goto out; - -- skb = ieee80211_beacon_get_template(mt76_hw(dev), vif, &offs); -+ skb = ieee80211_beacon_get_template(mt76_hw(dev), vif, &offs, 0); - if (!skb) - return -EINVAL; - -@@ -2525,7 +2525,7 @@ int mt7615_mcu_set_bss_pm(struct mt7615_dev *dev, struct ieee80211_vif *vif, - u8 pad; - } req = { - .bss_idx = mvif->mt76.idx, -- .aid = cpu_to_le16(vif->bss_conf.aid), -+ .aid = cpu_to_le16(vif->cfg.aid), - .dtim_period = vif->bss_conf.dtim_period, - .bcn_interval = cpu_to_le16(vif->bss_conf.beacon_int), - }; -diff --git a/mt7615/soc.c b/mt7615/soc.c -index be9a69fe1b38..f13d1b418742 100644 ---- a/mt7615/soc.c -+++ b/mt7615/soc.c -@@ -31,7 +31,6 @@ int mt7622_wmac_init(struct mt7615_dev *dev) - - static int mt7622_wmac_probe(struct platform_device *pdev) - { -- struct resource *res = platform_get_resource(pdev, IORESOURCE_MEM, 0); - void __iomem *mem_base; - int irq; - -@@ -39,7 +38,7 @@ static int mt7622_wmac_probe(struct platform_device *pdev) - if (irq < 0) - return irq; - -- mem_base = devm_ioremap_resource(&pdev->dev, res); -+ mem_base = devm_platform_get_and_ioremap_resource(pdev, 0, NULL); - if (IS_ERR(mem_base)) - return PTR_ERR(mem_base); - -diff --git a/mt76_connac_mcu.c b/mt76_connac_mcu.c -index 673fca296b89..83c59d2de692 100644 ---- a/mt76_connac_mcu.c -+++ b/mt76_connac_mcu.c -@@ -196,7 +196,7 @@ int mt76_connac_mcu_set_vif_ps(struct mt76_dev *dev, struct ieee80211_vif *vif) - */ - } req = { - .bss_idx = mvif->idx, -- .ps_state = vif->bss_conf.ps ? 2 : 0, -+ .ps_state = vif->cfg.ps ? 2 : 0, - }; - - if (vif->type != NL80211_IFTYPE_STATION) -@@ -407,7 +407,7 @@ void mt76_connac_mcu_sta_basic_tlv(struct sk_buff *skb, - else - conn_type = CONNECTION_INFRA_AP; - basic->conn_type = cpu_to_le32(conn_type); -- basic->aid = cpu_to_le16(vif->bss_conf.aid); -+ basic->aid = cpu_to_le16(vif->cfg.aid); - break; - case NL80211_IFTYPE_ADHOC: - basic->conn_type = cpu_to_le32(CONNECTION_IBSS_ADHOC); -@@ -551,7 +551,7 @@ void mt76_connac_mcu_wtbl_generic_tlv(struct mt76_dev *dev, - - if (sta) { - if (vif->type == NL80211_IFTYPE_STATION) -- generic->partial_aid = cpu_to_le16(vif->bss_conf.aid); -+ generic->partial_aid = cpu_to_le16(vif->cfg.aid); - else - generic->partial_aid = cpu_to_le16(sta->aid); - memcpy(generic->peer_addr, sta->addr, ETH_ALEN); -@@ -597,14 +597,14 @@ mt76_connac_mcu_sta_amsdu_tlv(struct sk_buff *skb, struct ieee80211_sta *sta, - vif->type != NL80211_IFTYPE_STATION) - return; - -- if (!sta->max_amsdu_len) -+ if (!sta->deflink.agg.max_amsdu_len) - return; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HW_AMSDU, sizeof(*amsdu)); - amsdu = (struct sta_rec_amsdu *)tlv; - amsdu->max_amsdu_num = 8; - amsdu->amsdu_en = true; -- amsdu->max_mpdu_size = sta->max_amsdu_len >= -+ amsdu->max_mpdu_size = sta->deflink.agg.max_amsdu_len >= - IEEE80211_MAX_MPDU_LEN_VHT_7991; - - wcid->amsdu = true; -@@ -615,7 +615,7 @@ mt76_connac_mcu_sta_amsdu_tlv(struct sk_buff *skb, struct ieee80211_sta *sta, - static void - mt76_connac_mcu_sta_he_tlv(struct sk_buff *skb, struct ieee80211_sta *sta) - { -- struct ieee80211_sta_he_cap *he_cap = &sta->he_cap; -+ struct ieee80211_sta_he_cap *he_cap = &sta->deflink.he_cap; - struct ieee80211_he_cap_elem *elem = &he_cap->he_cap_elem; - struct sta_rec_he *he; - struct tlv *tlv; -@@ -703,7 +703,7 @@ mt76_connac_mcu_sta_he_tlv(struct sk_buff *skb, struct ieee80211_sta *sta) - - he->he_cap = cpu_to_le32(cap); - -- switch (sta->bandwidth) { -+ switch (sta->deflink.bandwidth) { - case IEEE80211_STA_RX_BW_160: - if (elem->phy_cap_info[0] & - IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G) -@@ -755,9 +755,9 @@ mt76_connac_get_phy_mode_v2(struct mt76_phy *mphy, struct ieee80211_vif *vif, - u8 mode = 0; - - if (sta) { -- ht_cap = &sta->ht_cap; -- vht_cap = &sta->vht_cap; -- he_cap = &sta->he_cap; -+ ht_cap = &sta->deflink.ht_cap; -+ vht_cap = &sta->deflink.vht_cap; -+ he_cap = &sta->deflink.he_cap; - } else { - struct ieee80211_supported_band *sband; - -@@ -806,25 +806,25 @@ void mt76_connac_mcu_sta_tlv(struct mt76_phy *mphy, struct sk_buff *skb, - u16 supp_rates; - - /* starec ht */ -- if (sta->ht_cap.ht_supported) { -+ if (sta->deflink.ht_cap.ht_supported) { - struct sta_rec_ht *ht; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HT, sizeof(*ht)); - ht = (struct sta_rec_ht *)tlv; -- ht->ht_cap = cpu_to_le16(sta->ht_cap.cap); -+ ht->ht_cap = cpu_to_le16(sta->deflink.ht_cap.cap); - } - - /* starec vht */ -- if (sta->vht_cap.vht_supported) { -+ if (sta->deflink.vht_cap.vht_supported) { - struct sta_rec_vht *vht; - int len; - - len = is_mt7921(dev) ? sizeof(*vht) : sizeof(*vht) - 4; - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_VHT, len); - vht = (struct sta_rec_vht *)tlv; -- vht->vht_cap = cpu_to_le32(sta->vht_cap.cap); -- vht->vht_rx_mcs_map = sta->vht_cap.vht_mcs.rx_mcs_map; -- vht->vht_tx_mcs_map = sta->vht_cap.vht_mcs.tx_mcs_map; -+ vht->vht_cap = cpu_to_le32(sta->deflink.vht_cap.cap); -+ vht->vht_rx_mcs_map = sta->deflink.vht_cap.vht_mcs.rx_mcs_map; -+ vht->vht_tx_mcs_map = sta->deflink.vht_cap.vht_mcs.tx_mcs_map; - } - - /* starec uapsd */ -@@ -833,11 +833,11 @@ void mt76_connac_mcu_sta_tlv(struct mt76_phy *mphy, struct sk_buff *skb, - if (!is_mt7921(dev)) - return; - -- if (sta->ht_cap.ht_supported || sta->he_cap.has_he) -+ if (sta->deflink.ht_cap.ht_supported || sta->deflink.he_cap.has_he) - mt76_connac_mcu_sta_amsdu_tlv(skb, sta, vif); - - /* starec he */ -- if (sta->he_cap.has_he) { -+ if (sta->deflink.he_cap.has_he) { - mt76_connac_mcu_sta_he_tlv(skb, sta); - if (band == NL80211_BAND_6GHZ && - sta_state == MT76_STA_INFO_STATE_ASSOC) { -@@ -846,7 +846,7 @@ void mt76_connac_mcu_sta_tlv(struct mt76_phy *mphy, struct sk_buff *skb, - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HE_6G, - sizeof(*he_6g_capa)); - he_6g_capa = (struct sta_rec_he_6g_capa *)tlv; -- he_6g_capa->capa = sta->he_6ghz_capa.capa; -+ he_6g_capa->capa = sta->deflink.he_6ghz_capa.capa; - } - } - -@@ -856,14 +856,14 @@ void mt76_connac_mcu_sta_tlv(struct mt76_phy *mphy, struct sk_buff *skb, - phy->basic_rate = cpu_to_le16((u16)vif->bss_conf.basic_rates); - phy->rcpi = rcpi; - phy->ampdu = FIELD_PREP(IEEE80211_HT_AMPDU_PARM_FACTOR, -- sta->ht_cap.ampdu_factor) | -+ sta->deflink.ht_cap.ampdu_factor) | - FIELD_PREP(IEEE80211_HT_AMPDU_PARM_DENSITY, -- sta->ht_cap.ampdu_density); -+ sta->deflink.ht_cap.ampdu_density); - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_RA, sizeof(*ra_info)); - ra_info = (struct sta_rec_ra_info *)tlv; - -- supp_rates = sta->supp_rates[band]; -+ supp_rates = sta->deflink.supp_rates[band]; - if (band == NL80211_BAND_2GHZ) - supp_rates = FIELD_PREP(RA_LEGACY_OFDM, supp_rates >> 4) | - FIELD_PREP(RA_LEGACY_CCK, supp_rates & 0xf); -@@ -872,17 +872,18 @@ void mt76_connac_mcu_sta_tlv(struct mt76_phy *mphy, struct sk_buff *skb, - - ra_info->legacy = cpu_to_le16(supp_rates); - -- if (sta->ht_cap.ht_supported) -- memcpy(ra_info->rx_mcs_bitmask, sta->ht_cap.mcs.rx_mask, -+ if (sta->deflink.ht_cap.ht_supported) -+ memcpy(ra_info->rx_mcs_bitmask, -+ sta->deflink.ht_cap.mcs.rx_mask, - HT_MCS_MASK_NUM); - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_STATE, sizeof(*state)); - state = (struct sta_rec_state *)tlv; - state->state = sta_state; - -- if (sta->vht_cap.vht_supported) { -- state->vht_opmode = sta->bandwidth; -- state->vht_opmode |= (sta->rx_nss - 1) << -+ if (sta->deflink.vht_cap.vht_supported) { -+ state->vht_opmode = sta->deflink.bandwidth; -+ state->vht_opmode |= (sta->deflink.rx_nss - 1) << - IEEE80211_OPMODE_NOTIF_RX_NSS_SHIFT; - } - } -@@ -898,7 +899,7 @@ void mt76_connac_mcu_wtbl_smps_tlv(struct sk_buff *skb, - tlv = mt76_connac_mcu_add_nested_tlv(skb, WTBL_SMPS, sizeof(*smps), - wtbl_tlv, sta_wtbl); - smps = (struct wtbl_smps *)tlv; -- smps->smps = (sta->smps_mode == IEEE80211_SMPS_DYNAMIC); -+ smps->smps = (sta->deflink.smps_mode == IEEE80211_SMPS_DYNAMIC); - } - EXPORT_SYMBOL_GPL(mt76_connac_mcu_wtbl_smps_tlv); - -@@ -910,27 +911,27 @@ void mt76_connac_mcu_wtbl_ht_tlv(struct mt76_dev *dev, struct sk_buff *skb, - struct tlv *tlv; - u32 flags = 0; - -- if (sta->ht_cap.ht_supported || sta->he_6ghz_capa.capa) { -+ if (sta->deflink.ht_cap.ht_supported || sta->deflink.he_6ghz_capa.capa) { - tlv = mt76_connac_mcu_add_nested_tlv(skb, WTBL_HT, sizeof(*ht), - wtbl_tlv, sta_wtbl); - ht = (struct wtbl_ht *)tlv; - ht->ldpc = ht_ldpc && -- !!(sta->ht_cap.cap & IEEE80211_HT_CAP_LDPC_CODING); -+ !!(sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_LDPC_CODING); - -- if (sta->ht_cap.ht_supported) { -- ht->af = sta->ht_cap.ampdu_factor; -- ht->mm = sta->ht_cap.ampdu_density; -+ if (sta->deflink.ht_cap.ht_supported) { -+ ht->af = sta->deflink.ht_cap.ampdu_factor; -+ ht->mm = sta->deflink.ht_cap.ampdu_density; - } else { -- ht->af = le16_get_bits(sta->he_6ghz_capa.capa, -+ ht->af = le16_get_bits(sta->deflink.he_6ghz_capa.capa, - IEEE80211_HE_6GHZ_CAP_MAX_AMPDU_LEN_EXP); -- ht->mm = le16_get_bits(sta->he_6ghz_capa.capa, -+ ht->mm = le16_get_bits(sta->deflink.he_6ghz_capa.capa, - IEEE80211_HE_6GHZ_CAP_MIN_MPDU_START); - } - - ht->ht = true; - } - -- if (sta->vht_cap.vht_supported || sta->he_6ghz_capa.capa) { -+ if (sta->deflink.vht_cap.vht_supported || sta->deflink.he_6ghz_capa.capa) { - struct wtbl_vht *vht; - u8 af; - -@@ -939,18 +940,18 @@ void mt76_connac_mcu_wtbl_ht_tlv(struct mt76_dev *dev, struct sk_buff *skb, - sta_wtbl); - vht = (struct wtbl_vht *)tlv; - vht->ldpc = vht_ldpc && -- !!(sta->vht_cap.cap & IEEE80211_VHT_CAP_RXLDPC); -+ !!(sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_RXLDPC); - vht->vht = true; - - af = FIELD_GET(IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK, -- sta->vht_cap.cap); -+ sta->deflink.vht_cap.cap); - if (ht) - ht->af = max(ht->af, af); - } - - mt76_connac_mcu_wtbl_smps_tlv(skb, sta, sta_wtbl, wtbl_tlv); - -- if (is_connac_v1(dev) && sta->ht_cap.ht_supported) { -+ if (is_connac_v1(dev) && sta->deflink.ht_cap.ht_supported) { - /* sgi */ - u32 msk = MT_WTBL_W5_SHORT_GI_20 | MT_WTBL_W5_SHORT_GI_40 | - MT_WTBL_W5_SHORT_GI_80 | MT_WTBL_W5_SHORT_GI_160; -@@ -960,15 +961,15 @@ void mt76_connac_mcu_wtbl_ht_tlv(struct mt76_dev *dev, struct sk_buff *skb, - sizeof(*raw), wtbl_tlv, - sta_wtbl); - -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_20) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_20) - flags |= MT_WTBL_W5_SHORT_GI_20; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_40) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_40) - flags |= MT_WTBL_W5_SHORT_GI_40; - -- if (sta->vht_cap.vht_supported) { -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_80) -+ if (sta->deflink.vht_cap.vht_supported) { -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_80) - flags |= MT_WTBL_W5_SHORT_GI_80; -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_160) -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_160) - flags |= MT_WTBL_W5_SHORT_GI_160; - } - raw = (struct wtbl_raw *)tlv; -@@ -1254,9 +1255,9 @@ u8 mt76_connac_get_phy_mode(struct mt76_phy *phy, struct ieee80211_vif *vif, - return 0x38; - - if (sta) { -- ht_cap = &sta->ht_cap; -- vht_cap = &sta->vht_cap; -- he_cap = &sta->he_cap; -+ ht_cap = &sta->deflink.ht_cap; -+ vht_cap = &sta->deflink.vht_cap; -+ he_cap = &sta->deflink.he_cap; - } else { - struct ieee80211_supported_band *sband; - -@@ -2196,8 +2197,10 @@ int mt76_connac_mcu_update_arp_filter(struct mt76_dev *dev, - struct mt76_vif *vif, - struct ieee80211_bss_conf *info) - { -+ struct ieee80211_vif *mvif = container_of(info, struct ieee80211_vif, -+ bss_conf); - struct sk_buff *skb; -- int i, len = min_t(int, info->arp_addr_cnt, -+ int i, len = min_t(int, mvif->cfg.arp_addr_cnt, - IEEE80211_BSS_ARP_ADDR_LIST_LEN); - struct { - struct { -@@ -2225,7 +2228,7 @@ int mt76_connac_mcu_update_arp_filter(struct mt76_dev *dev, - - skb_put_data(skb, &req_hdr, sizeof(req_hdr)); - for (i = 0; i < len; i++) -- skb_put_data(skb, &info->arp_addr_list[i], sizeof(__be32)); -+ skb_put_data(skb, &mvif->cfg.arp_addr_list[i], sizeof(__be32)); - - return mt76_mcu_skb_send_msg(dev, skb, MCU_UNI_CMD(OFFLOAD), true); - } -diff --git a/mt76x02.h b/mt76x02.h -index 3f2a9b7fa070..4cd63bacd742 100644 ---- a/mt76x02.h -+++ b/mt76x02.h -@@ -170,7 +170,8 @@ int mt76x02_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, - struct ieee80211_vif *vif, struct ieee80211_sta *sta, - struct ieee80211_key_conf *key); - int mt76x02_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -- u16 queue, const struct ieee80211_tx_queue_params *params); -+ unsigned int link_id, u16 queue, -+ const struct ieee80211_tx_queue_params *params); - void mt76x02_sta_rate_tbl_update(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, - struct ieee80211_sta *sta); -@@ -201,7 +202,7 @@ void mt76x02_sw_scan_complete(struct ieee80211_hw *hw, - void mt76x02_sta_ps(struct mt76_dev *dev, struct ieee80211_sta *sta, bool ps); - void mt76x02_bss_info_changed(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, -- struct ieee80211_bss_conf *info, u32 changed); -+ struct ieee80211_bss_conf *info, u64 changed); - void mt76x02_reconfig_complete(struct ieee80211_hw *hw, - enum ieee80211_reconfig_type reconfig_type); - -diff --git a/mt76x02_beacon.c b/mt76x02_beacon.c -index 67844e2ed3f8..ad4dc8e17b58 100644 ---- a/mt76x02_beacon.c -+++ b/mt76x02_beacon.c -@@ -143,7 +143,7 @@ mt76x02_update_beacon_iter(void *priv, u8 *mac, struct ieee80211_vif *vif) - if (!(dev->mt76.beacon_mask & BIT(mvif->idx))) - return; - -- skb = ieee80211_beacon_get(mt76_hw(dev), vif); -+ skb = ieee80211_beacon_get(mt76_hw(dev), vif, 0); - if (!skb) - return; - -diff --git a/mt76x02_mac.c b/mt76x02_mac.c -index 87ea3db140d9..d3f74473e6fb 100644 ---- a/mt76x02_mac.c -+++ b/mt76x02_mac.c -@@ -404,7 +404,7 @@ void mt76x02_mac_write_txwi(struct mt76x02_dev *dev, struct mt76x02_txwi *txwi, - txwi->rate |= cpu_to_le16(MT_RXWI_RATE_LDPC); - if ((info->flags & IEEE80211_TX_CTL_STBC) && nss == 1) - txwi->rate |= cpu_to_le16(MT_RXWI_RATE_STBC); -- if (nss > 1 && sta && sta->smps_mode == IEEE80211_SMPS_DYNAMIC) -+ if (nss > 1 && sta && sta->deflink.smps_mode == IEEE80211_SMPS_DYNAMIC) - txwi_flags |= MT_TXWI_FLAGS_MMPS; - if (!(info->flags & IEEE80211_TX_CTL_NO_ACK)) - txwi->ack_ctl |= MT_TXWI_ACK_CTL_REQ; -@@ -412,9 +412,9 @@ void mt76x02_mac_write_txwi(struct mt76x02_dev *dev, struct mt76x02_txwi *txwi, - txwi->ack_ctl |= MT_TXWI_ACK_CTL_NSEQ; - if ((info->flags & IEEE80211_TX_CTL_AMPDU) && sta) { - u8 ba_size = IEEE80211_MIN_AMPDU_BUF; -- u8 ampdu_density = sta->ht_cap.ampdu_density; -+ u8 ampdu_density = sta->deflink.ht_cap.ampdu_density; - -- ba_size <<= sta->ht_cap.ampdu_factor; -+ ba_size <<= sta->deflink.ht_cap.ampdu_factor; - ba_size = min_t(int, 63, ba_size - 1); - if (info->flags & IEEE80211_TX_CTL_RATE_CTRL_PROBE) - ba_size = 0; -diff --git a/mt76x02_mmio.c b/mt76x02_mmio.c -index 648f4ab9d684..e9c5e85ec07c 100644 ---- a/mt76x02_mmio.c -+++ b/mt76x02_mmio.c -@@ -231,8 +231,8 @@ int mt76x02_dma_init(struct mt76x02_dev *dev) - if (ret) - return ret; - -- netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -- mt76x02_poll_tx, NAPI_POLL_WEIGHT); -+ netif_napi_add_tx(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -+ mt76x02_poll_tx); - napi_enable(&dev->mt76.tx_napi); - - return 0; -diff --git a/mt76x02_util.c b/mt76x02_util.c -index 5bd0a0bae688..604ddcc21123 100644 ---- a/mt76x02_util.c -+++ b/mt76x02_util.c -@@ -487,7 +487,8 @@ int mt76x02_set_key(struct ieee80211_hw *hw, enum set_key_cmd cmd, - EXPORT_SYMBOL_GPL(mt76x02_set_key); - - int mt76x02_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -- u16 queue, const struct ieee80211_tx_queue_params *params) -+ unsigned int link_id, u16 queue, -+ const struct ieee80211_tx_queue_params *params) - { - struct mt76x02_dev *dev = hw->priv; - u8 cw_min = 5, cw_max = 10, qid; -@@ -636,7 +637,7 @@ EXPORT_SYMBOL_GPL(mt76x02_sta_ps); - void mt76x02_bss_info_changed(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, - struct ieee80211_bss_conf *info, -- u32 changed) -+ u64 changed) - { - struct mt76x02_vif *mvif = (struct mt76x02_vif *)vif->drv_priv; - struct mt76x02_dev *dev = hw->priv; -diff --git a/mt76x2/pci.c b/mt76x2/pci.c -index 8a22ee581674..df85ebc6e1df 100644 ---- a/mt76x2/pci.c -+++ b/mt76x2/pci.c -@@ -80,7 +80,7 @@ mt76x2e_probe(struct pci_dev *pdev, const struct pci_device_id *id) - mt76_rmw_field(dev, 0x15a10, 0x1f << 16, 0x9); - - /* RG_SSUSB_G1_CDR_BIC_LTR = 0xf */ -- mt76_rmw_field(dev, 0x15a0c, 0xf << 28, 0xf); -+ mt76_rmw_field(dev, 0x15a0c, 0xfU << 28, 0xf); - - /* RG_SSUSB_CDR_BR_PE1D = 0x3 */ - mt76_rmw_field(dev, 0x15c58, 0x3 << 6, 0x3); -diff --git a/mt7915/Kconfig b/mt7915/Kconfig -index 320012543634..d710726d47bf 100644 ---- a/mt7915/Kconfig -+++ b/mt7915/Kconfig -@@ -5,6 +5,7 @@ config MT7915E - select WANT_DEV_COREDUMP - depends on MAC80211 - depends on PCI -+ select RELAY - help - This adds support for MT7915-based wireless PCIe devices, - which support concurrent dual-band operation at both 5GHz -diff --git a/mt7915/debugfs.c b/mt7915/debugfs.c -index e7c61378d1f0..fb46c2c1784f 100644 ---- a/mt7915/debugfs.c -+++ b/mt7915/debugfs.c -@@ -1362,8 +1362,8 @@ static ssize_t mt7915_sta_fixed_rate_set(struct file *file, - - phy.ldpc = (phy.bw || phy.ldpc) * GENMASK(2, 0); - for (i = 0; i <= phy.bw; i++) { -- phy.sgi |= gi << (i << sta->he_cap.has_he); -- phy.he_ltf |= he_ltf << (i << sta->he_cap.has_he); -+ phy.sgi |= gi << (i << sta->deflink.he_cap.has_he); -+ phy.he_ltf |= he_ltf << (i << sta->deflink.he_cap.has_he); - } - field = RATE_PARAM_FIXED; - -diff --git a/mt7915/dma.c b/mt7915/dma.c -index 0ca68d4a999a..e3fa064918bf 100644 ---- a/mt7915/dma.c -+++ b/mt7915/dma.c -@@ -550,8 +550,8 @@ int mt7915_dma_init(struct mt7915_dev *dev, struct mt7915_phy *phy2) - if (ret < 0) - return ret; - -- netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -- mt7915_poll_tx, NAPI_POLL_WEIGHT); -+ netif_napi_add_tx(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -+ mt7915_poll_tx); - napi_enable(&dev->mt76.tx_napi); - - mt7915_dma_enable(dev); -diff --git a/mt7915/init.c b/mt7915/init.c -index dfc3f53b1676..b97eb2cc8e8f 100644 ---- a/mt7915/init.c -+++ b/mt7915/init.c -@@ -1022,7 +1022,8 @@ mt7915_init_he_caps(struct mt7915_phy *phy, enum nl80211_band band, - mt7915_gen_ppe_thresh(he_cap->ppe_thres, nss); - } else { - he_cap_elem->phy_cap_info[9] |= -- IEEE80211_HE_PHY_CAP9_NOMIMAL_PKT_PADDING_16US; -+ u8_encode_bits(IEEE80211_HE_PHY_CAP9_NOMINAL_PKT_PADDING_16US, -+ IEEE80211_HE_PHY_CAP9_NOMINAL_PKT_PADDING_MASK); - } - - if (band == NL80211_BAND_6GHZ) { -diff --git a/mt7915/mac.c b/mt7915/mac.c -index b477e9d9fe03..f0d5a3603902 100644 ---- a/mt7915/mac.c -+++ b/mt7915/mac.c -@@ -853,7 +853,7 @@ mt7915_tx_check_aggr(struct ieee80211_sta *sta, __le32 *txwi) - u16 fc, tid; - u32 val; - -- if (!sta || !(sta->ht_cap.ht_supported || sta->he_cap.has_he)) -+ if (!sta || !(sta->deflink.ht_cap.ht_supported || sta->deflink.he_cap.has_he)) - return; - - tid = le32_get_bits(txwi[1], MT_TXD1_TID); -diff --git a/mt7915/main.c b/mt7915/main.c -index 076688d8e7f0..0511d6a505b0 100644 ---- a/mt7915/main.c -+++ b/mt7915/main.c -@@ -490,7 +490,8 @@ static int mt7915_config(struct ieee80211_hw *hw, u32 changed) - } - - static int --mt7915_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u16 queue, -+mt7915_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ unsigned int link_id, u16 queue, - const struct ieee80211_tx_queue_params *params) - { - struct mt7915_vif *mvif = (struct mt7915_vif *)vif->drv_priv; -@@ -585,7 +586,7 @@ mt7915_update_bss_color(struct ieee80211_hw *hw, - static void mt7915_bss_info_changed(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, - struct ieee80211_bss_conf *info, -- u32 changed) -+ u64 changed) - { - struct mt7915_phy *phy = mt7915_hw_phy(hw); - struct mt7915_dev *dev = mt7915_hw_dev(hw); -@@ -605,7 +606,7 @@ static void mt7915_bss_info_changed(struct ieee80211_hw *hw, - } - - if (changed & BSS_CHANGED_ASSOC) -- mt7915_mcu_add_bss_info(phy, vif, info->assoc); -+ mt7915_mcu_add_bss_info(phy, vif, vif->cfg.assoc); - - if (changed & BSS_CHANGED_ERP_CTS_PROT) - mt7915_mac_enable_rtscts(dev, vif, info->use_cts_prot); -@@ -1145,10 +1146,10 @@ static int mt7915_sta_set_txpwr(struct ieee80211_hw *hw, - { - struct mt7915_phy *phy = mt7915_hw_phy(hw); - struct mt7915_dev *dev = mt7915_hw_dev(hw); -- s16 txpower = sta->txpwr.power; -+ s16 txpower = sta->deflink.txpwr.power; - int ret; - -- if (sta->txpwr.type == NL80211_TX_POWER_AUTOMATIC) -+ if (sta->deflink.txpwr.type == NL80211_TX_POWER_AUTOMATIC) - txpower = 0; - - mutex_lock(&dev->mt76.mutex); -diff --git a/mt7915/mcu.c b/mt7915/mcu.c -index b787fa0cd307..d7d84b0f863f 100644 ---- a/mt7915/mcu.c -+++ b/mt7915/mcu.c -@@ -59,7 +59,7 @@ mt7915_mcu_set_sta_he_mcs(struct ieee80211_sta *sta, __le16 *he_mcs, - struct mt7915_dev *dev = msta->vif->phy->dev; - enum nl80211_band band = msta->vif->phy->mt76->chandef.chan->band; - const u16 *mask = msta->vif->bitrate_mask.control[band].he_mcs; -- int nss, max_nss = sta->rx_nss > 3 ? 4 : sta->rx_nss; -+ int nss, max_nss = sta->deflink.rx_nss > 3 ? 4 : sta->deflink.rx_nss; - - for (nss = 0; nss < max_nss; nss++) { - int mcs; -@@ -99,7 +99,7 @@ mt7915_mcu_set_sta_he_mcs(struct ieee80211_sta *sta, __le16 *he_mcs, - - /* only support 2ss on 160MHz for mt7915 */ - if (is_mt7915(&dev->mt76) && nss > 1 && -- sta->bandwidth == IEEE80211_STA_RX_BW_160) -+ sta->deflink.bandwidth == IEEE80211_STA_RX_BW_160) - break; - } - -@@ -112,8 +112,8 @@ mt7915_mcu_set_sta_vht_mcs(struct ieee80211_sta *sta, __le16 *vht_mcs, - { - struct mt7915_sta *msta = (struct mt7915_sta *)sta->drv_priv; - struct mt7915_dev *dev = msta->vif->phy->dev; -- u16 mcs_map = le16_to_cpu(sta->vht_cap.vht_mcs.rx_mcs_map); -- int nss, max_nss = sta->rx_nss > 3 ? 4 : sta->rx_nss; -+ u16 mcs_map = le16_to_cpu(sta->deflink.vht_cap.vht_mcs.rx_mcs_map); -+ int nss, max_nss = sta->deflink.rx_nss > 3 ? 4 : sta->deflink.rx_nss; - u16 mcs; - - for (nss = 0; nss < max_nss; nss++, mcs_map >>= 2) { -@@ -135,7 +135,7 @@ mt7915_mcu_set_sta_vht_mcs(struct ieee80211_sta *sta, __le16 *vht_mcs, - - /* only support 2ss on 160MHz for mt7915 */ - if (is_mt7915(&dev->mt76) && nss > 1 && -- sta->bandwidth == IEEE80211_STA_RX_BW_160) -+ sta->deflink.bandwidth == IEEE80211_STA_RX_BW_160) - break; - } - } -@@ -144,10 +144,10 @@ static void - mt7915_mcu_set_sta_ht_mcs(struct ieee80211_sta *sta, u8 *ht_mcs, - const u8 *mask) - { -- int nss, max_nss = sta->rx_nss > 3 ? 4 : sta->rx_nss; -+ int nss, max_nss = sta->deflink.rx_nss > 3 ? 4 : sta->deflink.rx_nss; - - for (nss = 0; nss < max_nss; nss++) -- ht_mcs[nss] = sta->ht_cap.mcs.rx_mask[nss] & mask[nss]; -+ ht_mcs[nss] = sta->deflink.ht_cap.mcs.rx_mask[nss] & mask[nss]; - } - - static int -@@ -220,7 +220,7 @@ int mt7915_mcu_wa_cmd(struct mt7915_dev *dev, int cmd, u32 a1, u32 a2, u32 a3) - static void - mt7915_mcu_csa_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { -- if (vif->csa_active) -+ if (vif->bss_conf.csa_active) - ieee80211_csa_finish(vif); - } - -@@ -312,7 +312,7 @@ mt7915_mcu_rx_log_message(struct mt7915_dev *dev, struct sk_buff *skb) - static void - mt7915_mcu_cca_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { -- if (!vif->color_change_active) -+ if (!vif->bss_conf.color_change_active) - return; - - ieee80211_color_change_finish(vif); -@@ -694,13 +694,13 @@ mt7915_mcu_sta_he_tlv(struct sk_buff *skb, struct ieee80211_sta *sta, - struct ieee80211_vif *vif) - { - struct mt7915_vif *mvif = (struct mt7915_vif *)vif->drv_priv; -- struct ieee80211_he_cap_elem *elem = &sta->he_cap.he_cap_elem; -+ struct ieee80211_he_cap_elem *elem = &sta->deflink.he_cap.he_cap_elem; - struct ieee80211_he_mcs_nss_supp mcs_map; - struct sta_rec_he *he; - struct tlv *tlv; - u32 cap = 0; - -- if (!sta->he_cap.has_he) -+ if (!sta->deflink.he_cap.has_he) - return; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HE, sizeof(*he)); -@@ -786,8 +786,8 @@ mt7915_mcu_sta_he_tlv(struct sk_buff *skb, struct ieee80211_sta *sta, - - he->he_cap = cpu_to_le32(cap); - -- mcs_map = sta->he_cap.he_mcs_nss_supp; -- switch (sta->bandwidth) { -+ mcs_map = sta->deflink.he_cap.he_mcs_nss_supp; -+ switch (sta->deflink.bandwidth) { - case IEEE80211_STA_RX_BW_160: - if (elem->phy_cap_info[0] & - IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G) -@@ -837,7 +837,7 @@ mt7915_mcu_sta_muru_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - struct ieee80211_sta *sta, struct ieee80211_vif *vif) - { - struct mt7915_vif *mvif = (struct mt7915_vif *)vif->drv_priv; -- struct ieee80211_he_cap_elem *elem = &sta->he_cap.he_cap_elem; -+ struct ieee80211_he_cap_elem *elem = &sta->deflink.he_cap.he_cap_elem; - struct sta_rec_muru *muru; - struct tlv *tlv; - -@@ -856,11 +856,11 @@ mt7915_mcu_sta_muru_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - muru->cfg.mimo_ul_en = true; - muru->cfg.ofdma_dl_en = true; - -- if (sta->vht_cap.vht_supported) -+ if (sta->deflink.vht_cap.vht_supported) - muru->mimo_dl.vht_mu_bfee = -- !!(sta->vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE); -+ !!(sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_MU_BEAMFORMEE_CAPABLE); - -- if (!sta->he_cap.has_he) -+ if (!sta->deflink.he_cap.has_he) - return; - - muru->mimo_dl.partial_bw_dl_mimo = -@@ -894,13 +894,13 @@ mt7915_mcu_sta_ht_tlv(struct sk_buff *skb, struct ieee80211_sta *sta) - struct sta_rec_ht *ht; - struct tlv *tlv; - -- if (!sta->ht_cap.ht_supported) -+ if (!sta->deflink.ht_cap.ht_supported) - return; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HT, sizeof(*ht)); - - ht = (struct sta_rec_ht *)tlv; -- ht->ht_cap = cpu_to_le16(sta->ht_cap.cap); -+ ht->ht_cap = cpu_to_le16(sta->deflink.ht_cap.cap); - } - - static void -@@ -909,15 +909,15 @@ mt7915_mcu_sta_vht_tlv(struct sk_buff *skb, struct ieee80211_sta *sta) - struct sta_rec_vht *vht; - struct tlv *tlv; - -- if (!sta->vht_cap.vht_supported) -+ if (!sta->deflink.vht_cap.vht_supported) - return; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_VHT, sizeof(*vht)); - - vht = (struct sta_rec_vht *)tlv; -- vht->vht_cap = cpu_to_le32(sta->vht_cap.cap); -- vht->vht_rx_mcs_map = sta->vht_cap.vht_mcs.rx_mcs_map; -- vht->vht_tx_mcs_map = sta->vht_cap.vht_mcs.tx_mcs_map; -+ vht->vht_cap = cpu_to_le32(sta->deflink.vht_cap.cap); -+ vht->vht_rx_mcs_map = sta->deflink.vht_cap.vht_mcs.rx_mcs_map; -+ vht->vht_tx_mcs_map = sta->deflink.vht_cap.vht_mcs.tx_mcs_map; - } - - static void -@@ -932,7 +932,7 @@ mt7915_mcu_sta_amsdu_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - vif->type != NL80211_IFTYPE_AP) - return; - -- if (!sta->max_amsdu_len) -+ if (!sta->deflink.agg.max_amsdu_len) - return; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_HW_AMSDU, sizeof(*amsdu)); -@@ -941,7 +941,7 @@ mt7915_mcu_sta_amsdu_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - amsdu->amsdu_en = true; - msta->wcid.amsdu = true; - -- switch (sta->max_amsdu_len) { -+ switch (sta->deflink.agg.max_amsdu_len) { - case IEEE80211_MAX_MPDU_LEN_VHT_11454: - if (!is_mt7915(&dev->mt76)) { - amsdu->max_mpdu_size = -@@ -1004,8 +1004,8 @@ mt7915_is_ebf_supported(struct mt7915_phy *phy, struct ieee80211_vif *vif, - if (!bfee && tx_ant < 2) - return false; - -- if (sta->he_cap.has_he) { -- struct ieee80211_he_cap_elem *pe = &sta->he_cap.he_cap_elem; -+ if (sta->deflink.he_cap.has_he) { -+ struct ieee80211_he_cap_elem *pe = &sta->deflink.he_cap.he_cap_elem; - - if (bfee) - return mvif->cap.he_su_ebfee && -@@ -1015,8 +1015,8 @@ mt7915_is_ebf_supported(struct mt7915_phy *phy, struct ieee80211_vif *vif, - HE_PHY(CAP4_SU_BEAMFORMEE, pe->phy_cap_info[4]); - } - -- if (sta->vht_cap.vht_supported) { -- u32 cap = sta->vht_cap.cap; -+ if (sta->deflink.vht_cap.vht_supported) { -+ u32 cap = sta->deflink.vht_cap.cap; - - if (bfee) - return mvif->cap.vht_su_ebfee && -@@ -1042,7 +1042,7 @@ static void - mt7915_mcu_sta_bfer_ht(struct ieee80211_sta *sta, struct mt7915_phy *phy, - struct sta_rec_bf *bf) - { -- struct ieee80211_mcs_info *mcs = &sta->ht_cap.mcs; -+ struct ieee80211_mcs_info *mcs = &sta->deflink.ht_cap.mcs; - u8 n = 0; - - bf->tx_mode = MT_PHY_TYPE_HT; -@@ -1067,7 +1067,7 @@ static void - mt7915_mcu_sta_bfer_vht(struct ieee80211_sta *sta, struct mt7915_phy *phy, - struct sta_rec_bf *bf, bool explicit) - { -- struct ieee80211_sta_vht_cap *pc = &sta->vht_cap; -+ struct ieee80211_sta_vht_cap *pc = &sta->deflink.vht_cap; - struct ieee80211_sta_vht_cap *vc = &phy->mt76->sband_5g.sband.vht_cap; - u16 mcs_map = le16_to_cpu(pc->vht_mcs.rx_mcs_map); - u8 nss_mcs = mt7915_mcu_get_sta_nss(mcs_map); -@@ -1088,14 +1088,14 @@ mt7915_mcu_sta_bfer_vht(struct ieee80211_sta *sta, struct mt7915_phy *phy, - bf->ncol = min_t(u8, nss_mcs, bf->nrow); - bf->ibf_ncol = bf->ncol; - -- if (sta->bandwidth == IEEE80211_STA_RX_BW_160) -+ if (sta->deflink.bandwidth == IEEE80211_STA_RX_BW_160) - bf->nrow = 1; - } else { - bf->nrow = tx_ant; - bf->ncol = min_t(u8, nss_mcs, bf->nrow); - bf->ibf_ncol = nss_mcs; - -- if (sta->bandwidth == IEEE80211_STA_RX_BW_160) -+ if (sta->deflink.bandwidth == IEEE80211_STA_RX_BW_160) - bf->ibf_nrow = 1; - } - } -@@ -1104,7 +1104,7 @@ static void - mt7915_mcu_sta_bfer_he(struct ieee80211_sta *sta, struct ieee80211_vif *vif, - struct mt7915_phy *phy, struct sta_rec_bf *bf) - { -- struct ieee80211_sta_he_cap *pc = &sta->he_cap; -+ struct ieee80211_sta_he_cap *pc = &sta->deflink.he_cap; - struct ieee80211_he_cap_elem *pe = &pc->he_cap_elem; - const struct ieee80211_sta_he_cap *vc = - mt76_connac_get_he_phy_cap(phy->mt76, vif); -@@ -1129,7 +1129,7 @@ mt7915_mcu_sta_bfer_he(struct ieee80211_sta *sta, struct ieee80211_vif *vif, - bf->ncol = min_t(u8, nss_mcs, bf->nrow); - bf->ibf_ncol = bf->ncol; - -- if (sta->bandwidth != IEEE80211_STA_RX_BW_160) -+ if (sta->deflink.bandwidth != IEEE80211_STA_RX_BW_160) - return; - - /* go over for 160MHz and 80p80 */ -@@ -1177,7 +1177,7 @@ mt7915_mcu_sta_bfer_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - }; - bool ebf; - -- if (!(sta->ht_cap.ht_supported || sta->he_cap.has_he)) -+ if (!(sta->deflink.ht_cap.ht_supported || sta->deflink.he_cap.has_he)) - return; - - ebf = mt7915_is_ebf_supported(phy, vif, sta, false); -@@ -1191,21 +1191,21 @@ mt7915_mcu_sta_bfer_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - * vht: support eBF and iBF - * ht: iBF only, since mac80211 lacks of eBF support - */ -- if (sta->he_cap.has_he && ebf) -+ if (sta->deflink.he_cap.has_he && ebf) - mt7915_mcu_sta_bfer_he(sta, vif, phy, bf); -- else if (sta->vht_cap.vht_supported) -+ else if (sta->deflink.vht_cap.vht_supported) - mt7915_mcu_sta_bfer_vht(sta, phy, bf, ebf); -- else if (sta->ht_cap.ht_supported) -+ else if (sta->deflink.ht_cap.ht_supported) - mt7915_mcu_sta_bfer_ht(sta, phy, bf); - else - return; - - bf->bf_cap = ebf ? ebf : dev->ibf << 1; -- bf->bw = sta->bandwidth; -- bf->ibf_dbw = sta->bandwidth; -+ bf->bw = sta->deflink.bandwidth; -+ bf->ibf_dbw = sta->deflink.bandwidth; - bf->ibf_nrow = tx_ant; - -- if (!ebf && sta->bandwidth <= IEEE80211_STA_RX_BW_40 && !bf->ncol) -+ if (!ebf && sta->deflink.bandwidth <= IEEE80211_STA_RX_BW_40 && !bf->ncol) - bf->ibf_timeout = 0x48; - else - bf->ibf_timeout = 0x18; -@@ -1215,7 +1215,7 @@ mt7915_mcu_sta_bfer_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - else - bf->mem_20m = matrix[bf->nrow][bf->ncol]; - -- switch (sta->bandwidth) { -+ switch (sta->deflink.bandwidth) { - case IEEE80211_STA_RX_BW_160: - case IEEE80211_STA_RX_BW_80: - bf->mem_total = bf->mem_20m * 2; -@@ -1240,7 +1240,7 @@ mt7915_mcu_sta_bfee_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - struct tlv *tlv; - u8 nrow = 0; - -- if (!(sta->vht_cap.vht_supported || sta->he_cap.has_he)) -+ if (!(sta->deflink.vht_cap.vht_supported || sta->deflink.he_cap.has_he)) - return; - - if (!mt7915_is_ebf_supported(phy, vif, sta, true)) -@@ -1249,13 +1249,13 @@ mt7915_mcu_sta_bfee_tlv(struct mt7915_dev *dev, struct sk_buff *skb, - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_BFEE, sizeof(*bfee)); - bfee = (struct sta_rec_bfee *)tlv; - -- if (sta->he_cap.has_he) { -- struct ieee80211_he_cap_elem *pe = &sta->he_cap.he_cap_elem; -+ if (sta->deflink.he_cap.has_he) { -+ struct ieee80211_he_cap_elem *pe = &sta->deflink.he_cap.he_cap_elem; - - nrow = HE_PHY(CAP5_BEAMFORMEE_NUM_SND_DIM_UNDER_80MHZ_MASK, - pe->phy_cap_info[5]); -- } else if (sta->vht_cap.vht_supported) { -- struct ieee80211_sta_vht_cap *pc = &sta->vht_cap; -+ } else if (sta->deflink.vht_cap.vht_supported) { -+ struct ieee80211_sta_vht_cap *pc = &sta->deflink.vht_cap; - - nrow = FIELD_GET(IEEE80211_VHT_CAP_SOUNDING_DIMENSIONS_MASK, - pc->cap); -@@ -1311,7 +1311,7 @@ int mt7915_mcu_set_fixed_rate_ctrl(struct mt7915_dev *dev, - ra->phy = *phy; - break; - case RATE_PARAM_MMPS_UPDATE: -- ra->mmps_mode = mt7915_mcu_get_mmps_mode(sta->smps_mode); -+ ra->mmps_mode = mt7915_mcu_get_mmps_mode(sta->deflink.smps_mode); - break; - case RATE_PARAM_SPE_UPDATE: - ra->spe_idx = *(u8 *)data; -@@ -1386,7 +1386,7 @@ mt7915_mcu_add_rate_ctrl_fixed(struct mt7915_dev *dev, - do { \ - u8 i, gi = mask->control[band]._gi; \ - gi = (_he) ? gi : gi == NL80211_TXRATE_FORCE_SGI; \ -- for (i = 0; i <= sta->bandwidth; i++) { \ -+ for (i = 0; i <= sta->deflink.bandwidth; i++) { \ - phy.sgi |= gi << (i << (_he)); \ - phy.he_ltf |= mask->control[band].he_ltf << (i << (_he));\ - } \ -@@ -1400,11 +1400,11 @@ mt7915_mcu_add_rate_ctrl_fixed(struct mt7915_dev *dev, - } \ - } while (0) - -- if (sta->he_cap.has_he) { -+ if (sta->deflink.he_cap.has_he) { - __sta_phy_bitrate_mask_check(he_mcs, he_gi, 0, 1); -- } else if (sta->vht_cap.vht_supported) { -+ } else if (sta->deflink.vht_cap.vht_supported) { - __sta_phy_bitrate_mask_check(vht_mcs, gi, 0, 0); -- } else if (sta->ht_cap.ht_supported) { -+ } else if (sta->deflink.ht_cap.ht_supported) { - __sta_phy_bitrate_mask_check(ht_mcs, gi, 1, 0); - } else { - nrates = hweight32(mask->control[band].legacy); -@@ -1438,7 +1438,7 @@ mt7915_mcu_add_rate_ctrl_fixed(struct mt7915_dev *dev, - * actual txrate hardware sends out. - */ - addr = mt7915_mac_wtbl_lmac_addr(dev, msta->wcid.idx, 7); -- if (sta->he_cap.has_he) -+ if (sta->deflink.he_cap.has_he) - mt76_rmw_field(dev, addr, GENMASK(31, 24), phy.sgi); - else - mt76_rmw_field(dev, addr, GENMASK(15, 12), phy.sgi); -@@ -1471,7 +1471,7 @@ mt7915_mcu_sta_rate_ctrl_tlv(struct sk_buff *skb, struct mt7915_dev *dev, - enum nl80211_band band = chandef->chan->band; - struct sta_rec_ra *ra; - struct tlv *tlv; -- u32 supp_rate = sta->supp_rates[band]; -+ u32 supp_rate = sta->deflink.supp_rates[band]; - u32 cap = sta->wme ? STA_CAP_WMM : 0; - - tlv = mt76_connac_mcu_add_tlv(skb, STA_REC_RA, sizeof(*ra)); -@@ -1481,9 +1481,9 @@ mt7915_mcu_sta_rate_ctrl_tlv(struct sk_buff *skb, struct mt7915_dev *dev, - ra->auto_rate = true; - ra->phy_mode = mt76_connac_get_phy_mode(mphy, vif, band, sta); - ra->channel = chandef->chan->hw_value; -- ra->bw = sta->bandwidth; -- ra->phy.bw = sta->bandwidth; -- ra->mmps_mode = mt7915_mcu_get_mmps_mode(sta->smps_mode); -+ ra->bw = sta->deflink.bandwidth; -+ ra->phy.bw = sta->deflink.bandwidth; -+ ra->mmps_mode = mt7915_mcu_get_mmps_mode(sta->deflink.smps_mode); - - if (supp_rate) { - supp_rate &= mask->control[band].legacy; -@@ -1503,22 +1503,22 @@ mt7915_mcu_sta_rate_ctrl_tlv(struct sk_buff *skb, struct mt7915_dev *dev, - } - } - -- if (sta->ht_cap.ht_supported) { -+ if (sta->deflink.ht_cap.ht_supported) { - ra->supp_mode |= MODE_HT; -- ra->af = sta->ht_cap.ampdu_factor; -- ra->ht_gf = !!(sta->ht_cap.cap & IEEE80211_HT_CAP_GRN_FLD); -+ ra->af = sta->deflink.ht_cap.ampdu_factor; -+ ra->ht_gf = !!(sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_GRN_FLD); - - cap |= STA_CAP_HT; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_20) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_20) - cap |= STA_CAP_SGI_20; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_SGI_40) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_SGI_40) - cap |= STA_CAP_SGI_40; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_TX_STBC) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_TX_STBC) - cap |= STA_CAP_TX_STBC; -- if (sta->ht_cap.cap & IEEE80211_HT_CAP_RX_STBC) -+ if (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_RX_STBC) - cap |= STA_CAP_RX_STBC; - if (mvif->cap.ht_ldpc && -- (sta->ht_cap.cap & IEEE80211_HT_CAP_LDPC_CODING)) -+ (sta->deflink.ht_cap.cap & IEEE80211_HT_CAP_LDPC_CODING)) - cap |= STA_CAP_LDPC; - - mt7915_mcu_set_sta_ht_mcs(sta, ra->ht_mcs, -@@ -1526,37 +1526,37 @@ mt7915_mcu_sta_rate_ctrl_tlv(struct sk_buff *skb, struct mt7915_dev *dev, - ra->supp_ht_mcs = *(__le32 *)ra->ht_mcs; - } - -- if (sta->vht_cap.vht_supported) { -+ if (sta->deflink.vht_cap.vht_supported) { - u8 af; - - ra->supp_mode |= MODE_VHT; - af = FIELD_GET(IEEE80211_VHT_CAP_MAX_A_MPDU_LENGTH_EXPONENT_MASK, -- sta->vht_cap.cap); -+ sta->deflink.vht_cap.cap); - ra->af = max_t(u8, ra->af, af); - - cap |= STA_CAP_VHT; -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_80) -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_80) - cap |= STA_CAP_VHT_SGI_80; -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_160) -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_SHORT_GI_160) - cap |= STA_CAP_VHT_SGI_160; -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_TXSTBC) -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_TXSTBC) - cap |= STA_CAP_VHT_TX_STBC; -- if (sta->vht_cap.cap & IEEE80211_VHT_CAP_RXSTBC_1) -+ if (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_RXSTBC_1) - cap |= STA_CAP_VHT_RX_STBC; - if (mvif->cap.vht_ldpc && -- (sta->vht_cap.cap & IEEE80211_VHT_CAP_RXLDPC)) -+ (sta->deflink.vht_cap.cap & IEEE80211_VHT_CAP_RXLDPC)) - cap |= STA_CAP_VHT_LDPC; - - mt7915_mcu_set_sta_vht_mcs(sta, ra->supp_vht_mcs, - mask->control[band].vht_mcs); - } - -- if (sta->he_cap.has_he) { -+ if (sta->deflink.he_cap.has_he) { - ra->supp_mode |= MODE_HE; - cap |= STA_CAP_HE; - -- if (sta->he_6ghz_capa.capa) -- ra->af = le16_get_bits(sta->he_6ghz_capa.capa, -+ if (sta->deflink.he_6ghz_capa.capa) -+ ra->af = le16_get_bits(sta->deflink.he_6ghz_capa.capa, - IEEE80211_HE_6GHZ_CAP_MAX_AMPDU_LEN_EXP); - } - -@@ -1765,7 +1765,7 @@ mt7915_mcu_beacon_cntdwn(struct ieee80211_vif *vif, struct sk_buff *rskb, - if (!offs->cntdwn_counter_offs[0]) - return; - -- sub_tag = vif->csa_active ? BSS_INFO_BCN_CSA : BSS_INFO_BCN_BCC; -+ sub_tag = vif->bss_conf.csa_active ? BSS_INFO_BCN_CSA : BSS_INFO_BCN_BCC; - tlv = mt7915_mcu_add_nested_subtlv(rskb, sub_tag, sizeof(*info), - &bcn->sub_ntlv, &bcn->len); - info = (struct bss_info_bcn_cntdwn *)tlv; -@@ -1850,9 +1850,9 @@ mt7915_mcu_beacon_cont(struct mt7915_dev *dev, struct ieee80211_vif *vif, - if (offs->cntdwn_counter_offs[0]) { - u16 offset = offs->cntdwn_counter_offs[0]; - -- if (vif->csa_active) -+ if (vif->bss_conf.csa_active) - cont->csa_ofs = cpu_to_le16(offset - 4); -- if (vif->color_change_active) -+ if (vif->bss_conf.color_change_active) - cont->bcc_ofs = cpu_to_le16(offset - 3); - } - -@@ -2037,7 +2037,7 @@ int mt7915_mcu_add_beacon(struct ieee80211_hw *hw, struct ieee80211_vif *vif, - if (!en) - goto out; - -- skb = ieee80211_beacon_get_template(hw, vif, &offs); -+ skb = ieee80211_beacon_get_template(hw, vif, &offs, 0); - if (!skb) - return -EINVAL; - -@@ -3162,17 +3162,17 @@ int mt7915_mcu_set_txpower_frame(struct mt7915_phy *phy, - if (txpower) { - u32 offs, len, i; - -- if (sta->ht_cap.ht_supported) { -+ if (sta->deflink.ht_cap.ht_supported) { - const u8 *sku_len = mt7915_sku_group_len; - - offs = sku_len[SKU_CCK] + sku_len[SKU_OFDM]; - len = sku_len[SKU_HT_BW20] + sku_len[SKU_HT_BW40]; - -- if (sta->vht_cap.vht_supported) { -+ if (sta->deflink.vht_cap.vht_supported) { - offs += len; - len = sku_len[SKU_VHT_BW20] * 4; - -- if (sta->he_cap.has_he) { -+ if (sta->deflink.he_cap.has_he) { - offs += len + sku_len[SKU_HE_RU26] * 3; - len = sku_len[SKU_HE_RU242] * 4; - } -diff --git a/mt7915/soc.c b/mt7915/soc.c -index 8b398d577369..c06c56a0270d 100644 ---- a/mt7915/soc.c -+++ b/mt7915/soc.c -@@ -4,6 +4,7 @@ - #include - #include - #include -+#include - #include - #include - #include -diff --git a/mt7921/dma.c b/mt7921/dma.c -index 6456c9a6175a..d1f10f6d9adc 100644 ---- a/mt7921/dma.c -+++ b/mt7921/dma.c -@@ -283,8 +283,8 @@ int mt7921_dma_init(struct mt7921_dev *dev) - if (ret < 0) - return ret; - -- netif_tx_napi_add(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -- mt7921_poll_tx, NAPI_POLL_WEIGHT); -+ netif_napi_add_tx(&dev->mt76.tx_napi_dev, &dev->mt76.tx_napi, -+ mt7921_poll_tx); - napi_enable(&dev->mt76.tx_napi); - - return mt7921_dma_enable(dev); -diff --git a/mt7921/init.c b/mt7921/init.c -index e42cb6be4055..0d8db2bd6a25 100644 ---- a/mt7921/init.c -+++ b/mt7921/init.c -@@ -55,8 +55,8 @@ mt7921_init_wiphy(struct ieee80211_hw *hw) - struct wiphy *wiphy = hw->wiphy; - - hw->queues = 4; -- hw->max_rx_aggregation_subframes = 256; -- hw->max_tx_aggregation_subframes = 256; -+ hw->max_rx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF_HE; -+ hw->max_tx_aggregation_subframes = IEEE80211_MAX_AMPDU_BUF_HE; - hw->netdev_features = NETIF_F_RXCSUM; - - hw->radiotap_timestamp.units_pos = -diff --git a/mt7921/mac.c b/mt7921/mac.c -index 639614b04c5f..2d2b53d6cd47 100644 ---- a/mt7921/mac.c -+++ b/mt7921/mac.c -@@ -504,7 +504,7 @@ static void mt7921_tx_check_aggr(struct ieee80211_sta *sta, __le32 *txwi) - u16 fc, tid; - u32 val; - -- if (!sta || !(sta->ht_cap.ht_supported || sta->he_cap.has_he)) -+ if (!sta || !(sta->deflink.ht_cap.ht_supported || sta->deflink.he_cap.has_he)) - return; - - tid = le32_get_bits(txwi[1], MT_TXD1_TID); -diff --git a/mt7921/main.c b/mt7921/main.c -index 1b7219e37d19..3e42dcaa4391 100644 ---- a/mt7921/main.c -+++ b/mt7921/main.c -@@ -171,7 +171,8 @@ mt7921_init_he_caps(struct mt7921_phy *phy, enum nl80211_band band, - mt7921_gen_ppe_thresh(he_cap->ppe_thres, nss); - } else { - he_cap_elem->phy_cap_info[9] |= -- IEEE80211_HE_PHY_CAP9_NOMIMAL_PKT_PADDING_16US; -+ u8_encode_bits(IEEE80211_HE_PHY_CAP9_NOMINAL_PKT_PADDING_16US, -+ IEEE80211_HE_PHY_CAP9_NOMINAL_PKT_PADDING_MASK); - } - - if (band == NL80211_BAND_6GHZ) { -@@ -690,7 +691,8 @@ out: - } - - static int --mt7921_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, u16 queue, -+mt7921_conf_tx(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ unsigned int link_id, u16 queue, - const struct ieee80211_tx_queue_params *params) - { - struct mt7921_vif *mvif = (struct mt7921_vif *)vif->drv_priv; -@@ -760,7 +762,7 @@ static void mt7921_configure_filter(struct ieee80211_hw *hw, - static void mt7921_bss_info_changed(struct ieee80211_hw *hw, - struct ieee80211_vif *vif, - struct ieee80211_bss_conf *info, -- u32 changed) -+ u64 changed) - { - struct mt7921_phy *phy = mt7921_hw_phy(hw); - struct mt7921_dev *dev = mt7921_hw_dev(hw); -@@ -791,7 +793,7 @@ static void mt7921_bss_info_changed(struct ieee80211_hw *hw, - if (changed & BSS_CHANGED_ASSOC) { - mt7921_mcu_sta_update(dev, NULL, vif, true, - MT76_STA_INFO_STATE_ASSOC); -- mt7921_mcu_set_beacon_filter(dev, vif, info->assoc); -+ mt7921_mcu_set_beacon_filter(dev, vif, vif->cfg.assoc); - } - - if (changed & BSS_CHANGED_ARP_FILTER) { -@@ -1638,8 +1640,8 @@ mt7921_channel_switch_beacon(struct ieee80211_hw *hw, - } - - static int --mt7921_start_ap(struct ieee80211_hw *hw, -- struct ieee80211_vif *vif) -+mt7921_start_ap(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ struct ieee80211_bss_conf *link_conf) - { - struct mt7921_vif *mvif = (struct mt7921_vif *)vif->drv_priv; - struct mt7921_phy *phy = mt7921_hw_phy(hw); -@@ -1666,8 +1668,8 @@ out: - } - - static void --mt7921_stop_ap(struct ieee80211_hw *hw, -- struct ieee80211_vif *vif) -+mt7921_stop_ap(struct ieee80211_hw *hw, struct ieee80211_vif *vif, -+ struct ieee80211_bss_conf *link_conf) - { - struct mt7921_vif *mvif = (struct mt7921_vif *)vif->drv_priv; - struct mt7921_phy *phy = mt7921_hw_phy(hw); -diff --git a/mt7921/mcu.c b/mt7921/mcu.c -index b7ed744fa396..fb9c0f66cb27 100644 ---- a/mt7921/mcu.c -+++ b/mt7921/mcu.c -@@ -862,7 +862,7 @@ int mt7921_mcu_uni_bss_ps(struct mt7921_dev *dev, struct ieee80211_vif *vif) - .ps = { - .tag = cpu_to_le16(UNI_BSS_INFO_PS), - .len = cpu_to_le16(sizeof(struct ps_tlv)), -- .ps_state = vif->bss_conf.ps ? 2 : 0, -+ .ps_state = vif->cfg.ps ? 2 : 0, - }, - }; - -@@ -926,7 +926,7 @@ mt7921_mcu_set_bss_pm(struct mt7921_dev *dev, struct ieee80211_vif *vif, - u8 pad; - } req = { - .bss_idx = mvif->mt76.idx, -- .aid = cpu_to_le16(vif->bss_conf.aid), -+ .aid = cpu_to_le16(vif->cfg.aid), - .dtim_period = vif->bss_conf.dtim_period, - .bcn_interval = cpu_to_le16(vif->bss_conf.beacon_int), - }; -@@ -1143,7 +1143,7 @@ mt7921_mcu_uni_add_beacon_offload(struct mt7921_dev *dev, - if (!enable) - return -EOPNOTSUPP; - -- skb = ieee80211_beacon_get_template(mt76_hw(dev), vif, &offs); -+ skb = ieee80211_beacon_get_template(mt76_hw(dev), vif, &offs, 0); - if (!skb) - return -EINVAL; - -diff --git a/mt7921/pci_mac.c b/mt7921/pci_mac.c -index 436f07ba9629..8dd60408b117 100644 ---- a/mt7921/pci_mac.c -+++ b/mt7921/pci_mac.c -@@ -113,7 +113,7 @@ int mt7921e_mac_reset(struct mt7921_dev *dev) - - err = mt7921e_driver_own(dev); - if (err) -- return err; -+ goto out; - - err = mt7921_run_firmware(dev); - if (err) -diff --git a/tx.c b/tx.c -index c8d78b0a5d84..24568b98ed9d 100644 ---- a/tx.c -+++ b/tx.c -@@ -60,15 +60,20 @@ mt76_tx_status_unlock(struct mt76_dev *dev, struct sk_buff_head *list) - .skb = skb, - .info = IEEE80211_SKB_CB(skb), - }; -+ struct ieee80211_rate_status rs = {}; - struct mt76_tx_cb *cb = mt76_tx_skb_cb(skb); - struct mt76_wcid *wcid; - - wcid = rcu_dereference(dev->wcid[cb->wcid]); - if (wcid) { - status.sta = wcid_to_sta(wcid); -- -- if (status.sta) -- status.rate = &wcid->rate; -+ if (status.sta && (wcid->rate.flags || wcid->rate.legacy)) { -+ rs.rate_idx = wcid->rate; -+ status.rates = &rs; -+ status.n_rates = 1; -+ } else { -+ status.n_rates = 0; -+ } - } - - hw = mt76_tx_status_get_hw(dev, skb); -diff --git a/usb.c b/usb.c -index 369c27ab9259..3e281715fcd4 100644 ---- a/usb.c -+++ b/usb.c -@@ -1075,7 +1075,7 @@ int __mt76u_init(struct mt76_dev *dev, struct usb_interface *intf, - - INIT_WORK(&usb->stat_work, mt76u_tx_status_data); - -- usb->data_len = usb_maxpacket(udev, usb_sndctrlpipe(udev, 0), 1); -+ usb->data_len = usb_maxpacket(udev, usb_sndctrlpipe(udev, 0)); - if (usb->data_len < 32) - usb->data_len = 32; - --- -2.38.1 -