wifi: ath12k: Fix issues in channel list update
authorSriram R <quic_srirrama@quicinc.com>
Wed, 17 Jan 2024 06:26:28 +0000 (11:56 +0530)
committerKalle Valo <quic_kvalo@quicinc.com>
Wed, 24 Jan 2024 10:16:42 +0000 (12:16 +0200)
Currently, the logic used to select the 6 GHz band is incorrect,
which may cause 6 GHz supported channels to not be updated properly.
This is because the 6 GHz Max frequency supported by the driver is
being compared to the Max frequency supported on the board. If in
some cases, the 6 GHz Max frequency supported on the board is less
than the defined 6 GHz Max frequency, all 6 GHz channels are disabled.
To address this, compare the max frequency supported by the board to
the defined 6 GHz Minimum frequency by the driver.

Similarly, when a dual mac card supports both 6 GHz and 5 GHz radios,
if the 5 GHz radio gets enumerated first before 6 GHz, the checks in
ath12k_mac_setup_channels_rates() can cause the 5 GHz channels which
were enabled earlier to get disabled when the 6 GHz channel list is
updated. This is because the Min 6 GHz frequency defined in the driver
is 5945 MHz, which should be 5925 MHz since channel 2 is not considered
currently, but the firmware can pass 5925 MHz as the minimum.
Hence, update the Min frequency supported by the driver to 5925 MHz.

In addition, ensure that the channel list update to firmware updates
only the channels that the current radio (ar) supports rather than
considering the wiphy support. This would be required when multiple pdevs
are supported in a wiphy and they support different ranges of frequencies
or bands as in single wiphy support.

Fixes: d889913205cf ("wifi: ath12k: driver for Qualcomm Wi-Fi 7 devices")
Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.0.1-00029-QCAHKSWPL_SILICONZ-1
Tested-on: QCN9274 hw2.0 PCI WLAN.WBE.1.1.1-00188-QCAHKSWPL_SILICONZ-1
Tested-on: WCN7850 hw2.0 PCI WLAN.HMT.1.0.c5-00481-QCAHMTSWPL_V1.0_V2.0_SILICONZ-3

Signed-off-by: Sriram R <quic_srirrama@quicinc.com>
Acked-by: Jeff Johnson <quic_jjohnson@quicinc.com>
Signed-off-by: Kalle Valo <quic_kvalo@quicinc.com>
Link: https://msgid.link/20240117062628.8260-1-quic_srirrama@quicinc.com
drivers/net/wireless/ath/ath12k/core.h
drivers/net/wireless/ath/ath12k/mac.c
drivers/net/wireless/ath/ath12k/reg.c

index a56fc74366b40136b90db7bed844b11f68744417..5c6c1e2eddb6c28751159c29ba8e7cc6bccb597d 100644 (file)
@@ -425,7 +425,7 @@ struct ath12k_sta {
 };
 
 #define ATH12K_MIN_5G_FREQ 4150
-#define ATH12K_MIN_6G_FREQ 5945
+#define ATH12K_MIN_6G_FREQ 5925
 #define ATH12K_MAX_6G_FREQ 7115
 #define ATH12K_NUM_CHANS 100
 #define ATH12K_MAX_5G_CHAN 173
index fe600dbef875ec77b5cb878e59541aa88bcf5f5a..a27480a69b27325d50a0c2350c8ae82a2971e1e0 100644 (file)
@@ -7394,7 +7394,7 @@ static int ath12k_mac_setup_channels_rates(struct ath12k *ar,
        }
 
        if (supported_bands & WMI_HOST_WLAN_5G_CAP) {
-               if (reg_cap->high_5ghz_chan >= ATH12K_MAX_6G_FREQ) {
+               if (reg_cap->high_5ghz_chan >= ATH12K_MIN_6G_FREQ) {
                        channels = kmemdup(ath12k_6ghz_channels,
                                           sizeof(ath12k_6ghz_channels), GFP_KERNEL);
                        if (!channels) {
index a164f15d1e2bbabd9d0ca5cfd13852431929867f..f308e9a6ed551d932925550441394d05dd37bfdd 100644 (file)
@@ -104,7 +104,7 @@ int ath12k_reg_update_chan_list(struct ath12k *ar)
 
        bands = hw->wiphy->bands;
        for (band = 0; band < NUM_NL80211_BANDS; band++) {
-               if (!bands[band])
+               if (!(ar->mac.sbands[band].channels && bands[band]))
                        continue;
 
                for (i = 0; i < bands[band]->n_channels; i++) {
@@ -130,7 +130,7 @@ int ath12k_reg_update_chan_list(struct ath12k *ar)
        ch = arg->channel;
 
        for (band = 0; band < NUM_NL80211_BANDS; band++) {
-               if (!bands[band])
+               if (!(ar->mac.sbands[band].channels && bands[band]))
                        continue;
 
                for (i = 0; i < bands[band]->n_channels; i++) {