mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-17 02:10:10 +00:00
323e249ce8
This updates mac80211 to version 6.1.97-1. This code is based on Linux 6.1.97 and contains all fixes included in the upstream wireless subsystem from that kernel version. This includes many bugfixes and also some security fixes. The removed patches are already integrated in upstream Linux 6.1.97 or in backports. The following patches were integrated in upstream Linux: ath11k/0013-wifi-ath11k-synchronize-ath11k_mac_he_gi_to_nl80211_.patch ath11k/0035-wifi-ath11k-Use-platform_get_irq-to-get-the-interrup.patch ath11k/0036-wifi-ath11k-fix-SAC-bug-on-peer-addition-with-sta-ba.patch ath11k/0047-wifi-ath11k-fix-deinitialization-of-firmware-resourc.patch ath11k/0053-wifi-ath11k-fix-writing-to-unintended-memory-region.patch ath11k/0060-wifi-ath11k-Ignore-frags-from-uninitialized-peer-in-.patch ath11k/0065-wifi-ath11k-fix-tx-status-reporting-in-encap-offload.patch ath11k/0067-wifi-ath11k-Fix-SKB-corruption-in-REO-destination-ri.patch ath11k/0069-wifi-ath11k-fix-registration-of-6Ghz-only-phy-withou.patch ath11k/0080-wifi-ath11k-add-support-default-regdb-while-searchin.patch ath11k/0085-wifi-ath11k-fix-memory-leak-in-WMI-firmware-stats.patch ath11k/0086-wifi-ath11k-Add-missing-check-for-ioremap.patch ath11k/0096-wifi-ath11k-fix-boot-failure-with-one-MSI-vector.patch subsys/337-wifi-mac80211-fix-race-condition-on-enabling-fast-xm.patch The following patches were integrated in upstream backports: ath11k/901-wifi-ath11k-pci-fix-compilation-in-5.16-and-older.patch build/080-resv_start_op.patch build/110-backport_napi_build_skb.patch The following files are missing in backports, we do not have to remove them any more. Some were already missing before some were removed in this update: include/linux/cordic.h include/linux/crc8.h include/linux/eeprom_93cx6.h include/linux/wl12xx.h include/net/ieee80211.h backport-include/linux/bcm47xx_nvram.h include/linux/ath9k_platform.h include/net/bluetooth/ backports ships a dummy Mediatek wed header for older kernel versions. We backported the feature in our kernel, remove the dummy header: backport-include/linux/soc/mediatek/mtk_wed.h Remove header files for subsystems used form the mainline kernel: include/trace/events/qrtr.h include/net/rsi_91x.h backport-include/linux/platform_data/brcmnand.h Link: https://github.com/openwrt/openwrt/pull/15827 Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
108 lines
3.8 KiB
Diff
108 lines
3.8 KiB
Diff
From 2cc25e4b2a04cdd90dbb2916678745565cc4aeed Mon Sep 17 00:00:00 2001
|
|
From: Aloka Dixit <quic_alokad@quicinc.com>
|
|
Date: Mon, 30 Jan 2023 16:12:27 -0800
|
|
Subject: [PATCH] wifi: mac80211: configure puncturing bitmap
|
|
|
|
- Configure the bitmap in link_conf and notify the driver.
|
|
- Modify 'change' in ieee80211_start_ap() from u32 to u64 to support
|
|
BSS_CHANGED_EHT_PUNCTURING.
|
|
- Propagate the bitmap in channel switch events to userspace.
|
|
|
|
Signed-off-by: Aloka Dixit <quic_alokad@quicinc.com>
|
|
Signed-off-by: Muna Sinada <quic_msinada@quicinc.com>
|
|
Link: https://lore.kernel.org/r/20230131001227.25014-5-quic_alokad@quicinc.com
|
|
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
|
|
---
|
|
include/net/mac80211.h | 3 +++
|
|
net/mac80211/cfg.c | 22 +++++++++++++++++++---
|
|
2 files changed, 22 insertions(+), 3 deletions(-)
|
|
|
|
--- a/include/net/mac80211.h
|
|
+++ b/include/net/mac80211.h
|
|
@@ -645,6 +645,7 @@ struct ieee80211_fils_discovery {
|
|
* @csa_active: marks whether a channel switch is going on. Internally it is
|
|
* write-protected by sdata_lock and local->mtx so holding either is fine
|
|
* for read access.
|
|
+ * @csa_punct_bitmap: new puncturing bitmap for channel switch
|
|
* @mu_mimo_owner: indicates interface owns MU-MIMO capability
|
|
* @chanctx_conf: The channel context this interface is assigned to, or %NULL
|
|
* when it is not assigned. This pointer is RCU-protected due to the TX
|
|
@@ -744,6 +745,8 @@ struct ieee80211_bss_conf {
|
|
u16 eht_puncturing;
|
|
|
|
bool csa_active;
|
|
+ u16 csa_punct_bitmap;
|
|
+
|
|
bool mu_mimo_owner;
|
|
struct ieee80211_chanctx_conf __rcu *chanctx_conf;
|
|
|
|
--- a/net/mac80211/cfg.c
|
|
+++ b/net/mac80211/cfg.c
|
|
@@ -1223,7 +1223,7 @@ static int ieee80211_start_ap(struct wip
|
|
struct ieee80211_local *local = sdata->local;
|
|
struct beacon_data *old;
|
|
struct ieee80211_sub_if_data *vlan;
|
|
- u32 changed = BSS_CHANGED_BEACON_INT |
|
|
+ u64 changed = BSS_CHANGED_BEACON_INT |
|
|
BSS_CHANGED_BEACON_ENABLED |
|
|
BSS_CHANGED_BEACON |
|
|
BSS_CHANGED_P2P_PS |
|
|
@@ -1310,6 +1310,11 @@ static int ieee80211_start_ap(struct wip
|
|
IEEE80211_HE_PHY_CAP2_UL_MU_FULL_MU_MIMO;
|
|
}
|
|
|
|
+ if (params->eht_cap) {
|
|
+ link_conf->eht_puncturing = params->punct_bitmap;
|
|
+ changed |= BSS_CHANGED_EHT_PUNCTURING;
|
|
+ }
|
|
+
|
|
if (sdata->vif.type == NL80211_IFTYPE_AP &&
|
|
params->mbssid_config.tx_wdev) {
|
|
err = ieee80211_set_ap_mbssid_options(sdata,
|
|
@@ -3569,6 +3574,12 @@ static int __ieee80211_csa_finalize(stru
|
|
lockdep_assert_held(&local->mtx);
|
|
lockdep_assert_held(&local->chanctx_mtx);
|
|
|
|
+ if (sdata->vif.bss_conf.eht_puncturing != sdata->vif.bss_conf.csa_punct_bitmap) {
|
|
+ sdata->vif.bss_conf.eht_puncturing =
|
|
+ sdata->vif.bss_conf.csa_punct_bitmap;
|
|
+ changed |= BSS_CHANGED_EHT_PUNCTURING;
|
|
+ }
|
|
+
|
|
/*
|
|
* using reservation isn't immediate as it may be deferred until later
|
|
* with multi-vif. once reservation is complete it will re-schedule the
|
|
@@ -3611,7 +3622,7 @@ static int __ieee80211_csa_finalize(stru
|
|
return err;
|
|
|
|
cfg80211_ch_switch_notify(sdata->dev, &sdata->deflink.csa_chandef, 0,
|
|
- 0);
|
|
+ sdata->vif.bss_conf.eht_puncturing);
|
|
|
|
return 0;
|
|
}
|
|
@@ -3873,9 +3884,13 @@ __ieee80211_channel_switch(struct wiphy
|
|
goto out;
|
|
}
|
|
|
|
+ if (params->punct_bitmap && !sdata->vif.bss_conf.eht_support)
|
|
+ goto out;
|
|
+
|
|
sdata->deflink.csa_chandef = params->chandef;
|
|
sdata->deflink.csa_block_tx = params->block_tx;
|
|
sdata->vif.bss_conf.csa_active = true;
|
|
+ sdata->vif.bss_conf.csa_punct_bitmap = params->punct_bitmap;
|
|
|
|
if (sdata->deflink.csa_block_tx)
|
|
ieee80211_stop_vif_queues(local, sdata,
|
|
@@ -3883,7 +3898,8 @@ __ieee80211_channel_switch(struct wiphy
|
|
|
|
cfg80211_ch_switch_started_notify(sdata->dev,
|
|
&sdata->deflink.csa_chandef, 0,
|
|
- params->count, params->block_tx, 0);
|
|
+ params->count, params->block_tx,
|
|
+ sdata->vif.bss_conf.csa_punct_bitmap);
|
|
|
|
if (changed) {
|
|
ieee80211_link_info_change_notify(sdata, &sdata->deflink,
|