]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
wifi: iwlwifi: mvm: don't limit VLP/AFC to UATS-enabled
authorJohannes Berg <johannes.berg@intel.com>
Tue, 18 Jun 2024 16:59:45 +0000 (19:59 +0300)
committerJohannes Berg <johannes.berg@intel.com>
Wed, 26 Jun 2024 08:28:51 +0000 (10:28 +0200)
When UATS isn't enabled (no VLP/AFC AP support), we need to still
set the right bits in the channel/regulatory flags, so remove the
uats_enabled argument to the parsing etc.

Also, firmware deals just fine with getting the UATS table if it
supports the command even if the bits aren't set, so always send
it, since it's also needed if BIT(31) is set, but the driver need
not have any knowledge of that. Remove 'uats_enabled' entirely.

Fixes: 0d2fc8821a7d ("wifi: iwlwifi: nvm: parse the VLP/AFC bit from regulatory")
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
Signed-off-by: Miri Korenblit <miriam.rachel.korenblit@intel.com>
Link: https://patch.msgid.link/20240618195731.a81e7234c4f6.Ic0131180d38e0f1ead2f7fa0e7583407ceaa0bd1@changeid
Signed-off-by: Johannes Berg <johannes.berg@intel.com>
drivers/net/wireless/intel/iwlwifi/fw/runtime.h
drivers/net/wireless/intel/iwlwifi/iwl-nvm-parse.c
drivers/net/wireless/intel/iwlwifi/iwl-nvm-parse.h
drivers/net/wireless/intel/iwlwifi/mvm/fw.c
drivers/net/wireless/intel/iwlwifi/mvm/mac80211.c

