mt76: update to Git HEAD (2024-07-13)
authorFelix Fietkau <nbd@nbd.name>
Sat, 13 Jul 2024 13:31:11 +0000 (15:31 +0200)
committerFelix Fietkau <nbd@nbd.name>
Sat, 13 Jul 2024 13:31:32 +0000 (15:31 +0200)
564cd93961fc mt76: sync with upstream changes
3b47d9df427c wifi: mt76: mt7915: fix oops on non-dbdc mt7986

Signed-off-by: Felix Fietkau <nbd@nbd.name>
package/kernel/mt76/Makefile
package/kernel/mt76/patches/100-api_changes.patch [deleted file]

index c6cce9cf9c67490cb4a8c524320dac3c84cb607d..f71070dbb9072f96c5036748481471c40dee8edc 100644 (file)
@@ -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 <nbd@nbd.name>
 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 (file)
index de81614..0000000
+++ /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 <sean.wang@mediatek.com>");
- MODULE_AUTHOR("Lorenzo Bianconi <lorenzo@kernel.org>");
-+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 <sean.wang@mediatek.com>");
- MODULE_AUTHOR("Lorenzo Bianconi <lorenzo@kernel.org>");
-+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 <lorenzo@kernel.org>");
- MODULE_AUTHOR("Sean Wang <sean.wang@mediatek.com>");
-+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 <lorenzo@kernel.org>");
-+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 <lorenzo.bianconi83@gmail.com>");
-+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 <lorenzo.bianconi83@gmail.com>");
-+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 <linux/etherdevice.h>
- #include <linux/hwmon.h>
- #include <linux/hwmon-sysfs.h>
-+#include <linux/of.h>
- #include <linux/thermal.h>
- #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 <sean.wang@mediatek.com>");
---- 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 <sean.wang@mediatek.com>");
- MODULE_AUTHOR("Lorenzo Bianconi <lorenzo@kernel.org>");
-+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 <sean.wang@mediatek.com>");
- 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 <lorenzo@kernel.org>");
- 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 <deren.wu@mediatek.com>");
-+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 <deren.wu@mediatek.com>");
- MODULE_AUTHOR("Lorenzo Bianconi <lorenzo@kernel.org>");
-+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 <lorenzo@kernel.org>");
-+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 <lorenzo@kernel.org>");
---- 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 <lorenzo@kernel.org>");
---- a/mt7996/init.c
-+++ b/mt7996/init.c
-@@ -4,9 +4,10 @@
-  */
- #include <linux/etherdevice.h>
--#include <linux/thermal.h>
-+#include <linux/of.h>
- #include <linux/hwmon.h>
- #include <linux/hwmon-sysfs.h>
-+#include <linux/thermal.h>
- #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 <sean.wang@mediatek.com>");
- MODULE_AUTHOR("Lorenzo Bianconi <lorenzo@kernel.org>");
-+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 <lorenzo.bianconi83@gmail.com>");
-+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");