| .. | .. |
|---|
| 5 | 5 | * |
|---|
| 6 | 6 | * GPL LICENSE SUMMARY |
|---|
| 7 | 7 | * |
|---|
| 8 | | - * Copyright(c) 2008 - 2014 Intel Corporation. All rights reserved. |
|---|
| 9 | 8 | * Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH |
|---|
| 10 | 9 | * Copyright(c) 2016 - 2017 Intel Deutschland GmbH |
|---|
| 11 | | - * Copyright(c) 2018 Intel Corporation |
|---|
| 10 | + * Copyright(c) 2008 - 2014, 2018 - 2020 Intel Corporation |
|---|
| 12 | 11 | * |
|---|
| 13 | 12 | * This program is free software; you can redistribute it and/or modify |
|---|
| 14 | 13 | * it under the terms of version 2 of the GNU General Public License as |
|---|
| .. | .. |
|---|
| 19 | 18 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
|---|
| 20 | 19 | * General Public License for more details. |
|---|
| 21 | 20 | * |
|---|
| 22 | | - * You should have received a copy of the GNU General Public License |
|---|
| 23 | | - * along with this program; if not, write to the Free Software |
|---|
| 24 | | - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110, |
|---|
| 25 | | - * USA |
|---|
| 26 | | - * |
|---|
| 27 | 21 | * The full GNU General Public License is included in this distribution |
|---|
| 28 | 22 | * in the file called COPYING. |
|---|
| 29 | 23 | * |
|---|
| .. | .. |
|---|
| 33 | 27 | * |
|---|
| 34 | 28 | * BSD LICENSE |
|---|
| 35 | 29 | * |
|---|
| 36 | | - * Copyright(c) 2005 - 2014 Intel Corporation. All rights reserved. |
|---|
| 37 | 30 | * Copyright(c) 2013 - 2015 Intel Mobile Communications GmbH |
|---|
| 38 | 31 | * Copyright(c) 2016 - 2017 Intel Deutschland GmbH |
|---|
| 39 | | - * Copyright(c) 2018 Intel Corporation |
|---|
| 32 | + * Copyright(c) 2008 - 2014, 2018 - 2020 Intel Corporation |
|---|
| 40 | 33 | * All rights reserved. |
|---|
| 41 | 34 | * |
|---|
| 42 | 35 | * Redistribution and use in source and binary forms, with or without |
|---|
| .. | .. |
|---|
| 96 | 89 | } u; |
|---|
| 97 | 90 | }; |
|---|
| 98 | 91 | |
|---|
| 92 | +#define IWL_UCODE_TLV_DEBUG_BASE 0x1000005 |
|---|
| 93 | +#define IWL_UCODE_TLV_CONST_BASE 0x100 |
|---|
| 94 | + |
|---|
| 99 | 95 | /* |
|---|
| 100 | 96 | * new TLV uCode file layout |
|---|
| 101 | 97 | * |
|---|
| .. | .. |
|---|
| 143 | 139 | IWL_UCODE_TLV_FW_DBG_DEST = 38, |
|---|
| 144 | 140 | IWL_UCODE_TLV_FW_DBG_CONF = 39, |
|---|
| 145 | 141 | IWL_UCODE_TLV_FW_DBG_TRIGGER = 40, |
|---|
| 142 | + IWL_UCODE_TLV_CMD_VERSIONS = 48, |
|---|
| 146 | 143 | IWL_UCODE_TLV_FW_GSCAN_CAPA = 50, |
|---|
| 147 | 144 | IWL_UCODE_TLV_FW_MEM_SEG = 51, |
|---|
| 148 | 145 | IWL_UCODE_TLV_IML = 52, |
|---|
| 146 | + IWL_UCODE_TLV_UMAC_DEBUG_ADDRS = 54, |
|---|
| 147 | + IWL_UCODE_TLV_LMAC_DEBUG_ADDRS = 55, |
|---|
| 148 | + IWL_UCODE_TLV_FW_RECOVERY_INFO = 57, |
|---|
| 149 | + IWL_UCODE_TLV_HW_TYPE = 58, |
|---|
| 150 | + IWL_UCODE_TLV_FW_FSEQ_VERSION = 60, |
|---|
| 151 | + |
|---|
| 152 | + IWL_UCODE_TLV_PNVM_VERSION = 62, |
|---|
| 153 | + IWL_UCODE_TLV_PNVM_SKU = 64, |
|---|
| 154 | + |
|---|
| 155 | + IWL_UCODE_TLV_FW_NUM_STATIONS = IWL_UCODE_TLV_CONST_BASE + 0, |
|---|
| 156 | + |
|---|
| 157 | + IWL_UCODE_TLV_TYPE_DEBUG_INFO = IWL_UCODE_TLV_DEBUG_BASE + 0, |
|---|
| 158 | + IWL_UCODE_TLV_TYPE_BUFFER_ALLOCATION = IWL_UCODE_TLV_DEBUG_BASE + 1, |
|---|
| 159 | + IWL_UCODE_TLV_TYPE_HCMD = IWL_UCODE_TLV_DEBUG_BASE + 2, |
|---|
| 160 | + IWL_UCODE_TLV_TYPE_REGIONS = IWL_UCODE_TLV_DEBUG_BASE + 3, |
|---|
| 161 | + IWL_UCODE_TLV_TYPE_TRIGGERS = IWL_UCODE_TLV_DEBUG_BASE + 4, |
|---|
| 162 | + IWL_UCODE_TLV_DEBUG_MAX = IWL_UCODE_TLV_TYPE_TRIGGERS, |
|---|
| 149 | 163 | |
|---|
| 150 | 164 | /* TLVs 0x1000-0x2000 are for internal driver usage */ |
|---|
| 151 | 165 | IWL_UCODE_TLV_FW_DBG_DUMP_LST = 0x1000, |
|---|
| .. | .. |
|---|
| 206 | 220 | * treats good CRC threshold as a boolean |
|---|
| 207 | 221 | * @IWL_UCODE_TLV_FLAGS_MFP: This uCode image supports MFP (802.11w). |
|---|
| 208 | 222 | * @IWL_UCODE_TLV_FLAGS_UAPSD_SUPPORT: This uCode image supports uAPSD |
|---|
| 209 | | - * @IWL_UCODE_TLV_FLAGS_SHORT_BL: 16 entries of black list instead of 64 in scan |
|---|
| 223 | + * @IWL_UCODE_TLV_FLAGS_SHORT_BL: 16 entries of block list instead of 64 in scan |
|---|
| 210 | 224 | * offload profile config command. |
|---|
| 211 | 225 | * @IWL_UCODE_TLV_FLAGS_D3_6_IPV6_ADDRS: D3 image supports up to six |
|---|
| 212 | 226 | * (rather than two) IPv6 addresses |
|---|
| .. | .. |
|---|
| 258 | 272 | * deprecated. |
|---|
| 259 | 273 | * @IWL_UCODE_TLV_API_ADAPTIVE_DWELL_V2: This ucode supports version 8 |
|---|
| 260 | 274 | * of scan request: SCAN_REQUEST_CMD_UMAC_API_S_VER_8 |
|---|
| 275 | + * @IWL_UCODE_TLV_API_FRAG_EBS: This ucode supports fragmented EBS |
|---|
| 276 | + * @IWL_UCODE_TLV_API_REDUCE_TX_POWER: This ucode supports v5 of |
|---|
| 277 | + * the REDUCE_TX_POWER_CMD. |
|---|
| 278 | + * @IWL_UCODE_TLV_API_SHORT_BEACON_NOTIF: This ucode supports the short |
|---|
| 279 | + * version of the beacon notification. |
|---|
| 280 | + * @IWL_UCODE_TLV_API_BEACON_FILTER_V4: This ucode supports v4 of |
|---|
| 281 | + * BEACON_FILTER_CONFIG_API_S_VER_4. |
|---|
| 282 | + * @IWL_UCODE_TLV_API_REGULATORY_NVM_INFO: This ucode supports v4 of |
|---|
| 283 | + * REGULATORY_NVM_GET_INFO_RSP_API_S. |
|---|
| 284 | + * @IWL_UCODE_TLV_API_FTM_NEW_RANGE_REQ: This ucode supports v7 of |
|---|
| 285 | + * LOCATION_RANGE_REQ_CMD_API_S and v6 of LOCATION_RANGE_RESP_NTFY_API_S. |
|---|
| 286 | + * @IWL_UCODE_TLV_API_SCAN_OFFLOAD_CHANS: This ucode supports v2 of |
|---|
| 287 | + * SCAN_OFFLOAD_PROFILE_MATCH_RESULTS_S and v3 of |
|---|
| 288 | + * SCAN_OFFLOAD_PROFILES_QUERY_RSP_S. |
|---|
| 289 | + * @IWL_UCODE_TLV_API_MBSSID_HE: This ucode supports v2 of |
|---|
| 290 | + * STA_CONTEXT_DOT11AX_API_S |
|---|
| 291 | + * @IWL_UCODE_TLV_CAPA_SAR_TABLE_VER: This ucode supports different sar |
|---|
| 292 | + * version tables. |
|---|
| 293 | + * @IWL_UCODE_TLV_API_REDUCED_SCAN_CONFIG: This ucode supports v3 of |
|---|
| 294 | + * SCAN_CONFIG_DB_CMD_API_S. |
|---|
| 261 | 295 | * |
|---|
| 262 | 296 | * @NUM_IWL_UCODE_TLV_API: number of bits used |
|---|
| 263 | 297 | */ |
|---|
| .. | .. |
|---|
| 276 | 310 | IWL_UCODE_TLV_API_OCE = (__force iwl_ucode_tlv_api_t)33, |
|---|
| 277 | 311 | IWL_UCODE_TLV_API_NEW_BEACON_TEMPLATE = (__force iwl_ucode_tlv_api_t)34, |
|---|
| 278 | 312 | IWL_UCODE_TLV_API_NEW_RX_STATS = (__force iwl_ucode_tlv_api_t)35, |
|---|
| 313 | + IWL_UCODE_TLV_API_WOWLAN_KEY_MATERIAL = (__force iwl_ucode_tlv_api_t)36, |
|---|
| 279 | 314 | IWL_UCODE_TLV_API_QUOTA_LOW_LATENCY = (__force iwl_ucode_tlv_api_t)38, |
|---|
| 280 | 315 | IWL_UCODE_TLV_API_DEPRECATE_TTAK = (__force iwl_ucode_tlv_api_t)41, |
|---|
| 281 | 316 | IWL_UCODE_TLV_API_ADAPTIVE_DWELL_V2 = (__force iwl_ucode_tlv_api_t)42, |
|---|
| 317 | + IWL_UCODE_TLV_API_FRAG_EBS = (__force iwl_ucode_tlv_api_t)44, |
|---|
| 318 | + IWL_UCODE_TLV_API_REDUCE_TX_POWER = (__force iwl_ucode_tlv_api_t)45, |
|---|
| 319 | + IWL_UCODE_TLV_API_SHORT_BEACON_NOTIF = (__force iwl_ucode_tlv_api_t)46, |
|---|
| 320 | + IWL_UCODE_TLV_API_BEACON_FILTER_V4 = (__force iwl_ucode_tlv_api_t)47, |
|---|
| 321 | + IWL_UCODE_TLV_API_REGULATORY_NVM_INFO = (__force iwl_ucode_tlv_api_t)48, |
|---|
| 322 | + IWL_UCODE_TLV_API_FTM_NEW_RANGE_REQ = (__force iwl_ucode_tlv_api_t)49, |
|---|
| 323 | + IWL_UCODE_TLV_API_SCAN_OFFLOAD_CHANS = (__force iwl_ucode_tlv_api_t)50, |
|---|
| 324 | + IWL_UCODE_TLV_API_MBSSID_HE = (__force iwl_ucode_tlv_api_t)52, |
|---|
| 325 | + IWL_UCODE_TLV_API_WOWLAN_TCP_SYN_WAKE = (__force iwl_ucode_tlv_api_t)53, |
|---|
| 326 | + IWL_UCODE_TLV_API_FTM_RTT_ACCURACY = (__force iwl_ucode_tlv_api_t)54, |
|---|
| 327 | + IWL_UCODE_TLV_API_SAR_TABLE_VER = (__force iwl_ucode_tlv_api_t)55, |
|---|
| 328 | + IWL_UCODE_TLV_API_REDUCED_SCAN_CONFIG = (__force iwl_ucode_tlv_api_t)56, |
|---|
| 329 | + IWL_UCODE_TLV_API_ADWELL_HB_DEF_N_AP = (__force iwl_ucode_tlv_api_t)57, |
|---|
| 330 | + IWL_UCODE_TLV_API_SCAN_EXT_CHAN_VER = (__force iwl_ucode_tlv_api_t)58, |
|---|
| 331 | + IWL_UCODE_TLV_API_BAND_IN_RX_DATA = (__force iwl_ucode_tlv_api_t)59, |
|---|
| 332 | + |
|---|
| 282 | 333 | |
|---|
| 283 | 334 | NUM_IWL_UCODE_TLV_API |
|---|
| 284 | 335 | #ifdef __CHECKER__ |
|---|
| .. | .. |
|---|
| 295 | 346 | * @IWL_UCODE_TLV_CAPA_LAR_SUPPORT: supports Location Aware Regulatory |
|---|
| 296 | 347 | * @IWL_UCODE_TLV_CAPA_UMAC_SCAN: supports UMAC scan. |
|---|
| 297 | 348 | * @IWL_UCODE_TLV_CAPA_BEAMFORMER: supports Beamformer |
|---|
| 298 | | - * @IWL_UCODE_TLV_CAPA_TOF_SUPPORT: supports Time of Flight (802.11mc FTM) |
|---|
| 299 | 349 | * @IWL_UCODE_TLV_CAPA_TDLS_SUPPORT: support basic TDLS functionality |
|---|
| 300 | 350 | * @IWL_UCODE_TLV_CAPA_TXPOWER_INSERTION_SUPPORT: supports insertion of current |
|---|
| 301 | 351 | * tx power value into TPC Report action frame and Link Measurement Report |
|---|
| .. | .. |
|---|
| 322 | 372 | * is supported. |
|---|
| 323 | 373 | * @IWL_UCODE_TLV_CAPA_BT_COEX_RRC: supports BT Coex RRC |
|---|
| 324 | 374 | * @IWL_UCODE_TLV_CAPA_GSCAN_SUPPORT: supports gscan (no longer used) |
|---|
| 375 | + * @IWL_UCODE_TLV_CAPA_SOC_LATENCY_SUPPORT: the firmware supports setting |
|---|
| 376 | + * stabilization latency for SoCs. |
|---|
| 325 | 377 | * @IWL_UCODE_TLV_CAPA_STA_PM_NOTIF: firmware will send STA PM notification |
|---|
| 326 | 378 | * @IWL_UCODE_TLV_CAPA_TLC_OFFLOAD: firmware implements rate scaling algorithm |
|---|
| 327 | 379 | * @IWL_UCODE_TLV_CAPA_DYNAMIC_QUOTA: firmware implements quota related |
|---|
| 380 | + * @IWL_UCODE_TLV_CAPA_COEX_SCHEMA_2: firmware implements Coex Schema 2 |
|---|
| 381 | + * IWL_UCODE_TLV_CAPA_CHANNEL_SWITCH_CMD: firmware supports CSA command |
|---|
| 382 | + * @IWL_UCODE_TLV_CAPA_ULTRA_HB_CHANNELS: firmware supports ultra high band |
|---|
| 383 | + * (6 GHz). |
|---|
| 384 | + * @IWL_UCODE_TLV_CAPA_CS_MODIFY: firmware supports modify action CSA command |
|---|
| 328 | 385 | * @IWL_UCODE_TLV_CAPA_EXTENDED_DTS_MEASURE: extended DTS measurement |
|---|
| 329 | 386 | * @IWL_UCODE_TLV_CAPA_SHORT_PM_TIMEOUTS: supports short PM timeouts |
|---|
| 330 | 387 | * @IWL_UCODE_TLV_CAPA_BT_MPLUT_SUPPORT: supports bt-coex Multi-priority LUT |
|---|
| .. | .. |
|---|
| 335 | 392 | * antenna the beacon should be transmitted |
|---|
| 336 | 393 | * @IWL_UCODE_TLV_CAPA_BEACON_STORING: firmware will store the latest beacon |
|---|
| 337 | 394 | * from AP and will send it upon d0i3 exit. |
|---|
| 338 | | - * @IWL_UCODE_TLV_CAPA_LAR_SUPPORT_V2: support LAR API V2 |
|---|
| 395 | + * @IWL_UCODE_TLV_CAPA_LAR_SUPPORT_V3: support LAR API V3 |
|---|
| 339 | 396 | * @IWL_UCODE_TLV_CAPA_CT_KILL_BY_FW: firmware responsible for CT-kill |
|---|
| 340 | 397 | * @IWL_UCODE_TLV_CAPA_TEMP_THS_REPORT_SUPPORT: supports temperature |
|---|
| 341 | 398 | * thresholds reporting |
|---|
| .. | .. |
|---|
| 348 | 405 | * @IWL_UCODE_TLV_CAPA_TX_POWER_ACK: reduced TX power API has larger |
|---|
| 349 | 406 | * command size (command version 4) that supports toggling ACK TX |
|---|
| 350 | 407 | * power reduction. |
|---|
| 408 | + * @IWL_UCODE_TLV_CAPA_D3_DEBUG: supports debug recording during D3 |
|---|
| 409 | + * @IWL_UCODE_TLV_CAPA_MCC_UPDATE_11AX_SUPPORT: MCC response support 11ax |
|---|
| 410 | + * capability. |
|---|
| 411 | + * @IWL_UCODE_TLV_CAPA_CSI_REPORTING: firmware is capable of being configured |
|---|
| 412 | + * to report the CSI information with (certain) RX frames |
|---|
| 413 | + * @IWL_UCODE_TLV_CAPA_FTM_CALIBRATED: has FTM calibrated and thus supports both |
|---|
| 414 | + * initiator and responder |
|---|
| 351 | 415 | * @IWL_UCODE_TLV_CAPA_MLME_OFFLOAD: supports MLME offload |
|---|
| 416 | + * @IWL_UCODE_TLV_CAPA_PROTECTED_TWT: Supports protection of TWT action frames |
|---|
| 352 | 417 | * |
|---|
| 353 | 418 | * @NUM_IWL_UCODE_TLV_CAPA: number of bits used |
|---|
| 354 | 419 | */ |
|---|
| 355 | 420 | enum iwl_ucode_tlv_capa { |
|---|
| 421 | + /* set 0 */ |
|---|
| 356 | 422 | IWL_UCODE_TLV_CAPA_D0I3_SUPPORT = (__force iwl_ucode_tlv_capa_t)0, |
|---|
| 357 | 423 | IWL_UCODE_TLV_CAPA_LAR_SUPPORT = (__force iwl_ucode_tlv_capa_t)1, |
|---|
| 358 | 424 | IWL_UCODE_TLV_CAPA_UMAC_SCAN = (__force iwl_ucode_tlv_capa_t)2, |
|---|
| 359 | 425 | IWL_UCODE_TLV_CAPA_BEAMFORMER = (__force iwl_ucode_tlv_capa_t)3, |
|---|
| 360 | | - IWL_UCODE_TLV_CAPA_TOF_SUPPORT = (__force iwl_ucode_tlv_capa_t)5, |
|---|
| 361 | 426 | IWL_UCODE_TLV_CAPA_TDLS_SUPPORT = (__force iwl_ucode_tlv_capa_t)6, |
|---|
| 362 | 427 | IWL_UCODE_TLV_CAPA_TXPOWER_INSERTION_SUPPORT = (__force iwl_ucode_tlv_capa_t)8, |
|---|
| 363 | 428 | IWL_UCODE_TLV_CAPA_DS_PARAM_SET_IE_SUPPORT = (__force iwl_ucode_tlv_capa_t)9, |
|---|
| .. | .. |
|---|
| 375 | 440 | IWL_UCODE_TLV_CAPA_LAR_MULTI_MCC = (__force iwl_ucode_tlv_capa_t)29, |
|---|
| 376 | 441 | IWL_UCODE_TLV_CAPA_BT_COEX_RRC = (__force iwl_ucode_tlv_capa_t)30, |
|---|
| 377 | 442 | IWL_UCODE_TLV_CAPA_GSCAN_SUPPORT = (__force iwl_ucode_tlv_capa_t)31, |
|---|
| 443 | + |
|---|
| 444 | + /* set 1 */ |
|---|
| 445 | + IWL_UCODE_TLV_CAPA_SOC_LATENCY_SUPPORT = (__force iwl_ucode_tlv_capa_t)37, |
|---|
| 378 | 446 | IWL_UCODE_TLV_CAPA_STA_PM_NOTIF = (__force iwl_ucode_tlv_capa_t)38, |
|---|
| 379 | 447 | IWL_UCODE_TLV_CAPA_BINDING_CDB_SUPPORT = (__force iwl_ucode_tlv_capa_t)39, |
|---|
| 380 | 448 | IWL_UCODE_TLV_CAPA_CDB_SUPPORT = (__force iwl_ucode_tlv_capa_t)40, |
|---|
| 381 | 449 | IWL_UCODE_TLV_CAPA_D0I3_END_FIRST = (__force iwl_ucode_tlv_capa_t)41, |
|---|
| 382 | 450 | IWL_UCODE_TLV_CAPA_TLC_OFFLOAD = (__force iwl_ucode_tlv_capa_t)43, |
|---|
| 383 | 451 | IWL_UCODE_TLV_CAPA_DYNAMIC_QUOTA = (__force iwl_ucode_tlv_capa_t)44, |
|---|
| 452 | + IWL_UCODE_TLV_CAPA_COEX_SCHEMA_2 = (__force iwl_ucode_tlv_capa_t)45, |
|---|
| 453 | + IWL_UCODE_TLV_CAPA_CHANNEL_SWITCH_CMD = (__force iwl_ucode_tlv_capa_t)46, |
|---|
| 454 | + IWL_UCODE_TLV_CAPA_FTM_CALIBRATED = (__force iwl_ucode_tlv_capa_t)47, |
|---|
| 455 | + IWL_UCODE_TLV_CAPA_ULTRA_HB_CHANNELS = (__force iwl_ucode_tlv_capa_t)48, |
|---|
| 456 | + IWL_UCODE_TLV_CAPA_CS_MODIFY = (__force iwl_ucode_tlv_capa_t)49, |
|---|
| 457 | + IWL_UCODE_TLV_CAPA_SET_LTR_GEN2 = (__force iwl_ucode_tlv_capa_t)50, |
|---|
| 458 | + IWL_UCODE_TLV_CAPA_SET_PPAG = (__force iwl_ucode_tlv_capa_t)52, |
|---|
| 459 | + IWL_UCODE_TLV_CAPA_TAS_CFG = (__force iwl_ucode_tlv_capa_t)53, |
|---|
| 460 | + IWL_UCODE_TLV_CAPA_SESSION_PROT_CMD = (__force iwl_ucode_tlv_capa_t)54, |
|---|
| 461 | + IWL_UCODE_TLV_CAPA_PROTECTED_TWT = (__force iwl_ucode_tlv_capa_t)56, |
|---|
| 462 | + |
|---|
| 463 | + /* set 2 */ |
|---|
| 384 | 464 | IWL_UCODE_TLV_CAPA_EXTENDED_DTS_MEASURE = (__force iwl_ucode_tlv_capa_t)64, |
|---|
| 385 | 465 | IWL_UCODE_TLV_CAPA_SHORT_PM_TIMEOUTS = (__force iwl_ucode_tlv_capa_t)65, |
|---|
| 386 | 466 | IWL_UCODE_TLV_CAPA_BT_MPLUT_SUPPORT = (__force iwl_ucode_tlv_capa_t)67, |
|---|
| .. | .. |
|---|
| 388 | 468 | IWL_UCODE_TLV_CAPA_CSA_AND_TBTT_OFFLOAD = (__force iwl_ucode_tlv_capa_t)70, |
|---|
| 389 | 469 | IWL_UCODE_TLV_CAPA_BEACON_ANT_SELECTION = (__force iwl_ucode_tlv_capa_t)71, |
|---|
| 390 | 470 | IWL_UCODE_TLV_CAPA_BEACON_STORING = (__force iwl_ucode_tlv_capa_t)72, |
|---|
| 391 | | - IWL_UCODE_TLV_CAPA_LAR_SUPPORT_V2 = (__force iwl_ucode_tlv_capa_t)73, |
|---|
| 471 | + IWL_UCODE_TLV_CAPA_LAR_SUPPORT_V3 = (__force iwl_ucode_tlv_capa_t)73, |
|---|
| 392 | 472 | IWL_UCODE_TLV_CAPA_CT_KILL_BY_FW = (__force iwl_ucode_tlv_capa_t)74, |
|---|
| 393 | 473 | IWL_UCODE_TLV_CAPA_TEMP_THS_REPORT_SUPPORT = (__force iwl_ucode_tlv_capa_t)75, |
|---|
| 394 | 474 | IWL_UCODE_TLV_CAPA_CTDP_SUPPORT = (__force iwl_ucode_tlv_capa_t)76, |
|---|
| .. | .. |
|---|
| 396 | 476 | IWL_UCODE_TLV_CAPA_EXTEND_SHARED_MEM_CFG = (__force iwl_ucode_tlv_capa_t)80, |
|---|
| 397 | 477 | IWL_UCODE_TLV_CAPA_LQM_SUPPORT = (__force iwl_ucode_tlv_capa_t)81, |
|---|
| 398 | 478 | IWL_UCODE_TLV_CAPA_TX_POWER_ACK = (__force iwl_ucode_tlv_capa_t)84, |
|---|
| 399 | | - IWL_UCODE_TLV_CAPA_LED_CMD_SUPPORT = (__force iwl_ucode_tlv_capa_t)86, |
|---|
| 479 | + IWL_UCODE_TLV_CAPA_D3_DEBUG = (__force iwl_ucode_tlv_capa_t)87, |
|---|
| 480 | + IWL_UCODE_TLV_CAPA_LED_CMD_SUPPORT = (__force iwl_ucode_tlv_capa_t)88, |
|---|
| 481 | + IWL_UCODE_TLV_CAPA_MCC_UPDATE_11AX_SUPPORT = (__force iwl_ucode_tlv_capa_t)89, |
|---|
| 482 | + IWL_UCODE_TLV_CAPA_CSI_REPORTING = (__force iwl_ucode_tlv_capa_t)90, |
|---|
| 483 | + IWL_UCODE_TLV_CAPA_DBG_SUSPEND_RESUME_CMD_SUPP = (__force iwl_ucode_tlv_capa_t)92, |
|---|
| 484 | + IWL_UCODE_TLV_CAPA_DBG_BUF_ALLOC_CMD_SUPP = (__force iwl_ucode_tlv_capa_t)93, |
|---|
| 485 | + |
|---|
| 486 | + /* set 3 */ |
|---|
| 400 | 487 | IWL_UCODE_TLV_CAPA_MLME_OFFLOAD = (__force iwl_ucode_tlv_capa_t)96, |
|---|
| 401 | 488 | |
|---|
| 402 | 489 | NUM_IWL_UCODE_TLV_CAPA |
|---|
| .. | .. |
|---|
| 451 | 538 | FW_PHY_CFG_TX_CHAIN = 0xf << FW_PHY_CFG_TX_CHAIN_POS, |
|---|
| 452 | 539 | FW_PHY_CFG_RX_CHAIN_POS = 20, |
|---|
| 453 | 540 | FW_PHY_CFG_RX_CHAIN = 0xf << FW_PHY_CFG_RX_CHAIN_POS, |
|---|
| 541 | + FW_PHY_CFG_CHAIN_SAD_POS = 23, |
|---|
| 542 | + FW_PHY_CFG_CHAIN_SAD_ENABLED = 0x1 << FW_PHY_CFG_CHAIN_SAD_POS, |
|---|
| 543 | + FW_PHY_CFG_CHAIN_SAD_ANT_A = 0x2 << FW_PHY_CFG_CHAIN_SAD_POS, |
|---|
| 544 | + FW_PHY_CFG_CHAIN_SAD_ANT_B = 0x4 << FW_PHY_CFG_CHAIN_SAD_POS, |
|---|
| 454 | 545 | FW_PHY_CFG_SHARED_CLK = BIT(31), |
|---|
| 455 | 546 | }; |
|---|
| 456 | 547 | |
|---|
| .. | .. |
|---|
| 528 | 619 | }; |
|---|
| 529 | 620 | |
|---|
| 530 | 621 | /** |
|---|
| 531 | | - * enum iwl_fw_mem_seg_type - memory segment type |
|---|
| 532 | | - * @FW_DBG_MEM_TYPE_MASK: mask for the type indication |
|---|
| 533 | | - * @FW_DBG_MEM_TYPE_REGULAR: regular memory |
|---|
| 534 | | - * @FW_DBG_MEM_TYPE_PRPH: periphery memory (requires special reading) |
|---|
| 535 | | - */ |
|---|
| 536 | | -enum iwl_fw_mem_seg_type { |
|---|
| 537 | | - FW_DBG_MEM_TYPE_MASK = 0xff000000, |
|---|
| 538 | | - FW_DBG_MEM_TYPE_REGULAR = 0x00000000, |
|---|
| 539 | | - FW_DBG_MEM_TYPE_PRPH = 0x01000000, |
|---|
| 540 | | -}; |
|---|
| 541 | | - |
|---|
| 542 | | -/** |
|---|
| 543 | 622 | * struct iwl_fw_dbg_mem_seg_tlv - configures the debug data memory segments |
|---|
| 544 | 623 | * |
|---|
| 545 | | - * @data_type: the memory segment type to record, see &enum iwl_fw_mem_seg_type |
|---|
| 546 | | - * for what we care about |
|---|
| 624 | + * @data_type: the memory segment type to record |
|---|
| 547 | 625 | * @ofs: the memory segment offset |
|---|
| 548 | 626 | * @len: the memory segment length, in bytes |
|---|
| 549 | 627 | * |
|---|
| .. | .. |
|---|
| 892 | 970 | struct iwl_fw_dbg_conf_hcmd hcmd; |
|---|
| 893 | 971 | } __packed; |
|---|
| 894 | 972 | |
|---|
| 973 | +#define IWL_FW_CMD_VER_UNKNOWN 99 |
|---|
| 974 | + |
|---|
| 975 | +/** |
|---|
| 976 | + * struct iwl_fw_cmd_version - firmware command version entry |
|---|
| 977 | + * @cmd: command ID |
|---|
| 978 | + * @group: group ID |
|---|
| 979 | + * @cmd_ver: command version |
|---|
| 980 | + * @notif_ver: notification version |
|---|
| 981 | + */ |
|---|
| 982 | +struct iwl_fw_cmd_version { |
|---|
| 983 | + u8 cmd; |
|---|
| 984 | + u8 group; |
|---|
| 985 | + u8 cmd_ver; |
|---|
| 986 | + u8 notif_ver; |
|---|
| 987 | +} __packed; |
|---|
| 988 | + |
|---|
| 989 | +static inline size_t _iwl_tlv_array_len(const struct iwl_ucode_tlv *tlv, |
|---|
| 990 | + size_t fixed_size, size_t var_size) |
|---|
| 991 | +{ |
|---|
| 992 | + size_t var_len = le32_to_cpu(tlv->length) - fixed_size; |
|---|
| 993 | + |
|---|
| 994 | + if (WARN_ON(var_len % var_size)) |
|---|
| 995 | + return 0; |
|---|
| 996 | + |
|---|
| 997 | + return var_len / var_size; |
|---|
| 998 | +} |
|---|
| 999 | + |
|---|
| 1000 | +#define iwl_tlv_array_len(_tlv_ptr, _struct_ptr, _memb) \ |
|---|
| 1001 | + _iwl_tlv_array_len((_tlv_ptr), sizeof(*(_struct_ptr)), \ |
|---|
| 1002 | + sizeof(_struct_ptr->_memb[0])) |
|---|
| 1003 | + |
|---|
| 895 | 1004 | #endif /* __iwl_fw_file_h__ */ |
|---|