wifi: ath11k: Remove disabling of 80+80 and 160 MHz
authorMuna Sinada <quic_msinada@quicinc.com>
Mon, 17 Apr 2023 20:22:27 +0000 (13:22 -0700)
committerKalle Valo <quic_kvalo@quicinc.com>
Wed, 19 Apr 2023 14:27:23 +0000 (17:27 +0300)
This is a regression fix for 80+80 and 160 MHz support bits being
cleared, therefore not adverised. Remove disable of 80+80 and 160 MHz
capability flags and assign valid center frequency 2 similar to
VHT80_80.

Fixes: 38dfe775d0ab ("wifi: ath11k: push MU-MIMO params from hostapd to hardware")
Reported-by: Robert Marko <robert.marko@sartura.hr>
Tested-by: Robert Marko <robert.marko@sartura.hr> # IPQ8074 WLAN.HK.2.9.0.1-01385-QCAHKSWPL_SILICONZ-1
Link: https://bugzilla.kernel.org/show_bug.cgi?id=217299
Co-developed-by: P Praneesh <quic_ppranees@quicinc.com>
Signed-off-by: P Praneesh <quic_ppranees@quicinc.com>
Signed-off-by: Muna Sinada <quic_msinada@quicinc.com>
Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://lore.kernel.org/r/1681762947-13882-1-git-send-email-quic_msinada@quicinc.com
drivers/net/wireless/ath/ath11k/mac.c
drivers/net/wireless/ath/ath11k/wmi.c

index 4447fd4..1c93f1a 100644 (file)
@@ -5585,10 +5585,6 @@ static int ath11k_mac_copy_he_cap(struct ath11k *ar,
 
                he_cap_elem->mac_cap_info[1] &=
                        IEEE80211_HE_MAC_CAP1_TF_MAC_PAD_DUR_MASK;
-               he_cap_elem->phy_cap_info[0] &=
-                       ~IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_160MHZ_IN_5G;
-               he_cap_elem->phy_cap_info[0] &=
-                       ~IEEE80211_HE_PHY_CAP0_CHANNEL_WIDTH_SET_80PLUS80_MHZ_IN_5G;
 
                he_cap_elem->phy_cap_info[5] &=
                        ~IEEE80211_HE_PHY_CAP5_BEAMFORMEE_NUM_SND_DIM_UNDER_80MHZ_MASK;
index f338d44..d0b59bc 100644 (file)
@@ -871,7 +871,8 @@ static void ath11k_wmi_put_wmi_channel(struct wmi_channel *chan,
 
                chan->band_center_freq2 = arg->channel.band_center_freq1;
 
-       } else if (arg->channel.mode == MODE_11AC_VHT80_80) {
+       } else if ((arg->channel.mode == MODE_11AC_VHT80_80) ||
+                  (arg->channel.mode == MODE_11AX_HE80_80)) {
                chan->band_center_freq2 = arg->channel.band_center_freq2;
        } else {
                chan->band_center_freq2 = 0;