index 3fcc08b3c0db007c789065cfeed45c6c62b2120e..048877fa7c71a499172f365dc1207a6b5664c0c4 100644 (file)
@@ -103,7 +103,6 @@ struct iwl_txf_iter_data {
  * @cur_fw_img: current firmware image, must be maintained by
  *     the driver by calling &iwl_fw_set_current_image()
  * @dump: debug dump data
- * @uats_enabled: VLP or AFC AP is enabled
  * @uats_table: AP type table
  * @uefi_tables_lock_status: The status of the WIFI GUID UEFI variables lock:
  *     0: Unlocked, 1 and 2: Locked.
@@ -183,7 +182,6 @@ struct iwl_fw_runtime {
        bool sgom_enabled;
        struct iwl_mcc_allowed_ap_type_cmd uats_table;
        u8 uefi_tables_lock_status;
-       bool uats_enabled;
 };
 
 void iwl_fw_runtime_init(struct iwl_fw_runtime *fwrt, struct iwl_trans *trans,
index c2656dee5a869f5fcbce5e3a5ca6b40bcbb60dba..d902121da009279a52ba667d0e074d32310e3e37 100644 (file)
@@ -1610,8 +1610,7 @@ IWL_EXPORT_SYMBOL(iwl_parse_nvm_data);
 static u32 iwl_nvm_get_regdom_bw_flags(const u16 *nvm_chan,
                                       int ch_idx, u16 nvm_flags,
                                       struct iwl_reg_capa reg_capa,
-                                      const struct iwl_cfg *cfg,
-                                      bool uats_enabled)
+                                      const struct iwl_cfg *cfg)
 {
        u32 flags = NL80211_RRF_NO_HT40;
 
@@ -1662,15 +1661,13 @@ static u32 iwl_nvm_get_regdom_bw_flags(const u16 *nvm_chan,
        }
 
        /* Set the AP type for the UHB case. */
-       if (uats_enabled) {
-               if (nvm_flags & NVM_CHANNEL_VLP)
-                       flags |= NL80211_RRF_ALLOW_6GHZ_VLP_AP;
-               else
-                       flags |= NL80211_RRF_NO_6GHZ_VLP_CLIENT;
+       if (nvm_flags & NVM_CHANNEL_VLP)
+               flags |= NL80211_RRF_ALLOW_6GHZ_VLP_AP;
+       else
+               flags |= NL80211_RRF_NO_6GHZ_VLP_CLIENT;
 
-               if (!(nvm_flags & NVM_CHANNEL_AFC))
-                       flags |= NL80211_RRF_NO_6GHZ_AFC_CLIENT;
-       }
+       if (!(nvm_flags & NVM_CHANNEL_AFC))
+               flags |= NL80211_RRF_NO_6GHZ_AFC_CLIENT;
 
        /*
         * reg_capa is per regulatory domain so apply it for every channel
@@ -1726,7 +1723,7 @@ static struct iwl_reg_capa iwl_get_reg_capa(u32 flags, u8 resp_ver)
 struct ieee80211_regdomain *
 iwl_parse_nvm_mcc_info(struct device *dev, const struct iwl_cfg *cfg,
                       int num_of_ch, __le32 *channels, u16 fw_mcc,
-                      u16 geo_info, u32 cap, u8 resp_ver, bool uats_enabled)
+                      u16 geo_info, u32 cap, u8 resp_ver)
 {
        int ch_idx;
        u16 ch_flags;
@@ -1793,7 +1790,7 @@ iwl_parse_nvm_mcc_info(struct device *dev, const struct iwl_cfg *cfg,
 
                reg_rule_flags = iwl_nvm_get_regdom_bw_flags(nvm_chan, ch_idx,
                                                             ch_flags, reg_capa,
-                                                            cfg, uats_enabled);
+                                                            cfg);
 
                /* we can't continue the same rule */
                if (ch_idx == 0 || prev_reg_rule_flags != reg_rule_flags ||
index 5a1b5ab62de152d27903bcf5ca2a94c23908f659..fd82feb24b2d57cc8c524273e022445ec5eb8071 100644 (file)
@@ -1,6 +1,6 @@
 /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
 /*
- * Copyright (C) 2005-2015, 2018-2023 Intel Corporation
+ * Copyright (C) 2005-2015, 2018-2024 Intel Corporation
  * Copyright (C) 2016-2017 Intel Deutschland GmbH
  */
 #ifndef __iwl_nvm_parse_h__
@@ -50,7 +50,7 @@ iwl_parse_nvm_data(struct iwl_trans *trans, const struct iwl_cfg *cfg,
 struct ieee80211_regdomain *
 iwl_parse_nvm_mcc_info(struct device *dev, const struct iwl_cfg *cfg,
                       int num_of_ch, __le32 *channels, u16 fw_mcc,
-                      u16 geo_info, u32 cap, u8 resp_ver, bool uats_enabled);
+                      u16 geo_info, u32 cap, u8 resp_ver);
 
 /**
  * struct iwl_nvm_section - describes an NVM section in memory.
index 0a8bd957bd6c3bf3b9254aa61ef6b76a4c34f1a9..ef5acecd11fc0d1be68705ee6a2c47ce1b80ff43 100644 (file)
@@ -28,9 +28,6 @@
 #define MVM_UCODE_ALIVE_TIMEOUT        (2 * HZ)
 #define MVM_UCODE_CALIB_TIMEOUT        (2 * HZ)
 
-#define IWL_UATS_VLP_AP_SUPPORTED BIT(29)
-#define IWL_UATS_AFC_AP_SUPPORTED BIT(30)
-
 struct iwl_mvm_alive_data {
        bool valid;
        u32 scd_base_addr;
@@ -491,17 +488,11 @@ static void iwl_mvm_uats_init(struct iwl_mvm *mvm)
                .dataflags[0] = IWL_HCMD_DFL_NOCOPY,
        };
 
-       if (!(mvm->trans->trans_cfg->device_family >=
-             IWL_DEVICE_FAMILY_AX210)) {
+       if (mvm->trans->trans_cfg->device_family < IWL_DEVICE_FAMILY_AX210) {
                IWL_DEBUG_RADIO(mvm, "UATS feature is not supported\n");
                return;
        }
 
-       if (!mvm->fwrt.uats_enabled) {
-               IWL_DEBUG_RADIO(mvm, "UATS feature is disabled\n");
-               return;
-       }
-
        cmd_ver = iwl_fw_lookup_cmd_ver(mvm->fw, cmd.id,
                                        IWL_FW_CMD_VER_UNKNOWN);
        if (cmd_ver != 1) {
@@ -1223,10 +1214,6 @@ static void iwl_mvm_lari_cfg(struct iwl_mvm *mvm)
                                        "Failed to send LARI_CONFIG_CHANGE (%d)\n",
                                        ret);
        }
-
-       if (le32_to_cpu(cmd.oem_uhb_allow_bitmap) & IWL_UATS_VLP_AP_SUPPORTED ||
-           le32_to_cpu(cmd.oem_uhb_allow_bitmap) & IWL_UATS_AFC_AP_SUPPORTED)
-               mvm->fwrt.uats_enabled = true;
 }
 
 void iwl_mvm_get_bios_tables(struct iwl_mvm *mvm)
index 4f16ada07e2fe70ec4912a5a6bfd396a06c116c1..8c732becd2810b8fb4850a4ffe995e01f7ef129d 100644 (file)
@@ -151,8 +151,7 @@ struct ieee80211_regdomain *iwl_mvm_get_regdomain(struct wiphy *wiphy,
                                      resp->channels,
                                      __le16_to_cpu(resp->mcc),
                                      __le16_to_cpu(resp->geo_info),
-                                     le32_to_cpu(resp->cap), resp_ver,
-                                     mvm->fwrt.uats_enabled);
+                                     le32_to_cpu(resp->cap), resp_ver);
        /* Store the return source id */
        src_id = resp->source_id;
        if (IS_ERR_OR_NULL(regd)) {