Path: blob/main/sys/contrib/dev/iwlwifi/cfg/rf-jf.c
48372 views
// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause1/*2* Copyright (C) 2015-2017 Intel Deutschland GmbH3* Copyright (C) 2018-2021, 2023, 2025 Intel Corporation4*/5#include "iwl-config.h"67/* Highest firmware API version supported */8#define IWL_JF_UCODE_API_MAX 77910/* Lowest firmware API version supported */11#define IWL_JF_UCODE_API_MIN 771213#define IWL_QU_B_JF_B_FW_PRE "iwlwifi-Qu-b0-jf-b0"14#define IWL_QU_C_JF_B_FW_PRE "iwlwifi-Qu-c0-jf-b0"15#define IWL_QUZ_A_JF_B_FW_PRE "iwlwifi-QuZ-a0-jf-b0"16#define IWL_SO_A_JF_B_FW_PRE "iwlwifi-so-a0-jf-b0"1718#define IWL_QUZ_A_JF_B_MODULE_FIRMWARE(api) \19IWL_QUZ_A_JF_B_FW_PRE "-" __stringify(api) ".ucode"20#define IWL_QU_B_JF_B_MODULE_FIRMWARE(api) \21IWL_QU_B_JF_B_FW_PRE "-" __stringify(api) ".ucode"22#define IWL_QU_C_JF_B_MODULE_FIRMWARE(api) \23IWL_QU_C_JF_B_FW_PRE "-" __stringify(api) ".ucode"24#define IWL_SO_A_JF_B_MODULE_FIRMWARE(api) \25IWL_SO_A_JF_B_FW_PRE "-" __stringify(api) ".ucode"2627/* NVM versions */28#define IWL_JF_NVM_VERSION 0x0a1d2930/* Memory offsets and lengths */31#define IWL9000_DCCM_OFFSET 0x80000032#define IWL9000_DCCM_LEN 0x1800033#define IWL9000_DCCM2_OFFSET 0x88000034#define IWL9000_DCCM2_LEN 0x80003536static const struct iwl_tt_params iwl_jf_tt_params = {37.ct_kill_entry = 115,38.ct_kill_exit = 93,39.ct_kill_duration = 5,40.dynamic_smps_entry = 111,41.dynamic_smps_exit = 107,42.tx_protection_entry = 112,43.tx_protection_exit = 105,44.tx_backoff = {45{.temperature = 110, .backoff = 200},46{.temperature = 111, .backoff = 600},47{.temperature = 112, .backoff = 1200},48{.temperature = 113, .backoff = 2000},49{.temperature = 114, .backoff = 4000},50},51.support_ct_kill = true,52.support_dynamic_smps = true,53.support_tx_protection = true,54.support_tx_backoff = true,55};5657/* these values are ignored if not with Pu/Th MAC firmware, due to offload */58#define IWL_DEVICE_JF_PU \59.dccm_offset = IWL9000_DCCM_OFFSET, \60.dccm_len = IWL9000_DCCM_LEN, \61.dccm2_offset = IWL9000_DCCM2_OFFSET, \62.dccm2_len = IWL9000_DCCM2_LEN, \63.thermal_params = &iwl_jf_tt_params6465#define IWL_DEVICE_JF \66IWL_DEVICE_JF_PU, \67.led_mode = IWL_LED_RF_STATE, \68.non_shared_ant = ANT_B, \69.num_rbds = IWL_NUM_RBDS_NON_HE, \70.vht_mu_mimo_supported = true, \71.ht_params = { \72.stbc = true, \73.ldpc = true, \74.ht40_bands = BIT(NL80211_BAND_2GHZ) | \75BIT(NL80211_BAND_5GHZ), \76}, \77.nvm_ver = IWL_JF_NVM_VERSION, \78.nvm_type = IWL_NVM_EXT, \79.ucode_api_min = IWL_JF_UCODE_API_MIN, \80.ucode_api_max = IWL_JF_UCODE_API_MAX8182const struct iwl_rf_cfg iwl_rf_jf = {83IWL_DEVICE_JF,84};8586const struct iwl_rf_cfg iwl_rf_jf_80mhz = {87IWL_DEVICE_JF,88.bw_limit = 80,89};9091const char iwl9260_name[] = "Intel(R) Wireless-AC 9260";92const char iwl9461_name[] = "Intel(R) Wireless-AC 9461";93const char iwl9462_name[] = "Intel(R) Wireless-AC 9462";94const char iwl9560_name[] = "Intel(R) Wireless-AC 9560";95const char iwl9260_160_name[] = "Intel(R) Wireless-AC 9260 160MHz";96const char iwl9461_160_name[] = "Intel(R) Wireless-AC 9461 160MHz";97const char iwl9462_160_name[] = "Intel(R) Wireless-AC 9462 160MHz";98const char iwl9560_160_name[] = "Intel(R) Wireless-AC 9560 160MHz";99100const char iwl9260_killer_1550_name[] =101"Killer(R) Wireless-AC 1550 Wireless Network Adapter (9260NGW) 160MHz";102const char iwl9560_killer_1550i_name[] =103"Killer(R) Wireless-AC 1550i Wireless Network Adapter (9560NGW) 160MHz";104const char iwl9560_killer_1550s_name[] =105"Killer(R) Wireless-AC 1550s Wireless Network Adapter (9560D2W) 160MHz";106107MODULE_FIRMWARE(IWL_QU_B_JF_B_MODULE_FIRMWARE(IWL_JF_UCODE_API_MAX));108MODULE_FIRMWARE(IWL_QU_C_JF_B_MODULE_FIRMWARE(IWL_JF_UCODE_API_MAX));109MODULE_FIRMWARE(IWL_QUZ_A_JF_B_MODULE_FIRMWARE(IWL_JF_UCODE_API_MAX));110MODULE_FIRMWARE(IWL_SO_A_JF_B_MODULE_FIRMWARE(IWL_JF_UCODE_API_MAX));111112113