[<prev] [next>] [day] [month] [year] [list]
Message-Id: <20250604005531.4178547-16-sashal@kernel.org>
Date: Tue,  3 Jun 2025 20:53:59 -0400
From: Sasha Levin <sashal@...nel.org>
To: patches@...ts.linux.dev,
	stable@...r.kernel.org
Cc: Samuel Williams <sam8641@...il.com>,
	Felix Fietkau <nbd@....name>,
	Sasha Levin <sashal@...nel.org>,
	matthias.bgg@...il.com,
	angelogioacchino.delregno@...labora.com,
	sean.wang@...iatek.com,
	deren.wu@...iatek.com,
	mingyen.hsieh@...iatek.com,
	johannes.berg@...el.com,
	allan.wang@...iatek.com,
	michael.lo@...iatek.com,
	leon.yen@...iatek.com,
	linux-kernel@...r.kernel.org,
	linux-arm-kernel@...ts.infradead.org,
	linux-mediatek@...ts.infradead.org
Subject: [PATCH AUTOSEL 6.14 016/108] wifi: mt76: mt7921: add 160 MHz AP for mt7922 device
From: Samuel Williams <sam8641@...il.com>
[ Upstream commit 7011faebe543f8f094fdb3281d0ec9e1eab81309 ]
This allows mt7922 in hostapd mode to transmit up to 1.4 Gbps.
Signed-off-by: Samuel Williams <sam8641@...il.com>
Link: https://patch.msgid.link/20250511005316.1118961-1-sam8641@gmail.com
Signed-off-by: Felix Fietkau <nbd@....name>
Signed-off-by: Sasha Levin <sashal@...nel.org>
---
**YES** This commit should be backported to stable kernel trees. ##
Extensive Analysis ### Code Change Analysis The commit adds 160 MHz AP
support for the mt7922 device by modifying HE (High Efficiency)
capabilities in the `mt7921_init_he_caps()` function in
`drivers/net/wireless/mediatek/mt76/mt7921/main.c`. The change is
minimal and surgical: ```c if (is_mt7922(phy->mt76->dev)) {
he_cap_elem->phy_cap_info[0] |=
IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G; } ``` This single
addition enables 160 MHz channel width support specifically for mt7922
devices in AP mode, complementing the existing 160 MHz support that was
already present for station mode. ### Why This Should Be Backported **1.
Safe and Contained Change** - The modification is gated behind a device-
specific check (`is_mt7922()`) - Only affects mt7922 hardware, with zero
impact on other devices - Uses standard IEEE 802.11ax capability flags
that are well-defined and widely supported - No core functionality
changes - only capability advertisement **2. Follows Stable Tree
Criteria** - **Important bugfix**: This enables a hardware capability
that was artificially disabled in software - **Minimal risk**: Standard
capability flag with well-understood behavior - **No architectural
changes**: Simple capability enablement - **Confined to subsystem**:
Only affects mt76 WiFi driver **3. Historical Precedent** Looking at the
similar commits provided, this change follows the same pattern as commit
#4 ("mt76: mt7921: introduce 160 MHz channel bandwidth support") which
added 160 MHz support for station mode. The current commit simply
extends this to AP mode, completing the feature set. **4. Low Risk
Profile** - **No security implications**: Capability advertisement only,
no new attack vectors - **Graceful degradation**: If 160 MHz doesn't
work properly, it will fall back to lower bandwidths - **Standard
compliance**: Uses IEEE 802.11 standard capability bits - **Easy
reversal**: Simple to revert if issues arise **5. Clear User Benefit** -
Enables up to 1.4 Gbps throughput in hostapd mode (as stated in commit
message) - Unlocks full hardware capabilities for mt7922 users -
Improves performance for users with 160 MHz-capable infrastructure ###
Technical Safety Assessment The change is extremely low-risk because: 1.
It only modifies capability advertisement, not operational code paths 2.
The IEEE 802.11 stack handles 160 MHz operations robustly 3. Regulatory
compliance is handled by existing regulatory domain code 4. The mt7922
hardware already supports 160 MHz (firmware/hardware capability) ###
Comparison with Similar Commits Unlike the provided examples (which were
marked "NO" for various reasons like being new features, architectural
changes, or adding new channel support), this commit: - Fixes an
existing limitation rather than adding new functionality - Has minimal
code impact - Follows established patterns for capability enablement -
Represents a straightforward bug fix (capability mismatch between
hardware and software) This commit exemplifies an ideal stable tree
candidate: it's a small, safe change that fixes a real user-impacting
issue (artificial performance limitation) without introducing new risks
or architectural complexity.
 drivers/net/wireless/mediatek/mt76/mt7921/main.c | 5 +++++
 1 file changed, 5 insertions(+)
diff --git a/drivers/net/wireless/mediatek/mt76/mt7921/main.c b/drivers/net/wireless/mediatek/mt76/mt7921/main.c
index 78b77a54d1957..6b35769fc62b8 100644
--- a/drivers/net/wireless/mediatek/mt76/mt7921/main.c
+++ b/drivers/net/wireless/mediatek/mt76/mt7921/main.c
@@ -83,6 +83,11 @@ mt7921_init_he_caps(struct mt792x_phy *phy, enum nl80211_band band,
 			he_cap_elem->phy_cap_info[9] |=
 				IEEE80211_HE_PHY_CAP9_TX_1024_QAM_LESS_THAN_242_TONE_RU |
 				IEEE80211_HE_PHY_CAP9_RX_1024_QAM_LESS_THAN_242_TONE_RU;
+
+			if (is_mt7922(phy->mt76->dev)) {
+				he_cap_elem->phy_cap_info[0] |=
+					IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G;
+			}
 			break;
 		case NL80211_IFTYPE_STATION:
 			he_cap_elem->mac_cap_info[1] |=
-- 
2.39.5
Powered by blists - more mailing lists
 
