From 7f44f8d8d63d73807c4765386208b36acea01881 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Sat, 13 Jul 2024 15:31:11 +0200 Subject: [PATCH] mt76: update to Git HEAD (2024-07-13) 564cd93961fc mt76: sync with upstream changes 3b47d9df427c wifi: mt76: mt7915: fix oops on non-dbdc mt7986 Signed-off-by: Felix Fietkau --- package/kernel/mt76/Makefile | 6 +- .../kernel/mt76/patches/100-api_changes.patch | 678 ------------------ 2 files changed, 3 insertions(+), 681 deletions(-) delete mode 100644 package/kernel/mt76/patches/100-api_changes.patch diff --git a/package/kernel/mt76/Makefile b/package/kernel/mt76/Makefile index c6cce9cf9c6749..f71070dbb9072f 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:=2024-05-17 -PKG_SOURCE_VERSION:=513c131c6309712a51502870b041f45b4bd6a6d4 -PKG_MIRROR_HASH:=3e5d8ee6b8b122cc4e32668fdde0552a9fa23819b7ebdc758ecb63b5f761683a +PKG_SOURCE_DATE:=2024-07-13 +PKG_SOURCE_VERSION:=3b47d9df427c4833605a172f2a8f0e0012b04c80 +PKG_MIRROR_HASH:=23c3aaa53fb2e088446eb18148a44d3edcd3a0eda1ee41cf5cbf56064ebbee58 PKG_MAINTAINER:=Felix Fietkau PKG_USE_NINJA:=0 diff --git a/package/kernel/mt76/patches/100-api_changes.patch b/package/kernel/mt76/patches/100-api_changes.patch deleted file mode 100644 index de81614ada590e..00000000000000 --- a/package/kernel/mt76/patches/100-api_changes.patch +++ /dev/null @@ -1,678 +0,0 @@ ---- a/mac80211.c -+++ b/mac80211.c -@@ -1614,8 +1614,8 @@ EXPORT_SYMBOL_GPL(mt76_get_sar_power); - static void - __mt76_csa_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { -- if (vif->bss_conf.csa_active && ieee80211_beacon_cntdwn_is_complete(vif)) -- ieee80211_csa_finish(vif); -+ if (vif->bss_conf.csa_active && ieee80211_beacon_cntdwn_is_complete(vif, 0)) -+ ieee80211_csa_finish(vif, 0); - } - - void mt76_csa_finish(struct mt76_dev *dev) -@@ -1639,7 +1639,7 @@ __mt76_csa_check(void *priv, u8 *mac, st - if (!vif->bss_conf.csa_active) - return; - -- dev->csa_complete |= ieee80211_beacon_cntdwn_is_complete(vif); -+ dev->csa_complete |= ieee80211_beacon_cntdwn_is_complete(vif, 0); - } - - void mt76_csa_check(struct mt76_dev *dev) ---- a/mt76.h -+++ b/mt76.h -@@ -1611,6 +1611,18 @@ s8 mt76_get_rate_power_limits(struct mt7 - struct mt76_power_limits *dest, - s8 target_power); - -+static inline bool mt76_queue_is_rx(struct mt76_dev *dev, struct mt76_queue *q) -+{ -+ int i; -+ -+ for (i = 0; i < ARRAY_SIZE(dev->q_rx); i++) { -+ if (q == &dev->q_rx[i]) -+ return true; -+ } -+ -+ return false; -+} -+ - static inline bool mt76_queue_is_wed_tx_free(struct mt76_queue *q) - { - return (q->flags & MT_QFLAG_WED) && ---- a/mt7603/main.c -+++ b/mt7603/main.c -@@ -701,6 +701,10 @@ static void mt7603_tx(struct ieee80211_h - } - - const struct ieee80211_ops mt7603_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt7603_tx, - .start = mt7603_start, - .stop = mt7603_stop, -@@ -728,6 +732,7 @@ const struct ieee80211_ops mt7603_ops = - .set_sar_specs = mt7603_set_sar_specs, - }; - -+MODULE_DESCRIPTION("MediaTek MT7603E and MT76x8 wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); - - static int __init mt7603_init(void) ---- a/mt7615/Kconfig -+++ b/mt7615/Kconfig -@@ -11,7 +11,7 @@ config MT7615E - depends on MAC80211 - depends on PCI - help -- This adds support for MT7615-based wireless PCIe devices, -+ This adds support for MT7615-based PCIe wireless devices, - which support concurrent dual-band operation at both 5GHz - and 2.4GHz, IEEE 802.11ac 4x4:4SS 1733Mbps PHY rate, wave2 - MU-MIMO up to 4 users/group and 160MHz channels. ---- a/mt7615/main.c -+++ b/mt7615/main.c -@@ -1326,6 +1326,10 @@ static void mt7615_set_rekey_data(struct - #endif /* CONFIG_PM */ - - const struct ieee80211_ops mt7615_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt7615_tx, - .start = mt7615_start, - .stop = mt7615_stop, -@@ -1375,4 +1379,5 @@ const struct ieee80211_ops mt7615_ops = - }; - EXPORT_SYMBOL_GPL(mt7615_ops); - -+MODULE_DESCRIPTION("MediaTek MT7615E and MT7663E wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7615/mcu.c -+++ b/mt7615/mcu.c -@@ -353,7 +353,7 @@ static void - mt7615_mcu_csa_finish(void *priv, u8 *mac, struct ieee80211_vif *vif) - { - if (vif->bss_conf.csa_active) -- ieee80211_csa_finish(vif); -+ ieee80211_csa_finish(vif, 0); - } - - static void ---- a/mt7615/mmio.c -+++ b/mt7615/mmio.c -@@ -270,4 +270,5 @@ static void __exit mt7615_exit(void) - - module_init(mt7615_init); - module_exit(mt7615_exit); -+MODULE_DESCRIPTION("MediaTek MT7615E MMIO helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7615/sdio.c -+++ b/mt7615/sdio.c -@@ -180,7 +180,6 @@ static void mt7663s_remove(struct sdio_f - mt76_free_device(&dev->mt76); - } - --#ifdef CONFIG_PM - static int mt7663s_suspend(struct device *dev) - { - struct sdio_func *func = dev_to_sdio_func(dev); -@@ -235,31 +234,24 @@ static int mt7663s_resume(struct device - return err; - } - --static const struct dev_pm_ops mt7663s_pm_ops = { -- .suspend = mt7663s_suspend, -- .resume = mt7663s_resume, --}; --#endif -- - MODULE_DEVICE_TABLE(sdio, mt7663s_table); - MODULE_FIRMWARE(MT7663_OFFLOAD_FIRMWARE_N9); - MODULE_FIRMWARE(MT7663_OFFLOAD_ROM_PATCH); - MODULE_FIRMWARE(MT7663_FIRMWARE_N9); - MODULE_FIRMWARE(MT7663_ROM_PATCH); - -+static DEFINE_SIMPLE_DEV_PM_OPS(mt7663s_pm_ops, mt7663s_suspend, mt7663s_resume); -+ - static struct sdio_driver mt7663s_driver = { - .name = KBUILD_MODNAME, - .probe = mt7663s_probe, - .remove = mt7663s_remove, - .id_table = mt7663s_table, --#ifdef CONFIG_PM -- .drv = { -- .pm = &mt7663s_pm_ops, -- } --#endif -+ .drv.pm = pm_sleep_ptr(&mt7663s_pm_ops), - }; - module_sdio_driver(mt7663s_driver); - - MODULE_AUTHOR("Sean Wang "); - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT7663S (SDIO) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7615/usb.c -+++ b/mt7615/usb.c -@@ -281,4 +281,5 @@ module_usb_driver(mt7663u_driver); - - MODULE_AUTHOR("Sean Wang "); - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT7663U (USB) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7615/usb_sdio.c -+++ b/mt7615/usb_sdio.c -@@ -349,4 +349,5 @@ EXPORT_SYMBOL_GPL(mt7663_usb_sdio_regist - - MODULE_AUTHOR("Lorenzo Bianconi "); - MODULE_AUTHOR("Sean Wang "); -+MODULE_DESCRIPTION("MediaTek MT7663 SDIO/USB helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76_connac_mcu.c -+++ b/mt76_connac_mcu.c -@@ -3171,4 +3171,5 @@ exit: - EXPORT_SYMBOL_GPL(mt76_connac2_mcu_fill_message); - - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT76x connac layer helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76_connac_mcu.h -+++ b/mt76_connac_mcu.h -@@ -128,7 +128,7 @@ struct mt76_connac2_mcu_rxd { - u8 rsv1[2]; - u8 s2d_index; - -- u8 tlv[0]; -+ u8 tlv[]; - }; - - struct mt76_connac2_patch_hdr { -@@ -1460,7 +1460,7 @@ struct mt76_connac_beacon_loss_event { - } __packed; - - struct mt76_connac_rssi_notify_event { -- s32 rssi[4]; -+ __le32 rssi[4]; - } __packed; - - struct mt76_connac_mcu_bss_event { ---- a/mt76x0/eeprom.c -+++ b/mt76x0/eeprom.c -@@ -342,4 +342,5 @@ int mt76x0_eeprom_init(struct mt76x02_de - return 0; - } - -+MODULE_DESCRIPTION("MediaTek MT76x EEPROM helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76x0/pci.c -+++ b/mt76x0/pci.c -@@ -59,6 +59,10 @@ mt76x0e_flush(struct ieee80211_hw *hw, s - } - - static const struct ieee80211_ops mt76x0e_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt76x02_tx, - .start = mt76x0e_start, - .stop = mt76x0e_stop, -@@ -302,6 +306,7 @@ static const struct pci_device_id mt76x0 - MODULE_DEVICE_TABLE(pci, mt76x0e_device_table); - MODULE_FIRMWARE(MT7610E_FIRMWARE); - MODULE_FIRMWARE(MT7650E_FIRMWARE); -+MODULE_DESCRIPTION("MediaTek MT76x0E (PCIe) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); - - static struct pci_driver mt76x0e_driver = { ---- a/mt76x0/usb.c -+++ b/mt76x0/usb.c -@@ -118,6 +118,10 @@ static int mt76x0u_start(struct ieee8021 - } - - static const struct ieee80211_ops mt76x0u_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt76x02_tx, - .start = mt76x0u_start, - .stop = mt76x0u_stop, -@@ -336,6 +340,7 @@ err: - MODULE_DEVICE_TABLE(usb, mt76x0_device_table); - MODULE_FIRMWARE(MT7610E_FIRMWARE); - MODULE_FIRMWARE(MT7610U_FIRMWARE); -+MODULE_DESCRIPTION("MediaTek MT76x0U (USB) wireless driver"); - MODULE_LICENSE("GPL"); - - static struct usb_driver mt76x0_driver = { ---- a/mt76x02_usb_mcu.c -+++ b/mt76x02_usb_mcu.c -@@ -293,4 +293,5 @@ void mt76x02u_init_mcu(struct mt76_dev * - EXPORT_SYMBOL_GPL(mt76x02u_init_mcu); - - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT76x02 MCU helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76x02_util.c -+++ b/mt76x02_util.c -@@ -696,4 +696,5 @@ void mt76x02_config_mac_addr_list(struct - } - EXPORT_SYMBOL_GPL(mt76x02_config_mac_addr_list); - -+MODULE_DESCRIPTION("MediaTek MT76x02 helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76x2/eeprom.c -+++ b/mt76x2/eeprom.c -@@ -506,4 +506,5 @@ int mt76x2_eeprom_init(struct mt76x02_de - } - EXPORT_SYMBOL_GPL(mt76x2_eeprom_init); - -+MODULE_DESCRIPTION("MediaTek MT76x2 EEPROM helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76x2/pci.c -+++ b/mt76x2/pci.c -@@ -165,6 +165,7 @@ mt76x2e_resume(struct pci_dev *pdev) - MODULE_DEVICE_TABLE(pci, mt76x2e_device_table); - MODULE_FIRMWARE(MT7662_FIRMWARE); - MODULE_FIRMWARE(MT7662_ROM_PATCH); -+MODULE_DESCRIPTION("MediaTek MT76x2E (PCIe) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); - - static struct pci_driver mt76pci_driver = { ---- a/mt76x2/pci_main.c -+++ b/mt76x2/pci_main.c -@@ -132,6 +132,10 @@ static int mt76x2_set_antenna(struct iee - } - - const struct ieee80211_ops mt76x2_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt76x02_tx, - .start = mt76x2_start, - .stop = mt76x2_stop, ---- a/mt76x2/usb.c -+++ b/mt76x2/usb.c -@@ -148,4 +148,5 @@ static struct usb_driver mt76x2u_driver - module_usb_driver(mt76x2u_driver); - - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT76x2U (USB) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt76x2/usb_main.c -+++ b/mt76x2/usb_main.c -@@ -103,6 +103,10 @@ mt76x2u_config(struct ieee80211_hw *hw, - } - - const struct ieee80211_ops mt76x2u_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt76x02_tx, - .start = mt76x2u_start, - .stop = mt76x2u_stop, ---- a/mt7915/Kconfig -+++ b/mt7915/Kconfig -@@ -7,7 +7,7 @@ config MT7915E - depends on PCI - select RELAY - help -- This adds support for MT7915-based wireless PCIe devices, -+ This adds support for MT7915-based PCIe wireless devices, - which support concurrent dual-band operation at both 5GHz - and 2.4GHz IEEE 802.11ax 4x4:4SS 1024-QAM, 160MHz channels, - OFDMA, spatial reuse and dual carrier modulation. ---- a/mt7915/init.c -+++ b/mt7915/init.c -@@ -4,6 +4,7 @@ - #include - #include - #include -+#include - #include - #include "mt7915.h" - #include "mac.h" -@@ -1151,8 +1152,7 @@ void mt7915_set_stream_he_caps(struct mt - n = mt7915_init_he_caps(phy, NL80211_BAND_2GHZ, data); - - band = &phy->mt76->sband_2g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - } - - if (phy->mt76->cap.has_5ghz) { -@@ -1160,8 +1160,7 @@ void mt7915_set_stream_he_caps(struct mt - n = mt7915_init_he_caps(phy, NL80211_BAND_5GHZ, data); - - band = &phy->mt76->sband_5g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - } - - if (phy->mt76->cap.has_6ghz) { -@@ -1169,8 +1168,7 @@ void mt7915_set_stream_he_caps(struct mt - n = mt7915_init_he_caps(phy, NL80211_BAND_6GHZ, data); - - band = &phy->mt76->sband_6g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - } - } - ---- a/mt7915/main.c -+++ b/mt7915/main.c -@@ -1661,6 +1661,10 @@ mt7915_net_fill_forward_path(struct ieee - #endif - - const struct ieee80211_ops mt7915_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt7915_tx, - .start = mt7915_start, - .stop = mt7915_stop, ---- a/mt7915/mcu.c -+++ b/mt7915/mcu.c -@@ -228,7 +228,7 @@ mt7915_mcu_csa_finish(void *priv, u8 *ma - if (!vif->bss_conf.csa_active || vif->type == NL80211_IFTYPE_STATION) - return; - -- ieee80211_csa_finish(vif); -+ ieee80211_csa_finish(vif, 0); - } - - static void -@@ -463,10 +463,10 @@ static bool mt7915_check_he_obss_narrow_ - .tolerated = true, - }; - -- if (!(vif->bss_conf.chandef.chan->flags & IEEE80211_CHAN_RADAR)) -+ if (!(vif->bss_conf.chanreq.oper.chan->flags & IEEE80211_CHAN_RADAR)) - return false; - -- cfg80211_bss_iter(hw->wiphy, &vif->bss_conf.chandef, -+ cfg80211_bss_iter(hw->wiphy, &vif->bss_conf.chanreq.oper, - mt7915_check_he_obss_narrow_bw_ru_iter, - &iter_data); - ---- a/mt7915/mmio.c -+++ b/mt7915/mmio.c -@@ -993,4 +993,5 @@ static void __exit mt7915_exit(void) - - module_init(mt7915_init); - module_exit(mt7915_exit); -+MODULE_DESCRIPTION("MediaTek MT7915E MMIO helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7921/main.c -+++ b/mt7921/main.c -@@ -196,8 +196,7 @@ void mt7921_set_stream_he_caps(struct mt - n = mt7921_init_he_caps(phy, NL80211_BAND_2GHZ, data); - - band = &phy->mt76->sband_2g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - } - - if (phy->mt76->cap.has_5ghz) { -@@ -205,16 +204,14 @@ void mt7921_set_stream_he_caps(struct mt - n = mt7921_init_he_caps(phy, NL80211_BAND_5GHZ, data); - - band = &phy->mt76->sband_5g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - - if (phy->mt76->cap.has_6ghz) { - data = phy->iftype[NL80211_BAND_6GHZ]; - n = mt7921_init_he_caps(phy, NL80211_BAND_6GHZ, data); - - band = &phy->mt76->sband_6g.sband; -- band->iftype_data = data; -- band->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(band, data, n); - } - } - } -@@ -1464,5 +1461,6 @@ const struct ieee80211_ops mt7921_ops = - }; - EXPORT_SYMBOL_GPL(mt7921_ops); - -+MODULE_DESCRIPTION("MediaTek MT7921 core driver"); - MODULE_LICENSE("Dual BSD/GPL"); - MODULE_AUTHOR("Sean Wang "); ---- a/mt7921/pci.c -+++ b/mt7921/pci.c -@@ -570,4 +570,5 @@ MODULE_FIRMWARE(MT7922_FIRMWARE_WM); - MODULE_FIRMWARE(MT7922_ROM_PATCH); - MODULE_AUTHOR("Sean Wang "); - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT7921E (PCIe) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7921/sdio.c -+++ b/mt7921/sdio.c -@@ -201,7 +201,6 @@ static void mt7921s_remove(struct sdio_f - mt7921s_unregister_device(dev); - } - --#ifdef CONFIG_PM - static int mt7921s_suspend(struct device *__dev) - { - struct sdio_func *func = dev_to_sdio_func(__dev); -@@ -312,27 +311,20 @@ failed: - return err; - } - --static const struct dev_pm_ops mt7921s_pm_ops = { -- .suspend = mt7921s_suspend, -- .resume = mt7921s_resume, --}; --#endif -- - MODULE_DEVICE_TABLE(sdio, mt7921s_table); - MODULE_FIRMWARE(MT7921_FIRMWARE_WM); - MODULE_FIRMWARE(MT7921_ROM_PATCH); - -+static DEFINE_SIMPLE_DEV_PM_OPS(mt7921s_pm_ops, mt7921s_suspend, mt7921s_resume); -+ - static struct sdio_driver mt7921s_driver = { - .name = KBUILD_MODNAME, - .probe = mt7921s_probe, - .remove = mt7921s_remove, - .id_table = mt7921s_table, --#ifdef CONFIG_PM -- .drv = { -- .pm = &mt7921s_pm_ops, -- } --#endif -+ .drv.pm = pm_sleep_ptr(&mt7921s_pm_ops), - }; - module_sdio_driver(mt7921s_driver); -+MODULE_DESCRIPTION("MediaTek MT7921S (SDIO) wireless driver"); - MODULE_AUTHOR("Sean Wang "); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7921/usb.c -+++ b/mt7921/usb.c -@@ -336,5 +336,6 @@ static struct usb_driver mt7921u_driver - }; - module_usb_driver(mt7921u_driver); - -+MODULE_DESCRIPTION("MediaTek MT7921U (USB) wireless driver"); - MODULE_AUTHOR("Lorenzo Bianconi "); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7925/main.c -+++ b/mt7925/main.c -@@ -14,7 +14,7 @@ - static void - mt7925_init_he_caps(struct mt792x_phy *phy, enum nl80211_band band, - struct ieee80211_sband_iftype_data *data, -- enum nl80211_iftype iftype) -+ enum nl80211_iftype iftype) - { - struct ieee80211_sta_he_cap *he_cap = &data->he_cap; - struct ieee80211_he_cap_elem *he_cap_elem = &he_cap->he_cap_elem; -@@ -53,7 +53,7 @@ mt7925_init_he_caps(struct mt792x_phy *p - IEEE80211_HE_PHY_CAP2_UL_MU_FULL_MU_MIMO | - IEEE80211_HE_PHY_CAP2_UL_MU_PARTIAL_MU_MIMO; - -- switch (i) { -+ switch (iftype) { - case NL80211_IFTYPE_AP: - he_cap_elem->mac_cap_info[2] |= - IEEE80211_HE_MAC_CAP2_BSR; -@@ -1470,4 +1470,5 @@ const struct ieee80211_ops mt7925_ops = - EXPORT_SYMBOL_GPL(mt7925_ops); - - MODULE_AUTHOR("Deren Wu "); -+MODULE_DESCRIPTION("MediaTek MT7925 core driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7925/pci.c -+++ b/mt7925/pci.c -@@ -586,4 +586,5 @@ MODULE_FIRMWARE(MT7925_FIRMWARE_WM); - MODULE_FIRMWARE(MT7925_ROM_PATCH); - MODULE_AUTHOR("Deren Wu "); - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT7925E (PCIe) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt7925/usb.c -+++ b/mt7925/usb.c -@@ -329,4 +329,5 @@ static struct usb_driver mt7925u_driver - module_usb_driver(mt7925u_driver); - - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT7925U (USB) wireless driver"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/mt792x_core.c -+++ b/mt792x_core.c -@@ -685,9 +685,10 @@ mt792x_get_mac80211_ops(struct device *d - if (!(*fw_features & MT792x_FW_CAP_CNM)) { - ops->remain_on_channel = NULL; - ops->cancel_remain_on_channel = NULL; -- ops->add_chanctx = NULL; -- ops->remove_chanctx = NULL; -- ops->change_chanctx = NULL; -+ ops->add_chanctx = ieee80211_emulate_add_chanctx; -+ ops->remove_chanctx = ieee80211_emulate_remove_chanctx; -+ ops->change_chanctx = ieee80211_emulate_change_chanctx; -+ ops->switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx; - ops->assign_vif_chanctx = NULL; - ops->unassign_vif_chanctx = NULL; - ops->mgd_prepare_tx = NULL; -@@ -863,5 +864,6 @@ int mt792x_load_firmware(struct mt792x_d - } - EXPORT_SYMBOL_GPL(mt792x_load_firmware); - -+MODULE_DESCRIPTION("MediaTek MT792x core driver"); - MODULE_LICENSE("Dual BSD/GPL"); - MODULE_AUTHOR("Lorenzo Bianconi "); ---- a/mt792x_usb.c -+++ b/mt792x_usb.c -@@ -312,5 +312,6 @@ void mt792xu_disconnect(struct usb_inter - } - EXPORT_SYMBOL_GPL(mt792xu_disconnect); - -+MODULE_DESCRIPTION("MediaTek MT792x USB helpers"); - MODULE_LICENSE("Dual BSD/GPL"); - MODULE_AUTHOR("Lorenzo Bianconi "); ---- a/mt7996/init.c -+++ b/mt7996/init.c -@@ -4,9 +4,10 @@ - */ - - #include --#include -+#include - #include - #include -+#include - #include "mt7996.h" - #include "mac.h" - #include "mcu.h" -@@ -1278,8 +1279,7 @@ __mt7996_set_stream_he_eht_caps(struct m - n++; - } - -- sband->iftype_data = data; -- sband->n_iftype_data = n; -+ _ieee80211_set_sband_iftype_data(sband, data, n); - } - - void mt7996_set_stream_he_eht_caps(struct mt7996_phy *phy) ---- a/mt7996/main.c -+++ b/mt7996/main.c -@@ -1467,6 +1467,10 @@ mt7996_net_fill_forward_path(struct ieee - #endif - - const struct ieee80211_ops mt7996_ops = { -+ .add_chanctx = ieee80211_emulate_add_chanctx, -+ .remove_chanctx = ieee80211_emulate_remove_chanctx, -+ .change_chanctx = ieee80211_emulate_change_chanctx, -+ .switch_vif_chanctx = ieee80211_emulate_switch_vif_chanctx, - .tx = mt7996_tx, - .start = mt7996_start, - .stop = mt7996_stop, ---- a/mt7996/mcu.c -+++ b/mt7996/mcu.c -@@ -341,7 +341,7 @@ mt7996_mcu_csa_finish(void *priv, u8 *ma - if (!vif->bss_conf.csa_active || vif->type == NL80211_IFTYPE_STATION) - return; - -- ieee80211_csa_finish(vif); -+ ieee80211_csa_finish(vif, 0); - } - - static void ---- a/mt7996/mmio.c -+++ b/mt7996/mmio.c -@@ -670,4 +670,5 @@ static void __exit mt7996_exit(void) - - module_init(mt7996_init); - module_exit(mt7996_exit); -+MODULE_DESCRIPTION("MediaTek MT7996 MMIO helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/sdio.c -+++ b/sdio.c -@@ -677,4 +677,5 @@ EXPORT_SYMBOL_GPL(mt76s_init); - - MODULE_AUTHOR("Sean Wang "); - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT76x SDIO helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/usb.c -+++ b/usb.c -@@ -286,8 +286,7 @@ static bool mt76u_check_sg(struct mt76_d - struct usb_device *udev = interface_to_usbdev(uintf); - - return (!disable_usb_sg && udev->bus->sg_tablesize > 0 && -- (udev->bus->no_sg_constraint || -- udev->speed == USB_SPEED_WIRELESS)); -+ udev->bus->no_sg_constraint); - } - - static int -@@ -1136,4 +1135,5 @@ int mt76u_init(struct mt76_dev *dev, str - EXPORT_SYMBOL_GPL(mt76u_init); - - MODULE_AUTHOR("Lorenzo Bianconi "); -+MODULE_DESCRIPTION("MediaTek MT76x USB helpers"); - MODULE_LICENSE("Dual BSD/GPL"); ---- a/util.c -+++ b/util.c -@@ -138,4 +138,5 @@ int __mt76_worker_fn(void *ptr) - } - EXPORT_SYMBOL_GPL(__mt76_worker_fn); - -+MODULE_DESCRIPTION("MediaTek MT76x helpers"); - MODULE_LICENSE("Dual BSD/GPL");