Path: blob/main/sys/contrib/dev/iwlwifi/cfg/8000.c
48372 views
// SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause1/*2* Copyright (C) 2014, 2018-2020, 2023, 2025 Intel Corporation3* Copyright (C) 2014-2015 Intel Mobile Communications GmbH4* Copyright (C) 2016 Intel Deutschland GmbH5*/6#include <linux/module.h>7#include <linux/stringify.h>8#include "iwl-config.h"910/* Highest firmware API version supported */11#define IWL8000_UCODE_API_MAX 3612#define IWL8265_UCODE_API_MAX 361314/* Lowest firmware API version supported */15#define IWL8000_UCODE_API_MIN 2216#define IWL8265_UCODE_API_MIN 221718/* NVM versions */19#define IWL8000_NVM_VERSION 0x0a1d2021/* Memory offsets and lengths */22#define IWL8260_DCCM_OFFSET 0x80000023#define IWL8260_DCCM_LEN 0x1800024#define IWL8260_DCCM2_OFFSET 0x88000025#define IWL8260_DCCM2_LEN 0x800026#define IWL8260_SMEM_OFFSET 0x40000027#define IWL8260_SMEM_LEN 0x680002829#define IWL8000_FW_PRE "iwlwifi-8000C"30#define IWL8000_MODULE_FIRMWARE(api) \31IWL8000_FW_PRE "-" __stringify(api) ".ucode"3233#define IWL8265_FW_PRE "iwlwifi-8265"34#define IWL8265_MODULE_FIRMWARE(api) \35IWL8265_FW_PRE "-" __stringify(api) ".ucode"3637static const struct iwl_family_base_params iwl8000_base = {38.eeprom_size = OTP_LOW_IMAGE_SIZE_32K,39.num_of_queues = 31,40.max_tfd_queue_size = 256,41.shadow_ram_support = true,42.led_compensation = 57,43.wd_timeout = IWL_LONG_WD_TIMEOUT,44.max_event_log_size = 512,45.shadow_reg_enable = true,46.pcie_l1_allowed = true,47.nvm_hw_section_num = 10,48.features = NETIF_F_RXCSUM,49.smem_offset = IWL8260_SMEM_OFFSET,50.smem_len = IWL8260_SMEM_LEN,51.apmg_not_supported = true,52.min_umac_error_event_table = 0x800000,53};5455static const struct iwl_tt_params iwl8000_tt_params = {56.ct_kill_entry = 115,57.ct_kill_exit = 93,58.ct_kill_duration = 5,59.dynamic_smps_entry = 111,60.dynamic_smps_exit = 107,61.tx_protection_entry = 112,62.tx_protection_exit = 105,63.tx_backoff = {64{.temperature = 110, .backoff = 200},65{.temperature = 111, .backoff = 600},66{.temperature = 112, .backoff = 1200},67{.temperature = 113, .backoff = 2000},68{.temperature = 114, .backoff = 4000},69},70.support_ct_kill = true,71.support_dynamic_smps = true,72.support_tx_protection = true,73.support_tx_backoff = true,74};7576const struct iwl_mac_cfg iwl8000_mac_cfg = {77.device_family = IWL_DEVICE_FAMILY_8000,78.base = &iwl8000_base,79};8081#define IWL_DEVICE_8000_COMMON \82.led_mode = IWL_LED_RF_STATE, \83.non_shared_ant = ANT_A, \84.dccm_offset = IWL8260_DCCM_OFFSET, \85.dccm_len = IWL8260_DCCM_LEN, \86.dccm2_offset = IWL8260_DCCM2_OFFSET, \87.dccm2_len = IWL8260_DCCM2_LEN, \88.thermal_params = &iwl8000_tt_params, \89.nvm_type = IWL_NVM_EXT9091#define IWL_DEVICE_8260 \92IWL_DEVICE_8000_COMMON, \93.ucode_api_max = IWL8000_UCODE_API_MAX, \94.ucode_api_min = IWL8000_UCODE_API_MIN \9596#define IWL_DEVICE_8265 \97IWL_DEVICE_8000_COMMON, \98.ucode_api_max = IWL8265_UCODE_API_MAX, \99.ucode_api_min = IWL8265_UCODE_API_MIN \100101const char iwl8260_2n_name[] = "Intel(R) Dual Band Wireless-N 8260";102const char iwl8260_2ac_name[] = "Intel(R) Dual Band Wireless-AC 8260";103const char iwl8265_2ac_name[] = "Intel(R) Dual Band Wireless-AC 8265";104const char iwl8275_2ac_name[] = "Intel(R) Dual Band Wireless-AC 8275";105const char iwl4165_2ac_name[] = "Intel(R) Dual Band Wireless-AC 4165";106107const char iwl_killer_1435i_name[] =108"Killer(R) Wireless-AC 1435i Wireless Network Adapter (8265D2W)";109const char iwl_killer_1434_kix_name[] =110"Killer(R) Wireless-AC 1435-KIX Wireless Network Adapter (8265NGW)";111112const struct iwl_rf_cfg iwl8260_cfg = {113.fw_name_pre = IWL8000_FW_PRE,114IWL_DEVICE_8260,115.ht_params = {116.stbc = true,117.ldpc = true,118.ht40_bands = BIT(NL80211_BAND_2GHZ) | BIT(NL80211_BAND_5GHZ),119},120.nvm_ver = IWL8000_NVM_VERSION,121};122123const struct iwl_rf_cfg iwl8265_cfg = {124.fw_name_pre = IWL8265_FW_PRE,125IWL_DEVICE_8265,126.ht_params = {127.stbc = true,128.ldpc = true,129.ht40_bands = BIT(NL80211_BAND_2GHZ) | BIT(NL80211_BAND_5GHZ),130},131.nvm_ver = IWL8000_NVM_VERSION,132.vht_mu_mimo_supported = true,133};134135MODULE_FIRMWARE(IWL8000_MODULE_FIRMWARE(IWL8000_UCODE_API_MAX));136MODULE_FIRMWARE(IWL8265_MODULE_FIRMWARE(IWL8265_UCODE_API_MAX));137138139