Path: blob/main/sys/contrib/dev/athk/ath12k/wmi.h
109183 views
/* SPDX-License-Identifier: BSD-3-Clause-Clear */1/*2* Copyright (c) 2018-2021 The Linux Foundation. All rights reserved.3* Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.4*/56#ifndef ATH12K_WMI_H7#define ATH12K_WMI_H89#include <net/mac80211.h>10#include "htc.h"1112/* Naming conventions for structures:13*14* _cmd means that this is a firmware command sent from host to firmware.15*16* _event means that this is a firmware event sent from firmware to host17*18* _params is a structure which is embedded either into _cmd or _event (or19* both), it is not sent individually.20*21* _arg is used inside the host, the firmware does not see that at all.22*/2324struct ath12k_base;25struct ath12k;2627/* There is no signed version of __le32, so for a temporary solution come28* up with our own version. The idea is from fs/ntfs/endian.h.29*30* Use a_ prefix so that it doesn't conflict if we get proper support to31* linux/types.h.32*/33typedef __s32 __bitwise a_sle32;3435static inline a_sle32 a_cpu_to_sle32(s32 val)36{37return (__force a_sle32)cpu_to_le32(val);38}3940static inline s32 a_sle32_to_cpu(a_sle32 val)41{42return le32_to_cpu((__force __le32)val);43}4445/* defines to set Packet extension values which can be 0 us, 8 usec or 16 usec */46#define MAX_HE_NSS 847#define MAX_HE_MODULATION 848#define MAX_HE_RU 449#define HE_MODULATION_NONE 750#define HE_PET_0_USEC 051#define HE_PET_8_USEC 152#define HE_PET_16_USEC 25354#define WMI_MAX_CHAINS 85556#define WMI_MAX_NUM_SS MAX_HE_NSS57#define WMI_MAX_NUM_RU MAX_HE_RU5859#define WMI_TLV_CMD(grp_id) (((grp_id) << 12) | 0x1)60#define WMI_TLV_EV(grp_id) (((grp_id) << 12) | 0x1)61#define WMI_TLV_CMD_UNSUPPORTED 062#define WMI_TLV_PDEV_PARAM_UNSUPPORTED 063#define WMI_TLV_VDEV_PARAM_UNSUPPORTED 06465struct wmi_cmd_hdr {66__le32 cmd_id;67} __packed;6869struct wmi_tlv {70__le32 header;71u8 value[];72} __packed;7374#define WMI_TLV_LEN GENMASK(15, 0)75#define WMI_TLV_TAG GENMASK(31, 16)76#define TLV_HDR_SIZE sizeof_field(struct wmi_tlv, header)7778#define WMI_CMD_HDR_CMD_ID GENMASK(23, 0)79#define WMI_MAX_MEM_REQS 3280#define ATH12K_MAX_HW_LISTEN_INTERVAL 58182#define WMI_HOST_RC_DS_FLAG 0x0183#define WMI_HOST_RC_CW40_FLAG 0x0284#define WMI_HOST_RC_SGI_FLAG 0x0485#define WMI_HOST_RC_HT_FLAG 0x0886#define WMI_HOST_RC_RTSCTS_FLAG 0x1087#define WMI_HOST_RC_TX_STBC_FLAG 0x2088#define WMI_HOST_RC_RX_STBC_FLAG 0xC089#define WMI_HOST_RC_RX_STBC_FLAG_S 690#define WMI_HOST_RC_WEP_TKIP_FLAG 0x10091#define WMI_HOST_RC_TS_FLAG 0x20092#define WMI_HOST_RC_UAPSD_FLAG 0x4009394#define WMI_HT_CAP_ENABLED 0x000195#define WMI_HT_CAP_HT20_SGI 0x000296#define WMI_HT_CAP_DYNAMIC_SMPS 0x000497#define WMI_HT_CAP_TX_STBC 0x000898#define WMI_HT_CAP_TX_STBC_MASK_SHIFT 399#define WMI_HT_CAP_RX_STBC 0x0030100#define WMI_HT_CAP_RX_STBC_MASK_SHIFT 4101#define WMI_HT_CAP_LDPC 0x0040102#define WMI_HT_CAP_L_SIG_TXOP_PROT 0x0080103#define WMI_HT_CAP_MPDU_DENSITY 0x0700104#define WMI_HT_CAP_MPDU_DENSITY_MASK_SHIFT 8105#define WMI_HT_CAP_HT40_SGI 0x0800106#define WMI_HT_CAP_RX_LDPC 0x1000107#define WMI_HT_CAP_TX_LDPC 0x2000108#define WMI_HT_CAP_IBF_BFER 0x4000109110/* These macros should be used when we wish to advertise STBC support for111* only 1SS or 2SS or 3SS.112*/113#define WMI_HT_CAP_RX_STBC_1SS 0x0010114#define WMI_HT_CAP_RX_STBC_2SS 0x0020115#define WMI_HT_CAP_RX_STBC_3SS 0x0030116117#define WMI_HT_CAP_DEFAULT_ALL (WMI_HT_CAP_ENABLED | \118WMI_HT_CAP_HT20_SGI | \119WMI_HT_CAP_HT40_SGI | \120WMI_HT_CAP_TX_STBC | \121WMI_HT_CAP_RX_STBC | \122WMI_HT_CAP_LDPC)123124#define WMI_VHT_CAP_MAX_MPDU_LEN_MASK 0x00000003125#define WMI_VHT_CAP_RX_LDPC 0x00000010126#define WMI_VHT_CAP_SGI_80MHZ 0x00000020127#define WMI_VHT_CAP_SGI_160MHZ 0x00000040128#define WMI_VHT_CAP_TX_STBC 0x00000080129#define WMI_VHT_CAP_RX_STBC_MASK 0x00000300130#define WMI_VHT_CAP_RX_STBC_MASK_SHIFT 8131#define WMI_VHT_CAP_SU_BFER 0x00000800132#define WMI_VHT_CAP_SU_BFEE 0x00001000133#define WMI_VHT_CAP_MAX_CS_ANT_MASK 0x0000E000134#define WMI_VHT_CAP_MAX_CS_ANT_MASK_SHIFT 13135#define WMI_VHT_CAP_MAX_SND_DIM_MASK 0x00070000136#define WMI_VHT_CAP_MAX_SND_DIM_MASK_SHIFT 16137#define WMI_VHT_CAP_MU_BFER 0x00080000138#define WMI_VHT_CAP_MU_BFEE 0x00100000139#define WMI_VHT_CAP_MAX_AMPDU_LEN_EXP 0x03800000140#define WMI_VHT_CAP_MAX_AMPDU_LEN_EXP_SHIT 23141#define WMI_VHT_CAP_RX_FIXED_ANT 0x10000000142#define WMI_VHT_CAP_TX_FIXED_ANT 0x20000000143144#define WMI_VHT_CAP_MAX_MPDU_LEN_11454 0x00000002145146/* These macros should be used when we wish to advertise STBC support for147* only 1SS or 2SS or 3SS.148*/149#define WMI_VHT_CAP_RX_STBC_1SS 0x00000100150#define WMI_VHT_CAP_RX_STBC_2SS 0x00000200151#define WMI_VHT_CAP_RX_STBC_3SS 0x00000300152153#define WMI_VHT_CAP_DEFAULT_ALL (WMI_VHT_CAP_MAX_MPDU_LEN_11454 | \154WMI_VHT_CAP_SGI_80MHZ | \155WMI_VHT_CAP_TX_STBC | \156WMI_VHT_CAP_RX_STBC_MASK | \157WMI_VHT_CAP_RX_LDPC | \158WMI_VHT_CAP_MAX_AMPDU_LEN_EXP | \159WMI_VHT_CAP_RX_FIXED_ANT | \160WMI_VHT_CAP_TX_FIXED_ANT)161162#define WLAN_SCAN_MAX_HINT_S_SSID 10163#define WLAN_SCAN_MAX_HINT_BSSID 10164#define MAX_RNR_BSS 5165166#define WLAN_SCAN_MAX_HINT_S_SSID 10167#define WLAN_SCAN_MAX_HINT_BSSID 10168#define MAX_RNR_BSS 5169170#define WLAN_SCAN_PARAMS_MAX_SSID 16171#define WLAN_SCAN_PARAMS_MAX_BSSID 4172#define WLAN_SCAN_PARAMS_MAX_IE_LEN 256173174#define WMI_APPEND_TO_EXISTING_CHAN_LIST_FLAG 1175176#define WMI_BA_MODE_BUFFER_SIZE_256 3177178/* HW mode config type replicated from FW header179* @WMI_HOST_HW_MODE_SINGLE: Only one PHY is active.180* @WMI_HOST_HW_MODE_DBS: Both PHYs are active in different bands,181* one in 2G and another in 5G.182* @WMI_HOST_HW_MODE_SBS_PASSIVE: Both PHYs are in passive mode (only rx) in183* same band; no tx allowed.184* @WMI_HOST_HW_MODE_SBS: Both PHYs are active in the same band.185* Support for both PHYs within one band is planned186* for 5G only(as indicated in WMI_MAC_PHY_CAPABILITIES),187* but could be extended to other bands in the future.188* The separation of the band between the two PHYs needs189* to be communicated separately.190* @WMI_HOST_HW_MODE_DBS_SBS: 3 PHYs, with 2 on the same band doing SBS191* as in WMI_HW_MODE_SBS, and 3rd on the other band192* @WMI_HOST_HW_MODE_DBS_OR_SBS: Two PHY with one PHY capabale of both 2G and193* 5G. It can support SBS (5G + 5G) OR DBS (5G + 2G).194* @WMI_HOST_HW_MODE_MAX: Max hw_mode_id. Used to indicate invalid mode.195*/196enum wmi_host_hw_mode_config_type {197WMI_HOST_HW_MODE_SINGLE = 0,198WMI_HOST_HW_MODE_DBS = 1,199WMI_HOST_HW_MODE_SBS_PASSIVE = 2,200WMI_HOST_HW_MODE_SBS = 3,201WMI_HOST_HW_MODE_DBS_SBS = 4,202WMI_HOST_HW_MODE_DBS_OR_SBS = 5,203204/* keep last */205WMI_HOST_HW_MODE_MAX206};207208/* HW mode priority values used to detect the preferred HW mode209* on the available modes.210*/211enum wmi_host_hw_mode_priority {212WMI_HOST_HW_MODE_DBS_SBS_PRI,213WMI_HOST_HW_MODE_DBS_PRI,214WMI_HOST_HW_MODE_DBS_OR_SBS_PRI,215WMI_HOST_HW_MODE_SBS_PRI,216WMI_HOST_HW_MODE_SBS_PASSIVE_PRI,217WMI_HOST_HW_MODE_SINGLE_PRI,218219/* keep last the lowest priority */220WMI_HOST_HW_MODE_MAX_PRI221};222223enum WMI_HOST_WLAN_BAND {224WMI_HOST_WLAN_2G_CAP = 1,225WMI_HOST_WLAN_5G_CAP = 2,226WMI_HOST_WLAN_2G_5G_CAP = 3,227};228229enum wmi_cmd_group {230/* 0 to 2 are reserved */231WMI_GRP_START = 0x3,232WMI_GRP_SCAN = WMI_GRP_START,233WMI_GRP_PDEV = 0x4,234WMI_GRP_VDEV = 0x5,235WMI_GRP_PEER = 0x6,236WMI_GRP_MGMT = 0x7,237WMI_GRP_BA_NEG = 0x8,238WMI_GRP_STA_PS = 0x9,239WMI_GRP_DFS = 0xa,240WMI_GRP_ROAM = 0xb,241WMI_GRP_OFL_SCAN = 0xc,242WMI_GRP_P2P = 0xd,243WMI_GRP_AP_PS = 0xe,244WMI_GRP_RATE_CTRL = 0xf,245WMI_GRP_PROFILE = 0x10,246WMI_GRP_SUSPEND = 0x11,247WMI_GRP_BCN_FILTER = 0x12,248WMI_GRP_WOW = 0x13,249WMI_GRP_RTT = 0x14,250WMI_GRP_SPECTRAL = 0x15,251WMI_GRP_STATS = 0x16,252WMI_GRP_ARP_NS_OFL = 0x17,253WMI_GRP_NLO_OFL = 0x18,254WMI_GRP_GTK_OFL = 0x19,255WMI_GRP_CSA_OFL = 0x1a,256WMI_GRP_CHATTER = 0x1b,257WMI_GRP_TID_ADDBA = 0x1c,258WMI_GRP_MISC = 0x1d,259WMI_GRP_GPIO = 0x1e,260WMI_GRP_FWTEST = 0x1f,261WMI_GRP_TDLS = 0x20,262WMI_GRP_RESMGR = 0x21,263WMI_GRP_STA_SMPS = 0x22,264WMI_GRP_WLAN_HB = 0x23,265WMI_GRP_RMC = 0x24,266WMI_GRP_MHF_OFL = 0x25,267WMI_GRP_LOCATION_SCAN = 0x26,268WMI_GRP_OEM = 0x27,269WMI_GRP_NAN = 0x28,270WMI_GRP_COEX = 0x29,271WMI_GRP_OBSS_OFL = 0x2a,272WMI_GRP_LPI = 0x2b,273WMI_GRP_EXTSCAN = 0x2c,274WMI_GRP_DHCP_OFL = 0x2d,275WMI_GRP_IPA = 0x2e,276WMI_GRP_MDNS_OFL = 0x2f,277WMI_GRP_SAP_OFL = 0x30,278WMI_GRP_OCB = 0x31,279WMI_GRP_SOC = 0x32,280WMI_GRP_PKT_FILTER = 0x33,281WMI_GRP_MAWC = 0x34,282WMI_GRP_PMF_OFFLOAD = 0x35,283WMI_GRP_BPF_OFFLOAD = 0x36,284WMI_GRP_NAN_DATA = 0x37,285WMI_GRP_PROTOTYPE = 0x38,286WMI_GRP_MONITOR = 0x39,287WMI_GRP_REGULATORY = 0x3a,288WMI_GRP_HW_DATA_FILTER = 0x3b,289WMI_GRP_WLM = 0x3c,290WMI_GRP_11K_OFFLOAD = 0x3d,291WMI_GRP_TWT = 0x3e,292WMI_GRP_MOTION_DET = 0x3f,293WMI_GRP_SPATIAL_REUSE = 0x40,294};295296#define WMI_CMD_GRP(grp_id) (((grp_id) << 12) | 0x1)297#define WMI_EVT_GRP_START_ID(grp_id) (((grp_id) << 12) | 0x1)298299enum wmi_tlv_cmd_id {300WMI_CMD_UNSUPPORTED = 0,301WMI_INIT_CMDID = 0x1,302WMI_START_SCAN_CMDID = WMI_TLV_CMD(WMI_GRP_SCAN),303WMI_STOP_SCAN_CMDID,304WMI_SCAN_CHAN_LIST_CMDID,305WMI_SCAN_SCH_PRIO_TBL_CMDID,306WMI_SCAN_UPDATE_REQUEST_CMDID,307WMI_SCAN_PROB_REQ_OUI_CMDID,308WMI_SCAN_ADAPTIVE_DWELL_CONFIG_CMDID,309WMI_PDEV_SET_REGDOMAIN_CMDID = WMI_TLV_CMD(WMI_GRP_PDEV),310WMI_PDEV_SET_CHANNEL_CMDID,311WMI_PDEV_SET_PARAM_CMDID,312WMI_PDEV_PKTLOG_ENABLE_CMDID,313WMI_PDEV_PKTLOG_DISABLE_CMDID,314WMI_PDEV_SET_WMM_PARAMS_CMDID,315WMI_PDEV_SET_HT_CAP_IE_CMDID,316WMI_PDEV_SET_VHT_CAP_IE_CMDID,317WMI_PDEV_SET_DSCP_TID_MAP_CMDID,318WMI_PDEV_SET_QUIET_MODE_CMDID,319WMI_PDEV_GREEN_AP_PS_ENABLE_CMDID,320WMI_PDEV_GET_TPC_CONFIG_CMDID,321WMI_PDEV_SET_BASE_MACADDR_CMDID,322WMI_PDEV_DUMP_CMDID,323WMI_PDEV_SET_LED_CONFIG_CMDID,324WMI_PDEV_GET_TEMPERATURE_CMDID,325WMI_PDEV_SET_LED_FLASHING_CMDID,326WMI_PDEV_SMART_ANT_ENABLE_CMDID,327WMI_PDEV_SMART_ANT_SET_RX_ANTENNA_CMDID,328WMI_PDEV_SET_ANTENNA_SWITCH_TABLE_CMDID,329WMI_PDEV_SET_CTL_TABLE_CMDID,330WMI_PDEV_SET_MIMOGAIN_TABLE_CMDID,331WMI_PDEV_FIPS_CMDID,332WMI_PDEV_GET_ANI_CCK_CONFIG_CMDID,333WMI_PDEV_GET_ANI_OFDM_CONFIG_CMDID,334WMI_PDEV_GET_NFCAL_POWER_CMDID,335WMI_PDEV_GET_TPC_CMDID,336WMI_MIB_STATS_ENABLE_CMDID,337WMI_PDEV_SET_PCL_CMDID,338WMI_PDEV_SET_HW_MODE_CMDID,339WMI_PDEV_SET_MAC_CONFIG_CMDID,340WMI_PDEV_SET_ANTENNA_MODE_CMDID,341WMI_SET_PERIODIC_CHANNEL_STATS_CONFIG_CMDID,342WMI_PDEV_WAL_POWER_DEBUG_CMDID,343WMI_PDEV_SET_REORDER_TIMEOUT_VAL_CMDID,344WMI_PDEV_SET_WAKEUP_CONFIG_CMDID,345WMI_PDEV_GET_ANTDIV_STATUS_CMDID,346WMI_PDEV_GET_CHIP_POWER_STATS_CMDID,347WMI_PDEV_SET_STATS_THRESHOLD_CMDID,348WMI_PDEV_MULTIPLE_VDEV_RESTART_REQUEST_CMDID,349WMI_PDEV_UPDATE_PKT_ROUTING_CMDID,350WMI_PDEV_CHECK_CAL_VERSION_CMDID,351WMI_PDEV_SET_DIVERSITY_GAIN_CMDID,352WMI_PDEV_DIV_GET_RSSI_ANTID_CMDID,353WMI_PDEV_BSS_CHAN_INFO_REQUEST_CMDID,354WMI_PDEV_UPDATE_PMK_CACHE_CMDID,355WMI_PDEV_UPDATE_FILS_HLP_PKT_CMDID,356WMI_PDEV_UPDATE_CTLTABLE_REQUEST_CMDID,357WMI_PDEV_CONFIG_VENDOR_OUI_ACTION_CMDID,358WMI_PDEV_SET_AC_TX_QUEUE_OPTIMIZED_CMDID,359WMI_PDEV_SET_RX_FILTER_PROMISCUOUS_CMDID,360WMI_PDEV_DMA_RING_CFG_REQ_CMDID,361WMI_PDEV_HE_TB_ACTION_FRM_CMDID,362WMI_PDEV_PKTLOG_FILTER_CMDID,363WMI_VDEV_CREATE_CMDID = WMI_TLV_CMD(WMI_GRP_VDEV),364WMI_VDEV_DELETE_CMDID,365WMI_VDEV_START_REQUEST_CMDID,366WMI_VDEV_RESTART_REQUEST_CMDID,367WMI_VDEV_UP_CMDID,368WMI_VDEV_STOP_CMDID,369WMI_VDEV_DOWN_CMDID,370WMI_VDEV_SET_PARAM_CMDID,371WMI_VDEV_INSTALL_KEY_CMDID,372WMI_VDEV_WNM_SLEEPMODE_CMDID,373WMI_VDEV_WMM_ADDTS_CMDID,374WMI_VDEV_WMM_DELTS_CMDID,375WMI_VDEV_SET_WMM_PARAMS_CMDID,376WMI_VDEV_SET_GTX_PARAMS_CMDID,377WMI_VDEV_IPSEC_NATKEEPALIVE_FILTER_CMDID,378WMI_VDEV_PLMREQ_START_CMDID,379WMI_VDEV_PLMREQ_STOP_CMDID,380WMI_VDEV_TSF_TSTAMP_ACTION_CMDID,381WMI_VDEV_SET_IE_CMDID,382WMI_VDEV_RATEMASK_CMDID,383WMI_VDEV_ATF_REQUEST_CMDID,384WMI_VDEV_SET_DSCP_TID_MAP_CMDID,385WMI_VDEV_FILTER_NEIGHBOR_RX_PACKETS_CMDID,386WMI_VDEV_SET_QUIET_MODE_CMDID,387WMI_VDEV_SET_CUSTOM_AGGR_SIZE_CMDID,388WMI_VDEV_ENCRYPT_DECRYPT_DATA_REQ_CMDID,389WMI_VDEV_ADD_MAC_ADDR_TO_RX_FILTER_CMDID,390WMI_PEER_CREATE_CMDID = WMI_TLV_CMD(WMI_GRP_PEER),391WMI_PEER_DELETE_CMDID,392WMI_PEER_FLUSH_TIDS_CMDID,393WMI_PEER_SET_PARAM_CMDID,394WMI_PEER_ASSOC_CMDID,395WMI_PEER_ADD_WDS_ENTRY_CMDID,396WMI_PEER_REMOVE_WDS_ENTRY_CMDID,397WMI_PEER_MCAST_GROUP_CMDID,398WMI_PEER_INFO_REQ_CMDID,399WMI_PEER_GET_ESTIMATED_LINKSPEED_CMDID,400WMI_PEER_SET_RATE_REPORT_CONDITION_CMDID,401WMI_PEER_UPDATE_WDS_ENTRY_CMDID,402WMI_PEER_ADD_PROXY_STA_ENTRY_CMDID,403WMI_PEER_SMART_ANT_SET_TX_ANTENNA_CMDID,404WMI_PEER_SMART_ANT_SET_TRAIN_INFO_CMDID,405WMI_PEER_SMART_ANT_SET_NODE_CONFIG_OPS_CMDID,406WMI_PEER_ATF_REQUEST_CMDID,407WMI_PEER_BWF_REQUEST_CMDID,408WMI_PEER_REORDER_QUEUE_SETUP_CMDID,409WMI_PEER_REORDER_QUEUE_REMOVE_CMDID,410WMI_PEER_SET_RX_BLOCKSIZE_CMDID,411WMI_PEER_ANTDIV_INFO_REQ_CMDID,412WMI_BCN_TX_CMDID = WMI_TLV_CMD(WMI_GRP_MGMT),413WMI_PDEV_SEND_BCN_CMDID,414WMI_BCN_TMPL_CMDID,415WMI_BCN_FILTER_RX_CMDID,416WMI_PRB_REQ_FILTER_RX_CMDID,417WMI_MGMT_TX_CMDID,418WMI_PRB_TMPL_CMDID,419WMI_MGMT_TX_SEND_CMDID,420WMI_OFFCHAN_DATA_TX_SEND_CMDID,421WMI_PDEV_SEND_FD_CMDID,422WMI_BCN_OFFLOAD_CTRL_CMDID,423WMI_BSS_COLOR_CHANGE_ENABLE_CMDID,424WMI_VDEV_BCN_OFFLOAD_QUIET_CONFIG_CMDID,425WMI_FILS_DISCOVERY_TMPL_CMDID,426WMI_ADDBA_CLEAR_RESP_CMDID = WMI_TLV_CMD(WMI_GRP_BA_NEG),427WMI_ADDBA_SEND_CMDID,428WMI_ADDBA_STATUS_CMDID,429WMI_DELBA_SEND_CMDID,430WMI_ADDBA_SET_RESP_CMDID,431WMI_SEND_SINGLEAMSDU_CMDID,432WMI_STA_POWERSAVE_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_STA_PS),433WMI_STA_POWERSAVE_PARAM_CMDID,434WMI_STA_MIMO_PS_MODE_CMDID,435WMI_PDEV_DFS_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_DFS),436WMI_PDEV_DFS_DISABLE_CMDID,437WMI_DFS_PHYERR_FILTER_ENA_CMDID,438WMI_DFS_PHYERR_FILTER_DIS_CMDID,439WMI_PDEV_DFS_PHYERR_OFFLOAD_ENABLE_CMDID,440WMI_PDEV_DFS_PHYERR_OFFLOAD_DISABLE_CMDID,441WMI_VDEV_ADFS_CH_CFG_CMDID,442WMI_VDEV_ADFS_OCAC_ABORT_CMDID,443WMI_ROAM_SCAN_MODE = WMI_TLV_CMD(WMI_GRP_ROAM),444WMI_ROAM_SCAN_RSSI_THRESHOLD,445WMI_ROAM_SCAN_PERIOD,446WMI_ROAM_SCAN_RSSI_CHANGE_THRESHOLD,447WMI_ROAM_AP_PROFILE,448WMI_ROAM_CHAN_LIST,449WMI_ROAM_SCAN_CMD,450WMI_ROAM_SYNCH_COMPLETE,451WMI_ROAM_SET_RIC_REQUEST_CMDID,452WMI_ROAM_INVOKE_CMDID,453WMI_ROAM_FILTER_CMDID,454WMI_ROAM_SUBNET_CHANGE_CONFIG_CMDID,455WMI_ROAM_CONFIGURE_MAWC_CMDID,456WMI_ROAM_SET_MBO_PARAM_CMDID,457WMI_ROAM_PER_CONFIG_CMDID,458WMI_ROAM_BTM_CONFIG_CMDID,459WMI_ENABLE_FILS_CMDID,460WMI_OFL_SCAN_ADD_AP_PROFILE = WMI_TLV_CMD(WMI_GRP_OFL_SCAN),461WMI_OFL_SCAN_REMOVE_AP_PROFILE,462WMI_OFL_SCAN_PERIOD,463WMI_P2P_DEV_SET_DEVICE_INFO = WMI_TLV_CMD(WMI_GRP_P2P),464WMI_P2P_DEV_SET_DISCOVERABILITY,465WMI_P2P_GO_SET_BEACON_IE,466WMI_P2P_GO_SET_PROBE_RESP_IE,467WMI_P2P_SET_VENDOR_IE_DATA_CMDID,468WMI_P2P_DISC_OFFLOAD_CONFIG_CMDID,469WMI_P2P_DISC_OFFLOAD_APPIE_CMDID,470WMI_P2P_DISC_OFFLOAD_PATTERN_CMDID,471WMI_P2P_SET_OPPPS_PARAM_CMDID,472WMI_P2P_LISTEN_OFFLOAD_START_CMDID,473WMI_P2P_LISTEN_OFFLOAD_STOP_CMDID,474WMI_AP_PS_PEER_PARAM_CMDID = WMI_TLV_CMD(WMI_GRP_AP_PS),475WMI_AP_PS_PEER_UAPSD_COEX_CMDID,476WMI_AP_PS_EGAP_PARAM_CMDID,477WMI_PEER_RATE_RETRY_SCHED_CMDID = WMI_TLV_CMD(WMI_GRP_RATE_CTRL),478WMI_WLAN_PROFILE_TRIGGER_CMDID = WMI_TLV_CMD(WMI_GRP_PROFILE),479WMI_WLAN_PROFILE_SET_HIST_INTVL_CMDID,480WMI_WLAN_PROFILE_GET_PROFILE_DATA_CMDID,481WMI_WLAN_PROFILE_ENABLE_PROFILE_ID_CMDID,482WMI_WLAN_PROFILE_LIST_PROFILE_ID_CMDID,483WMI_PDEV_SUSPEND_CMDID = WMI_TLV_CMD(WMI_GRP_SUSPEND),484WMI_PDEV_RESUME_CMDID,485WMI_ADD_BCN_FILTER_CMDID = WMI_TLV_CMD(WMI_GRP_BCN_FILTER),486WMI_RMV_BCN_FILTER_CMDID,487WMI_WOW_ADD_WAKE_PATTERN_CMDID = WMI_TLV_CMD(WMI_GRP_WOW),488WMI_WOW_DEL_WAKE_PATTERN_CMDID,489WMI_WOW_ENABLE_DISABLE_WAKE_EVENT_CMDID,490WMI_WOW_ENABLE_CMDID,491WMI_WOW_HOSTWAKEUP_FROM_SLEEP_CMDID,492WMI_WOW_IOAC_ADD_KEEPALIVE_CMDID,493WMI_WOW_IOAC_DEL_KEEPALIVE_CMDID,494WMI_WOW_IOAC_ADD_WAKE_PATTERN_CMDID,495WMI_WOW_IOAC_DEL_WAKE_PATTERN_CMDID,496WMI_D0_WOW_ENABLE_DISABLE_CMDID,497WMI_EXTWOW_ENABLE_CMDID,498WMI_EXTWOW_SET_APP_TYPE1_PARAMS_CMDID,499WMI_EXTWOW_SET_APP_TYPE2_PARAMS_CMDID,500WMI_WOW_ENABLE_ICMPV6_NA_FLT_CMDID,501WMI_WOW_UDP_SVC_OFLD_CMDID,502WMI_WOW_HOSTWAKEUP_GPIO_PIN_PATTERN_CONFIG_CMDID,503WMI_WOW_SET_ACTION_WAKE_UP_CMDID,504WMI_RTT_MEASREQ_CMDID = WMI_TLV_CMD(WMI_GRP_RTT),505WMI_RTT_TSF_CMDID,506WMI_VDEV_SPECTRAL_SCAN_CONFIGURE_CMDID = WMI_TLV_CMD(WMI_GRP_SPECTRAL),507WMI_VDEV_SPECTRAL_SCAN_ENABLE_CMDID,508WMI_REQUEST_STATS_CMDID = WMI_TLV_CMD(WMI_GRP_STATS),509WMI_MCC_SCHED_TRAFFIC_STATS_CMDID,510WMI_REQUEST_STATS_EXT_CMDID,511WMI_REQUEST_LINK_STATS_CMDID,512WMI_START_LINK_STATS_CMDID,513WMI_CLEAR_LINK_STATS_CMDID,514WMI_GET_FW_MEM_DUMP_CMDID,515WMI_DEBUG_MESG_FLUSH_CMDID,516WMI_DIAG_EVENT_LOG_CONFIG_CMDID,517WMI_REQUEST_WLAN_STATS_CMDID,518WMI_REQUEST_RCPI_CMDID,519WMI_REQUEST_PEER_STATS_INFO_CMDID,520WMI_REQUEST_RADIO_CHAN_STATS_CMDID,521WMI_SET_ARP_NS_OFFLOAD_CMDID = WMI_TLV_CMD(WMI_GRP_ARP_NS_OFL),522WMI_ADD_PROACTIVE_ARP_RSP_PATTERN_CMDID,523WMI_DEL_PROACTIVE_ARP_RSP_PATTERN_CMDID,524WMI_NETWORK_LIST_OFFLOAD_CONFIG_CMDID = WMI_TLV_CMD(WMI_GRP_NLO_OFL),525WMI_APFIND_CMDID,526WMI_PASSPOINT_LIST_CONFIG_CMDID,527WMI_NLO_CONFIGURE_MAWC_CMDID,528WMI_GTK_OFFLOAD_CMDID = WMI_TLV_CMD(WMI_GRP_GTK_OFL),529WMI_CSA_OFFLOAD_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_CSA_OFL),530WMI_CSA_OFFLOAD_CHANSWITCH_CMDID,531WMI_CHATTER_SET_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_CHATTER),532WMI_CHATTER_ADD_COALESCING_FILTER_CMDID,533WMI_CHATTER_DELETE_COALESCING_FILTER_CMDID,534WMI_CHATTER_COALESCING_QUERY_CMDID,535WMI_PEER_TID_ADDBA_CMDID = WMI_TLV_CMD(WMI_GRP_TID_ADDBA),536WMI_PEER_TID_DELBA_CMDID,537WMI_STA_DTIM_PS_METHOD_CMDID,538WMI_STA_UAPSD_AUTO_TRIG_CMDID,539WMI_STA_KEEPALIVE_CMDID,540WMI_BA_REQ_SSN_CMDID,541WMI_ECHO_CMDID = WMI_TLV_CMD(WMI_GRP_MISC),542WMI_PDEV_UTF_CMDID,543WMI_DBGLOG_CFG_CMDID,544WMI_PDEV_QVIT_CMDID,545WMI_PDEV_FTM_INTG_CMDID,546WMI_VDEV_SET_KEEPALIVE_CMDID,547WMI_VDEV_GET_KEEPALIVE_CMDID,548WMI_FORCE_FW_HANG_CMDID,549WMI_SET_MCASTBCAST_FILTER_CMDID,550WMI_THERMAL_MGMT_CMDID,551WMI_HOST_AUTO_SHUTDOWN_CFG_CMDID,552WMI_TPC_CHAINMASK_CONFIG_CMDID,553WMI_SET_ANTENNA_DIVERSITY_CMDID,554WMI_OCB_SET_SCHED_CMDID,555WMI_RSSI_BREACH_MONITOR_CONFIG_CMDID,556WMI_LRO_CONFIG_CMDID,557WMI_TRANSFER_DATA_TO_FLASH_CMDID,558WMI_CONFIG_ENHANCED_MCAST_FILTER_CMDID,559WMI_VDEV_WISA_CMDID,560WMI_DBGLOG_TIME_STAMP_SYNC_CMDID,561WMI_SET_MULTIPLE_MCAST_FILTER_CMDID,562WMI_READ_DATA_FROM_FLASH_CMDID,563WMI_THERM_THROT_SET_CONF_CMDID,564WMI_RUNTIME_DPD_RECAL_CMDID,565WMI_GET_TPC_POWER_CMDID,566WMI_IDLE_TRIGGER_MONITOR_CMDID,567WMI_GPIO_CONFIG_CMDID = WMI_TLV_CMD(WMI_GRP_GPIO),568WMI_GPIO_OUTPUT_CMDID,569WMI_TXBF_CMDID,570WMI_FWTEST_VDEV_MCC_SET_TBTT_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_FWTEST),571WMI_FWTEST_P2P_SET_NOA_PARAM_CMDID,572WMI_UNIT_TEST_CMDID,573WMI_FWTEST_CMDID,574WMI_QBOOST_CFG_CMDID,575WMI_TDLS_SET_STATE_CMDID = WMI_TLV_CMD(WMI_GRP_TDLS),576WMI_TDLS_PEER_UPDATE_CMDID,577WMI_TDLS_SET_OFFCHAN_MODE_CMDID,578WMI_RESMGR_ADAPTIVE_OCS_EN_DIS_CMDID = WMI_TLV_CMD(WMI_GRP_RESMGR),579WMI_RESMGR_SET_CHAN_TIME_QUOTA_CMDID,580WMI_RESMGR_SET_CHAN_LATENCY_CMDID,581WMI_STA_SMPS_FORCE_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_STA_SMPS),582WMI_STA_SMPS_PARAM_CMDID,583WMI_HB_SET_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_WLAN_HB),584WMI_HB_SET_TCP_PARAMS_CMDID,585WMI_HB_SET_TCP_PKT_FILTER_CMDID,586WMI_HB_SET_UDP_PARAMS_CMDID,587WMI_HB_SET_UDP_PKT_FILTER_CMDID,588WMI_RMC_SET_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_RMC),589WMI_RMC_SET_ACTION_PERIOD_CMDID,590WMI_RMC_CONFIG_CMDID,591WMI_RMC_SET_MANUAL_LEADER_CMDID,592WMI_MHF_OFFLOAD_SET_MODE_CMDID = WMI_TLV_CMD(WMI_GRP_MHF_OFL),593WMI_MHF_OFFLOAD_PLUMB_ROUTING_TBL_CMDID,594WMI_BATCH_SCAN_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_LOCATION_SCAN),595WMI_BATCH_SCAN_DISABLE_CMDID,596WMI_BATCH_SCAN_TRIGGER_RESULT_CMDID,597WMI_OEM_REQ_CMDID = WMI_TLV_CMD(WMI_GRP_OEM),598WMI_OEM_REQUEST_CMDID,599WMI_LPI_OEM_REQ_CMDID,600WMI_NAN_CMDID = WMI_TLV_CMD(WMI_GRP_NAN),601WMI_MODEM_POWER_STATE_CMDID = WMI_TLV_CMD(WMI_GRP_COEX),602WMI_CHAN_AVOID_UPDATE_CMDID,603WMI_COEX_CONFIG_CMDID,604WMI_CHAN_AVOID_RPT_ALLOW_CMDID,605WMI_COEX_GET_ANTENNA_ISOLATION_CMDID,606WMI_SAR_LIMITS_CMDID,607WMI_OBSS_SCAN_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_OBSS_OFL),608WMI_OBSS_SCAN_DISABLE_CMDID,609WMI_OBSS_COLOR_COLLISION_DET_CONFIG_CMDID,610WMI_LPI_MGMT_SNOOPING_CONFIG_CMDID = WMI_TLV_CMD(WMI_GRP_LPI),611WMI_LPI_START_SCAN_CMDID,612WMI_LPI_STOP_SCAN_CMDID,613WMI_EXTSCAN_START_CMDID = WMI_TLV_CMD(WMI_GRP_EXTSCAN),614WMI_EXTSCAN_STOP_CMDID,615WMI_EXTSCAN_CONFIGURE_WLAN_CHANGE_MONITOR_CMDID,616WMI_EXTSCAN_CONFIGURE_HOTLIST_MONITOR_CMDID,617WMI_EXTSCAN_GET_CACHED_RESULTS_CMDID,618WMI_EXTSCAN_GET_WLAN_CHANGE_RESULTS_CMDID,619WMI_EXTSCAN_SET_CAPABILITIES_CMDID,620WMI_EXTSCAN_GET_CAPABILITIES_CMDID,621WMI_EXTSCAN_CONFIGURE_HOTLIST_SSID_MONITOR_CMDID,622WMI_EXTSCAN_CONFIGURE_MAWC_CMDID,623WMI_SET_DHCP_SERVER_OFFLOAD_CMDID = WMI_TLV_CMD(WMI_GRP_DHCP_OFL),624WMI_IPA_OFFLOAD_ENABLE_DISABLE_CMDID = WMI_TLV_CMD(WMI_GRP_IPA),625WMI_MDNS_OFFLOAD_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_MDNS_OFL),626WMI_MDNS_SET_FQDN_CMDID,627WMI_MDNS_SET_RESPONSE_CMDID,628WMI_MDNS_GET_STATS_CMDID,629WMI_SAP_OFL_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_SAP_OFL),630WMI_SAP_SET_BLACKLIST_PARAM_CMDID,631WMI_OCB_SET_CONFIG_CMDID = WMI_TLV_CMD(WMI_GRP_OCB),632WMI_OCB_SET_UTC_TIME_CMDID,633WMI_OCB_START_TIMING_ADVERT_CMDID,634WMI_OCB_STOP_TIMING_ADVERT_CMDID,635WMI_OCB_GET_TSF_TIMER_CMDID,636WMI_DCC_GET_STATS_CMDID,637WMI_DCC_CLEAR_STATS_CMDID,638WMI_DCC_UPDATE_NDL_CMDID,639WMI_SOC_SET_PCL_CMDID = WMI_TLV_CMD(WMI_GRP_SOC),640WMI_SOC_SET_HW_MODE_CMDID,641WMI_SOC_SET_DUAL_MAC_CONFIG_CMDID,642WMI_SOC_SET_ANTENNA_MODE_CMDID,643WMI_PACKET_FILTER_CONFIG_CMDID = WMI_TLV_CMD(WMI_GRP_PKT_FILTER),644WMI_PACKET_FILTER_ENABLE_CMDID,645WMI_MAWC_SENSOR_REPORT_IND_CMDID = WMI_TLV_CMD(WMI_GRP_MAWC),646WMI_PMF_OFFLOAD_SET_SA_QUERY_CMDID = WMI_TLV_CMD(WMI_GRP_PMF_OFFLOAD),647WMI_BPF_GET_CAPABILITY_CMDID = WMI_TLV_CMD(WMI_GRP_BPF_OFFLOAD),648WMI_BPF_GET_VDEV_STATS_CMDID,649WMI_BPF_SET_VDEV_INSTRUCTIONS_CMDID,650WMI_BPF_DEL_VDEV_INSTRUCTIONS_CMDID,651WMI_BPF_SET_VDEV_ACTIVE_MODE_CMDID,652WMI_MNT_FILTER_CMDID = WMI_TLV_CMD(WMI_GRP_MONITOR),653WMI_SET_CURRENT_COUNTRY_CMDID = WMI_TLV_CMD(WMI_GRP_REGULATORY),654WMI_11D_SCAN_START_CMDID,655WMI_11D_SCAN_STOP_CMDID,656WMI_SET_INIT_COUNTRY_CMDID,657WMI_NDI_GET_CAP_REQ_CMDID = WMI_TLV_CMD(WMI_GRP_PROTOTYPE),658WMI_NDP_INITIATOR_REQ_CMDID,659WMI_NDP_RESPONDER_REQ_CMDID,660WMI_NDP_END_REQ_CMDID,661WMI_HW_DATA_FILTER_CMDID = WMI_TLV_CMD(WMI_GRP_HW_DATA_FILTER),662WMI_TWT_ENABLE_CMDID = WMI_TLV_CMD(WMI_GRP_TWT),663WMI_TWT_DISABLE_CMDID,664WMI_TWT_ADD_DIALOG_CMDID,665WMI_TWT_DEL_DIALOG_CMDID,666WMI_TWT_PAUSE_DIALOG_CMDID,667WMI_TWT_RESUME_DIALOG_CMDID,668WMI_PDEV_OBSS_PD_SPATIAL_REUSE_CMDID =669WMI_TLV_CMD(WMI_GRP_SPATIAL_REUSE),670WMI_PDEV_OBSS_PD_SPATIAL_REUSE_SET_DEF_OBSS_THRESH_CMDID,671};672673enum wmi_tlv_event_id {674WMI_SERVICE_READY_EVENTID = 0x1,675WMI_READY_EVENTID,676WMI_SERVICE_AVAILABLE_EVENTID,677WMI_SCAN_EVENTID = WMI_EVT_GRP_START_ID(WMI_GRP_SCAN),678WMI_PDEV_TPC_CONFIG_EVENTID = WMI_TLV_CMD(WMI_GRP_PDEV),679WMI_CHAN_INFO_EVENTID,680WMI_PHYERR_EVENTID,681WMI_PDEV_DUMP_EVENTID,682WMI_TX_PAUSE_EVENTID,683WMI_DFS_RADAR_EVENTID,684WMI_PDEV_L1SS_TRACK_EVENTID,685WMI_PDEV_TEMPERATURE_EVENTID,686WMI_SERVICE_READY_EXT_EVENTID,687WMI_PDEV_FIPS_EVENTID,688WMI_PDEV_CHANNEL_HOPPING_EVENTID,689WMI_PDEV_ANI_CCK_LEVEL_EVENTID,690WMI_PDEV_ANI_OFDM_LEVEL_EVENTID,691WMI_PDEV_TPC_EVENTID,692WMI_PDEV_NFCAL_POWER_ALL_CHANNELS_EVENTID,693WMI_PDEV_SET_HW_MODE_RESP_EVENTID,694WMI_PDEV_HW_MODE_TRANSITION_EVENTID,695WMI_PDEV_SET_MAC_CONFIG_RESP_EVENTID,696WMI_PDEV_ANTDIV_STATUS_EVENTID,697WMI_PDEV_CHIP_POWER_STATS_EVENTID,698WMI_PDEV_CHIP_POWER_SAVE_FAILURE_DETECTED_EVENTID,699WMI_PDEV_CSA_SWITCH_COUNT_STATUS_EVENTID,700WMI_PDEV_CHECK_CAL_VERSION_EVENTID,701WMI_PDEV_DIV_RSSI_ANTID_EVENTID,702WMI_PDEV_BSS_CHAN_INFO_EVENTID,703WMI_PDEV_UPDATE_CTLTABLE_EVENTID,704WMI_PDEV_DMA_RING_CFG_RSP_EVENTID,705WMI_PDEV_DMA_RING_BUF_RELEASE_EVENTID,706WMI_PDEV_CTL_FAILSAFE_CHECK_EVENTID,707WMI_PDEV_CSC_SWITCH_COUNT_STATUS_EVENTID,708WMI_PDEV_COLD_BOOT_CAL_DATA_EVENTID,709WMI_PDEV_RAP_INFO_EVENTID,710WMI_CHAN_RF_CHARACTERIZATION_INFO_EVENTID,711WMI_SERVICE_READY_EXT2_EVENTID,712WMI_VDEV_START_RESP_EVENTID = WMI_TLV_CMD(WMI_GRP_VDEV),713WMI_VDEV_STOPPED_EVENTID,714WMI_VDEV_INSTALL_KEY_COMPLETE_EVENTID,715WMI_VDEV_MCC_BCN_INTERVAL_CHANGE_REQ_EVENTID,716WMI_VDEV_TSF_REPORT_EVENTID,717WMI_VDEV_DELETE_RESP_EVENTID,718WMI_VDEV_ENCRYPT_DECRYPT_DATA_RESP_EVENTID,719WMI_VDEV_ADD_MAC_ADDR_TO_RX_FILTER_STATUS_EVENTID,720WMI_PEER_STA_KICKOUT_EVENTID = WMI_TLV_CMD(WMI_GRP_PEER),721WMI_PEER_INFO_EVENTID,722WMI_PEER_TX_FAIL_CNT_THR_EVENTID,723WMI_PEER_ESTIMATED_LINKSPEED_EVENTID,724WMI_PEER_STATE_EVENTID,725WMI_PEER_ASSOC_CONF_EVENTID,726WMI_PEER_DELETE_RESP_EVENTID,727WMI_PEER_RATECODE_LIST_EVENTID,728WMI_WDS_PEER_EVENTID,729WMI_PEER_STA_PS_STATECHG_EVENTID,730WMI_PEER_ANTDIV_INFO_EVENTID,731WMI_PEER_RESERVED0_EVENTID,732WMI_PEER_RESERVED1_EVENTID,733WMI_PEER_RESERVED2_EVENTID,734WMI_PEER_RESERVED3_EVENTID,735WMI_PEER_RESERVED4_EVENTID,736WMI_PEER_RESERVED5_EVENTID,737WMI_PEER_RESERVED6_EVENTID,738WMI_PEER_RESERVED7_EVENTID,739WMI_PEER_RESERVED8_EVENTID,740WMI_PEER_RESERVED9_EVENTID,741WMI_PEER_RESERVED10_EVENTID,742WMI_PEER_OPER_MODE_CHANGE_EVENTID,743WMI_MGMT_RX_EVENTID = WMI_TLV_CMD(WMI_GRP_MGMT),744WMI_HOST_SWBA_EVENTID,745WMI_TBTTOFFSET_UPDATE_EVENTID,746WMI_OFFLOAD_BCN_TX_STATUS_EVENTID,747WMI_OFFLOAD_PROB_RESP_TX_STATUS_EVENTID,748WMI_MGMT_TX_COMPLETION_EVENTID,749WMI_MGMT_TX_BUNDLE_COMPLETION_EVENTID,750WMI_TBTTOFFSET_EXT_UPDATE_EVENTID,751WMI_OFFCHAN_DATA_TX_COMPLETION_EVENTID,752WMI_HOST_FILS_DISCOVERY_EVENTID,753WMI_TX_DELBA_COMPLETE_EVENTID = WMI_TLV_CMD(WMI_GRP_BA_NEG),754WMI_TX_ADDBA_COMPLETE_EVENTID,755WMI_BA_RSP_SSN_EVENTID,756WMI_AGGR_STATE_TRIG_EVENTID,757WMI_ROAM_EVENTID = WMI_TLV_CMD(WMI_GRP_ROAM),758WMI_PROFILE_MATCH,759WMI_ROAM_SYNCH_EVENTID,760WMI_P2P_DISC_EVENTID = WMI_TLV_CMD(WMI_GRP_P2P),761WMI_P2P_NOA_EVENTID,762WMI_P2P_LISTEN_OFFLOAD_STOPPED_EVENTID,763WMI_AP_PS_EGAP_INFO_EVENTID = WMI_TLV_CMD(WMI_GRP_AP_PS),764WMI_PDEV_RESUME_EVENTID = WMI_TLV_CMD(WMI_GRP_SUSPEND),765WMI_WOW_WAKEUP_HOST_EVENTID = WMI_TLV_CMD(WMI_GRP_WOW),766WMI_D0_WOW_DISABLE_ACK_EVENTID,767WMI_WOW_INITIAL_WAKEUP_EVENTID,768WMI_RTT_MEASUREMENT_REPORT_EVENTID = WMI_TLV_CMD(WMI_GRP_RTT),769WMI_TSF_MEASUREMENT_REPORT_EVENTID,770WMI_RTT_ERROR_REPORT_EVENTID,771WMI_STATS_EXT_EVENTID = WMI_TLV_CMD(WMI_GRP_STATS),772WMI_IFACE_LINK_STATS_EVENTID,773WMI_PEER_LINK_STATS_EVENTID,774WMI_RADIO_LINK_STATS_EVENTID,775WMI_UPDATE_FW_MEM_DUMP_EVENTID,776WMI_DIAG_EVENT_LOG_SUPPORTED_EVENTID,777WMI_INST_RSSI_STATS_EVENTID,778WMI_RADIO_TX_POWER_LEVEL_STATS_EVENTID,779WMI_REPORT_STATS_EVENTID,780WMI_UPDATE_RCPI_EVENTID,781WMI_PEER_STATS_INFO_EVENTID,782WMI_RADIO_CHAN_STATS_EVENTID,783WMI_NLO_MATCH_EVENTID = WMI_TLV_CMD(WMI_GRP_NLO_OFL),784WMI_NLO_SCAN_COMPLETE_EVENTID,785WMI_APFIND_EVENTID,786WMI_PASSPOINT_MATCH_EVENTID,787WMI_GTK_OFFLOAD_STATUS_EVENTID = WMI_TLV_CMD(WMI_GRP_GTK_OFL),788WMI_GTK_REKEY_FAIL_EVENTID,789WMI_CSA_HANDLING_EVENTID = WMI_TLV_CMD(WMI_GRP_CSA_OFL),790WMI_CHATTER_PC_QUERY_EVENTID = WMI_TLV_CMD(WMI_GRP_CHATTER),791WMI_PDEV_DFS_RADAR_DETECTION_EVENTID = WMI_TLV_CMD(WMI_GRP_DFS),792WMI_VDEV_DFS_CAC_COMPLETE_EVENTID,793WMI_VDEV_ADFS_OCAC_COMPLETE_EVENTID,794WMI_ECHO_EVENTID = WMI_TLV_CMD(WMI_GRP_MISC),795WMI_PDEV_UTF_EVENTID,796WMI_DEBUG_MESG_EVENTID,797WMI_UPDATE_STATS_EVENTID,798WMI_DEBUG_PRINT_EVENTID,799WMI_DCS_INTERFERENCE_EVENTID,800WMI_PDEV_QVIT_EVENTID,801WMI_WLAN_PROFILE_DATA_EVENTID,802WMI_PDEV_FTM_INTG_EVENTID,803WMI_WLAN_FREQ_AVOID_EVENTID,804WMI_VDEV_GET_KEEPALIVE_EVENTID,805WMI_THERMAL_MGMT_EVENTID,806WMI_DIAG_DATA_CONTAINER_EVENTID,807WMI_HOST_AUTO_SHUTDOWN_EVENTID,808WMI_UPDATE_WHAL_MIB_STATS_EVENTID,809WMI_UPDATE_VDEV_RATE_STATS_EVENTID,810WMI_DIAG_EVENTID,811WMI_OCB_SET_SCHED_EVENTID,812WMI_DEBUG_MESG_FLUSH_COMPLETE_EVENTID,813WMI_RSSI_BREACH_EVENTID,814WMI_TRANSFER_DATA_TO_FLASH_COMPLETE_EVENTID,815WMI_PDEV_UTF_SCPC_EVENTID,816WMI_READ_DATA_FROM_FLASH_EVENTID,817WMI_REPORT_RX_AGGR_FAILURE_EVENTID,818WMI_PKGID_EVENTID,819WMI_GPIO_INPUT_EVENTID = WMI_TLV_CMD(WMI_GRP_GPIO),820WMI_UPLOADH_EVENTID,821WMI_CAPTUREH_EVENTID,822WMI_RFKILL_STATE_CHANGE_EVENTID,823WMI_TDLS_PEER_EVENTID = WMI_TLV_CMD(WMI_GRP_TDLS),824WMI_STA_SMPS_FORCE_MODE_COMPL_EVENTID = WMI_TLV_CMD(WMI_GRP_STA_SMPS),825WMI_BATCH_SCAN_ENABLED_EVENTID = WMI_TLV_CMD(WMI_GRP_LOCATION_SCAN),826WMI_BATCH_SCAN_RESULT_EVENTID,827WMI_OEM_CAPABILITY_EVENTID = WMI_TLV_CMD(WMI_GRP_OEM),828WMI_OEM_MEASUREMENT_REPORT_EVENTID,829WMI_OEM_ERROR_REPORT_EVENTID,830WMI_OEM_RESPONSE_EVENTID,831WMI_NAN_EVENTID = WMI_TLV_CMD(WMI_GRP_NAN),832WMI_NAN_DISC_IFACE_CREATED_EVENTID,833WMI_NAN_DISC_IFACE_DELETED_EVENTID,834WMI_NAN_STARTED_CLUSTER_EVENTID,835WMI_NAN_JOINED_CLUSTER_EVENTID,836WMI_COEX_REPORT_ANTENNA_ISOLATION_EVENTID = WMI_TLV_CMD(WMI_GRP_COEX),837WMI_LPI_RESULT_EVENTID = WMI_TLV_CMD(WMI_GRP_LPI),838WMI_LPI_STATUS_EVENTID,839WMI_LPI_HANDOFF_EVENTID,840WMI_EXTSCAN_START_STOP_EVENTID = WMI_TLV_CMD(WMI_GRP_EXTSCAN),841WMI_EXTSCAN_OPERATION_EVENTID,842WMI_EXTSCAN_TABLE_USAGE_EVENTID,843WMI_EXTSCAN_CACHED_RESULTS_EVENTID,844WMI_EXTSCAN_WLAN_CHANGE_RESULTS_EVENTID,845WMI_EXTSCAN_HOTLIST_MATCH_EVENTID,846WMI_EXTSCAN_CAPABILITIES_EVENTID,847WMI_EXTSCAN_HOTLIST_SSID_MATCH_EVENTID,848WMI_MDNS_STATS_EVENTID = WMI_TLV_CMD(WMI_GRP_MDNS_OFL),849WMI_SAP_OFL_ADD_STA_EVENTID = WMI_TLV_CMD(WMI_GRP_SAP_OFL),850WMI_SAP_OFL_DEL_STA_EVENTID,851WMI_OCB_SET_CONFIG_RESP_EVENTID = WMI_TLV_CMD(WMI_GRP_OCB),852WMI_OCB_GET_TSF_TIMER_RESP_EVENTID,853WMI_DCC_GET_STATS_RESP_EVENTID,854WMI_DCC_UPDATE_NDL_RESP_EVENTID,855WMI_DCC_STATS_EVENTID,856WMI_SOC_SET_HW_MODE_RESP_EVENTID = WMI_TLV_CMD(WMI_GRP_SOC),857WMI_SOC_HW_MODE_TRANSITION_EVENTID,858WMI_SOC_SET_DUAL_MAC_CONFIG_RESP_EVENTID,859WMI_MAWC_ENABLE_SENSOR_EVENTID = WMI_TLV_CMD(WMI_GRP_MAWC),860WMI_BPF_CAPABILIY_INFO_EVENTID = WMI_TLV_CMD(WMI_GRP_BPF_OFFLOAD),861WMI_BPF_VDEV_STATS_INFO_EVENTID,862WMI_RMC_NEW_LEADER_EVENTID = WMI_TLV_CMD(WMI_GRP_RMC),863WMI_REG_CHAN_LIST_CC_EVENTID = WMI_TLV_CMD(WMI_GRP_REGULATORY),864WMI_11D_NEW_COUNTRY_EVENTID,865WMI_REG_CHAN_LIST_CC_EXT_EVENTID,866WMI_NDI_CAP_RSP_EVENTID = WMI_TLV_CMD(WMI_GRP_PROTOTYPE),867WMI_NDP_INITIATOR_RSP_EVENTID,868WMI_NDP_RESPONDER_RSP_EVENTID,869WMI_NDP_END_RSP_EVENTID,870WMI_NDP_INDICATION_EVENTID,871WMI_NDP_CONFIRM_EVENTID,872WMI_NDP_END_INDICATION_EVENTID,873874WMI_TWT_ENABLE_EVENTID = WMI_TLV_CMD(WMI_GRP_TWT),875WMI_TWT_DISABLE_EVENTID,876WMI_TWT_ADD_DIALOG_EVENTID,877WMI_TWT_DEL_DIALOG_EVENTID,878WMI_TWT_PAUSE_DIALOG_EVENTID,879WMI_TWT_RESUME_DIALOG_EVENTID,880};881882enum wmi_tlv_pdev_param {883WMI_PDEV_PARAM_TX_CHAIN_MASK = 0x1,884WMI_PDEV_PARAM_RX_CHAIN_MASK,885WMI_PDEV_PARAM_TXPOWER_LIMIT2G,886WMI_PDEV_PARAM_TXPOWER_LIMIT5G,887WMI_PDEV_PARAM_TXPOWER_SCALE,888WMI_PDEV_PARAM_BEACON_GEN_MODE,889WMI_PDEV_PARAM_BEACON_TX_MODE,890WMI_PDEV_PARAM_RESMGR_OFFCHAN_MODE,891WMI_PDEV_PARAM_PROTECTION_MODE,892WMI_PDEV_PARAM_DYNAMIC_BW,893WMI_PDEV_PARAM_NON_AGG_SW_RETRY_TH,894WMI_PDEV_PARAM_AGG_SW_RETRY_TH,895WMI_PDEV_PARAM_STA_KICKOUT_TH,896WMI_PDEV_PARAM_AC_AGGRSIZE_SCALING,897WMI_PDEV_PARAM_LTR_ENABLE,898WMI_PDEV_PARAM_LTR_AC_LATENCY_BE,899WMI_PDEV_PARAM_LTR_AC_LATENCY_BK,900WMI_PDEV_PARAM_LTR_AC_LATENCY_VI,901WMI_PDEV_PARAM_LTR_AC_LATENCY_VO,902WMI_PDEV_PARAM_LTR_AC_LATENCY_TIMEOUT,903WMI_PDEV_PARAM_LTR_SLEEP_OVERRIDE,904WMI_PDEV_PARAM_LTR_RX_OVERRIDE,905WMI_PDEV_PARAM_LTR_TX_ACTIVITY_TIMEOUT,906WMI_PDEV_PARAM_L1SS_ENABLE,907WMI_PDEV_PARAM_DSLEEP_ENABLE,908WMI_PDEV_PARAM_PCIELP_TXBUF_FLUSH,909WMI_PDEV_PARAM_PCIELP_TXBUF_WATERMARK,910WMI_PDEV_PARAM_PCIELP_TXBUF_TMO_EN,911WMI_PDEV_PARAM_PCIELP_TXBUF_TMO_VALUE,912WMI_PDEV_PARAM_PDEV_STATS_UPDATE_PERIOD,913WMI_PDEV_PARAM_VDEV_STATS_UPDATE_PERIOD,914WMI_PDEV_PARAM_PEER_STATS_UPDATE_PERIOD,915WMI_PDEV_PARAM_BCNFLT_STATS_UPDATE_PERIOD,916WMI_PDEV_PARAM_PMF_QOS,917WMI_PDEV_PARAM_ARP_AC_OVERRIDE,918WMI_PDEV_PARAM_DCS,919WMI_PDEV_PARAM_ANI_ENABLE,920WMI_PDEV_PARAM_ANI_POLL_PERIOD,921WMI_PDEV_PARAM_ANI_LISTEN_PERIOD,922WMI_PDEV_PARAM_ANI_OFDM_LEVEL,923WMI_PDEV_PARAM_ANI_CCK_LEVEL,924WMI_PDEV_PARAM_DYNTXCHAIN,925WMI_PDEV_PARAM_PROXY_STA,926WMI_PDEV_PARAM_IDLE_PS_CONFIG,927WMI_PDEV_PARAM_POWER_GATING_SLEEP,928WMI_PDEV_PARAM_RFKILL_ENABLE,929WMI_PDEV_PARAM_BURST_DUR,930WMI_PDEV_PARAM_BURST_ENABLE,931WMI_PDEV_PARAM_HW_RFKILL_CONFIG,932WMI_PDEV_PARAM_LOW_POWER_RF_ENABLE,933WMI_PDEV_PARAM_L1SS_TRACK,934WMI_PDEV_PARAM_HYST_EN,935WMI_PDEV_PARAM_POWER_COLLAPSE_ENABLE,936WMI_PDEV_PARAM_LED_SYS_STATE,937WMI_PDEV_PARAM_LED_ENABLE,938WMI_PDEV_PARAM_AUDIO_OVER_WLAN_LATENCY,939WMI_PDEV_PARAM_AUDIO_OVER_WLAN_ENABLE,940WMI_PDEV_PARAM_WHAL_MIB_STATS_UPDATE_ENABLE,941WMI_PDEV_PARAM_VDEV_RATE_STATS_UPDATE_PERIOD,942WMI_PDEV_PARAM_CTS_CBW,943WMI_PDEV_PARAM_WNTS_CONFIG,944WMI_PDEV_PARAM_ADAPTIVE_EARLY_RX_ENABLE,945WMI_PDEV_PARAM_ADAPTIVE_EARLY_RX_MIN_SLEEP_SLOP,946WMI_PDEV_PARAM_ADAPTIVE_EARLY_RX_INC_DEC_STEP,947WMI_PDEV_PARAM_EARLY_RX_FIX_SLEEP_SLOP,948WMI_PDEV_PARAM_BMISS_BASED_ADAPTIVE_BTO_ENABLE,949WMI_PDEV_PARAM_BMISS_BTO_MIN_BCN_TIMEOUT,950WMI_PDEV_PARAM_BMISS_BTO_INC_DEC_STEP,951WMI_PDEV_PARAM_BTO_FIX_BCN_TIMEOUT,952WMI_PDEV_PARAM_CE_BASED_ADAPTIVE_BTO_ENABLE,953WMI_PDEV_PARAM_CE_BTO_COMBO_CE_VALUE,954WMI_PDEV_PARAM_TX_CHAIN_MASK_2G,955WMI_PDEV_PARAM_RX_CHAIN_MASK_2G,956WMI_PDEV_PARAM_TX_CHAIN_MASK_5G,957WMI_PDEV_PARAM_RX_CHAIN_MASK_5G,958WMI_PDEV_PARAM_TX_CHAIN_MASK_CCK,959WMI_PDEV_PARAM_TX_CHAIN_MASK_1SS,960WMI_PDEV_PARAM_CTS2SELF_FOR_P2P_GO_CONFIG,961WMI_PDEV_PARAM_TXPOWER_DECR_DB,962WMI_PDEV_PARAM_AGGR_BURST,963WMI_PDEV_PARAM_RX_DECAP_MODE,964WMI_PDEV_PARAM_FAST_CHANNEL_RESET,965WMI_PDEV_PARAM_SMART_ANTENNA_DEFAULT_ANTENNA,966WMI_PDEV_PARAM_ANTENNA_GAIN,967WMI_PDEV_PARAM_RX_FILTER,968WMI_PDEV_SET_MCAST_TO_UCAST_TID,969WMI_PDEV_PARAM_PROXY_STA_MODE,970WMI_PDEV_PARAM_SET_MCAST2UCAST_MODE,971WMI_PDEV_PARAM_SET_MCAST2UCAST_BUFFER,972WMI_PDEV_PARAM_REMOVE_MCAST2UCAST_BUFFER,973WMI_PDEV_PEER_STA_PS_STATECHG_ENABLE,974WMI_PDEV_PARAM_IGMPMLD_AC_OVERRIDE,975WMI_PDEV_PARAM_BLOCK_INTERBSS,976WMI_PDEV_PARAM_SET_DISABLE_RESET_CMDID,977WMI_PDEV_PARAM_SET_MSDU_TTL_CMDID,978WMI_PDEV_PARAM_SET_PPDU_DURATION_CMDID,979WMI_PDEV_PARAM_TXBF_SOUND_PERIOD_CMDID,980WMI_PDEV_PARAM_SET_PROMISC_MODE_CMDID,981WMI_PDEV_PARAM_SET_BURST_MODE_CMDID,982WMI_PDEV_PARAM_EN_STATS,983WMI_PDEV_PARAM_MU_GROUP_POLICY,984WMI_PDEV_PARAM_NOISE_DETECTION,985WMI_PDEV_PARAM_NOISE_THRESHOLD,986WMI_PDEV_PARAM_DPD_ENABLE,987WMI_PDEV_PARAM_SET_MCAST_BCAST_ECHO,988WMI_PDEV_PARAM_ATF_STRICT_SCH,989WMI_PDEV_PARAM_ATF_SCHED_DURATION,990WMI_PDEV_PARAM_ANT_PLZN,991WMI_PDEV_PARAM_MGMT_RETRY_LIMIT,992WMI_PDEV_PARAM_SENSITIVITY_LEVEL,993WMI_PDEV_PARAM_SIGNED_TXPOWER_2G,994WMI_PDEV_PARAM_SIGNED_TXPOWER_5G,995WMI_PDEV_PARAM_ENABLE_PER_TID_AMSDU,996WMI_PDEV_PARAM_ENABLE_PER_TID_AMPDU,997WMI_PDEV_PARAM_CCA_THRESHOLD,998WMI_PDEV_PARAM_RTS_FIXED_RATE,999WMI_PDEV_PARAM_PDEV_RESET,1000WMI_PDEV_PARAM_WAPI_MBSSID_OFFSET,1001WMI_PDEV_PARAM_ARP_DBG_SRCADDR,1002WMI_PDEV_PARAM_ARP_DBG_DSTADDR,1003WMI_PDEV_PARAM_ATF_OBSS_NOISE_SCH,1004WMI_PDEV_PARAM_ATF_OBSS_NOISE_SCALING_FACTOR,1005WMI_PDEV_PARAM_CUST_TXPOWER_SCALE,1006WMI_PDEV_PARAM_ATF_DYNAMIC_ENABLE,1007WMI_PDEV_PARAM_CTRL_RETRY_LIMIT,1008WMI_PDEV_PARAM_PROPAGATION_DELAY,1009WMI_PDEV_PARAM_ENA_ANT_DIV,1010WMI_PDEV_PARAM_FORCE_CHAIN_ANT,1011WMI_PDEV_PARAM_ANT_DIV_SELFTEST,1012WMI_PDEV_PARAM_ANT_DIV_SELFTEST_INTVL,1013WMI_PDEV_PARAM_STATS_OBSERVATION_PERIOD,1014WMI_PDEV_PARAM_TX_PPDU_DELAY_BIN_SIZE_MS,1015WMI_PDEV_PARAM_TX_PPDU_DELAY_ARRAY_LEN,1016WMI_PDEV_PARAM_TX_MPDU_AGGR_ARRAY_LEN,1017WMI_PDEV_PARAM_RX_MPDU_AGGR_ARRAY_LEN,1018WMI_PDEV_PARAM_TX_SCH_DELAY,1019WMI_PDEV_PARAM_ENABLE_RTS_SIFS_BURSTING,1020WMI_PDEV_PARAM_MAX_MPDUS_IN_AMPDU,1021WMI_PDEV_PARAM_PEER_STATS_INFO_ENABLE,1022WMI_PDEV_PARAM_FAST_PWR_TRANSITION,1023WMI_PDEV_PARAM_RADIO_CHAN_STATS_ENABLE,1024WMI_PDEV_PARAM_RADIO_DIAGNOSIS_ENABLE,1025WMI_PDEV_PARAM_MESH_MCAST_ENABLE,1026};10271028enum wmi_tlv_vdev_param {1029WMI_VDEV_PARAM_RTS_THRESHOLD = 0x1,1030WMI_VDEV_PARAM_FRAGMENTATION_THRESHOLD,1031WMI_VDEV_PARAM_BEACON_INTERVAL,1032WMI_VDEV_PARAM_LISTEN_INTERVAL,1033WMI_VDEV_PARAM_MULTICAST_RATE,1034WMI_VDEV_PARAM_MGMT_TX_RATE,1035WMI_VDEV_PARAM_SLOT_TIME,1036WMI_VDEV_PARAM_PREAMBLE,1037WMI_VDEV_PARAM_SWBA_TIME,1038WMI_VDEV_STATS_UPDATE_PERIOD,1039WMI_VDEV_PWRSAVE_AGEOUT_TIME,1040WMI_VDEV_HOST_SWBA_INTERVAL,1041WMI_VDEV_PARAM_DTIM_PERIOD,1042WMI_VDEV_OC_SCHEDULER_AIR_TIME_LIMIT,1043WMI_VDEV_PARAM_WDS,1044WMI_VDEV_PARAM_ATIM_WINDOW,1045WMI_VDEV_PARAM_BMISS_COUNT_MAX,1046WMI_VDEV_PARAM_BMISS_FIRST_BCNT,1047WMI_VDEV_PARAM_BMISS_FINAL_BCNT,1048WMI_VDEV_PARAM_FEATURE_WMM,1049WMI_VDEV_PARAM_CHWIDTH,1050WMI_VDEV_PARAM_CHEXTOFFSET,1051WMI_VDEV_PARAM_DISABLE_HTPROTECTION,1052WMI_VDEV_PARAM_STA_QUICKKICKOUT,1053WMI_VDEV_PARAM_MGMT_RATE,1054WMI_VDEV_PARAM_PROTECTION_MODE,1055WMI_VDEV_PARAM_FIXED_RATE,1056WMI_VDEV_PARAM_SGI,1057WMI_VDEV_PARAM_LDPC,1058WMI_VDEV_PARAM_TX_STBC,1059WMI_VDEV_PARAM_RX_STBC,1060WMI_VDEV_PARAM_INTRA_BSS_FWD,1061WMI_VDEV_PARAM_DEF_KEYID,1062WMI_VDEV_PARAM_NSS,1063WMI_VDEV_PARAM_BCAST_DATA_RATE,1064WMI_VDEV_PARAM_MCAST_DATA_RATE,1065WMI_VDEV_PARAM_MCAST_INDICATE,1066WMI_VDEV_PARAM_DHCP_INDICATE,1067WMI_VDEV_PARAM_UNKNOWN_DEST_INDICATE,1068WMI_VDEV_PARAM_AP_KEEPALIVE_MIN_IDLE_INACTIVE_TIME_SECS,1069WMI_VDEV_PARAM_AP_KEEPALIVE_MAX_IDLE_INACTIVE_TIME_SECS,1070WMI_VDEV_PARAM_AP_KEEPALIVE_MAX_UNRESPONSIVE_TIME_SECS,1071WMI_VDEV_PARAM_AP_ENABLE_NAWDS,1072WMI_VDEV_PARAM_ENABLE_RTSCTS,1073WMI_VDEV_PARAM_TXBF,1074WMI_VDEV_PARAM_PACKET_POWERSAVE,1075WMI_VDEV_PARAM_DROP_UNENCRY,1076WMI_VDEV_PARAM_TX_ENCAP_TYPE,1077WMI_VDEV_PARAM_AP_DETECT_OUT_OF_SYNC_SLEEPING_STA_TIME_SECS,1078WMI_VDEV_PARAM_EARLY_RX_ADJUST_ENABLE,1079WMI_VDEV_PARAM_EARLY_RX_TGT_BMISS_NUM,1080WMI_VDEV_PARAM_EARLY_RX_BMISS_SAMPLE_CYCLE,1081WMI_VDEV_PARAM_EARLY_RX_SLOP_STEP,1082WMI_VDEV_PARAM_EARLY_RX_INIT_SLOP,1083WMI_VDEV_PARAM_EARLY_RX_ADJUST_PAUSE,1084WMI_VDEV_PARAM_TX_PWRLIMIT,1085WMI_VDEV_PARAM_SNR_NUM_FOR_CAL,1086WMI_VDEV_PARAM_ROAM_FW_OFFLOAD,1087WMI_VDEV_PARAM_ENABLE_RMC,1088WMI_VDEV_PARAM_IBSS_MAX_BCN_LOST_MS,1089WMI_VDEV_PARAM_MAX_RATE,1090WMI_VDEV_PARAM_EARLY_RX_DRIFT_SAMPLE,1091WMI_VDEV_PARAM_SET_IBSS_TX_FAIL_CNT_THR,1092WMI_VDEV_PARAM_EBT_RESYNC_TIMEOUT,1093WMI_VDEV_PARAM_AGGR_TRIG_EVENT_ENABLE,1094WMI_VDEV_PARAM_IS_IBSS_POWER_SAVE_ALLOWED,1095WMI_VDEV_PARAM_IS_POWER_COLLAPSE_ALLOWED,1096WMI_VDEV_PARAM_IS_AWAKE_ON_TXRX_ENABLED,1097WMI_VDEV_PARAM_INACTIVITY_CNT,1098WMI_VDEV_PARAM_TXSP_END_INACTIVITY_TIME_MS,1099WMI_VDEV_PARAM_DTIM_POLICY,1100WMI_VDEV_PARAM_IBSS_PS_WARMUP_TIME_SECS,1101WMI_VDEV_PARAM_IBSS_PS_1RX_CHAIN_IN_ATIM_WINDOW_ENABLE,1102WMI_VDEV_PARAM_RX_LEAK_WINDOW,1103WMI_VDEV_PARAM_STATS_AVG_FACTOR,1104WMI_VDEV_PARAM_DISCONNECT_TH,1105WMI_VDEV_PARAM_RTSCTS_RATE,1106WMI_VDEV_PARAM_MCC_RTSCTS_PROTECTION_ENABLE,1107WMI_VDEV_PARAM_MCC_BROADCAST_PROBE_ENABLE,1108WMI_VDEV_PARAM_TXPOWER_SCALE,1109WMI_VDEV_PARAM_TXPOWER_SCALE_DECR_DB,1110WMI_VDEV_PARAM_MCAST2UCAST_SET,1111WMI_VDEV_PARAM_RC_NUM_RETRIES,1112WMI_VDEV_PARAM_CABQ_MAXDUR,1113WMI_VDEV_PARAM_MFPTEST_SET,1114WMI_VDEV_PARAM_RTS_FIXED_RATE,1115WMI_VDEV_PARAM_VHT_SGIMASK,1116WMI_VDEV_PARAM_VHT80_RATEMASK,1117WMI_VDEV_PARAM_PROXY_STA,1118WMI_VDEV_PARAM_VIRTUAL_CELL_MODE,1119WMI_VDEV_PARAM_RX_DECAP_TYPE,1120WMI_VDEV_PARAM_BW_NSS_RATEMASK,1121WMI_VDEV_PARAM_SENSOR_AP,1122WMI_VDEV_PARAM_BEACON_RATE,1123WMI_VDEV_PARAM_DTIM_ENABLE_CTS,1124WMI_VDEV_PARAM_STA_KICKOUT,1125WMI_VDEV_PARAM_CAPABILITIES,1126WMI_VDEV_PARAM_TSF_INCREMENT,1127WMI_VDEV_PARAM_AMPDU_PER_AC,1128WMI_VDEV_PARAM_RX_FILTER,1129WMI_VDEV_PARAM_MGMT_TX_POWER,1130WMI_VDEV_PARAM_NON_AGG_SW_RETRY_TH,1131WMI_VDEV_PARAM_AGG_SW_RETRY_TH,1132WMI_VDEV_PARAM_DISABLE_DYN_BW_RTS,1133WMI_VDEV_PARAM_ATF_SSID_SCHED_POLICY,1134WMI_VDEV_PARAM_HE_DCM,1135WMI_VDEV_PARAM_HE_RANGE_EXT,1136WMI_VDEV_PARAM_ENABLE_BCAST_PROBE_RESPONSE,1137WMI_VDEV_PARAM_FILS_MAX_CHANNEL_GUARD_TIME,1138WMI_VDEV_PARAM_BA_MODE = 0x7e,1139WMI_VDEV_PARAM_SET_HE_SOUNDING_MODE = 0x87,1140WMI_VDEV_PARAM_6GHZ_PARAMS = 0x99,1141WMI_VDEV_PARAM_PROTOTYPE = 0x8000,1142WMI_VDEV_PARAM_BSS_COLOR,1143WMI_VDEV_PARAM_SET_HEMU_MODE,1144WMI_VDEV_PARAM_HEOPS_0_31 = 0x8003,1145};11461147enum wmi_tlv_peer_flags {1148WMI_TLV_PEER_AUTH = 0x00000001,1149WMI_TLV_PEER_QOS = 0x00000002,1150WMI_TLV_PEER_NEED_PTK_4_WAY = 0x00000004,1151WMI_TLV_PEER_NEED_GTK_2_WAY = 0x00000010,1152WMI_TLV_PEER_APSD = 0x00000800,1153WMI_TLV_PEER_HT = 0x00001000,1154WMI_TLV_PEER_40MHZ = 0x00002000,1155WMI_TLV_PEER_STBC = 0x00008000,1156WMI_TLV_PEER_LDPC = 0x00010000,1157WMI_TLV_PEER_DYN_MIMOPS = 0x00020000,1158WMI_TLV_PEER_STATIC_MIMOPS = 0x00040000,1159WMI_TLV_PEER_SPATIAL_MUX = 0x00200000,1160WMI_TLV_PEER_VHT = 0x02000000,1161WMI_TLV_PEER_80MHZ = 0x04000000,1162WMI_TLV_PEER_PMF = 0x08000000,1163WMI_PEER_IS_P2P_CAPABLE = 0x20000000,1164WMI_PEER_160MHZ = 0x40000000,1165WMI_PEER_SAFEMODE_EN = 0x80000000,11661167};11681169enum wmi_tlv_peer_flags_ext {1170WMI_PEER_EXT_EHT = BIT(0),1171WMI_PEER_EXT_320MHZ = BIT(1),1172};11731174/** Enum list of TLV Tags for each parameter structure type. */1175enum wmi_tlv_tag {1176WMI_TAG_LAST_RESERVED = 15,1177WMI_TAG_FIRST_ARRAY_ENUM,1178WMI_TAG_ARRAY_UINT32 = WMI_TAG_FIRST_ARRAY_ENUM,1179WMI_TAG_ARRAY_BYTE,1180WMI_TAG_ARRAY_STRUCT,1181WMI_TAG_ARRAY_FIXED_STRUCT,1182WMI_TAG_LAST_ARRAY_ENUM = 31,1183WMI_TAG_SERVICE_READY_EVENT,1184WMI_TAG_HAL_REG_CAPABILITIES,1185WMI_TAG_WLAN_HOST_MEM_REQ,1186WMI_TAG_READY_EVENT,1187WMI_TAG_SCAN_EVENT,1188WMI_TAG_PDEV_TPC_CONFIG_EVENT,1189WMI_TAG_CHAN_INFO_EVENT,1190WMI_TAG_COMB_PHYERR_RX_HDR,1191WMI_TAG_VDEV_START_RESPONSE_EVENT,1192WMI_TAG_VDEV_STOPPED_EVENT,1193WMI_TAG_VDEV_INSTALL_KEY_COMPLETE_EVENT,1194WMI_TAG_PEER_STA_KICKOUT_EVENT,1195WMI_TAG_MGMT_RX_HDR,1196WMI_TAG_TBTT_OFFSET_EVENT,1197WMI_TAG_TX_DELBA_COMPLETE_EVENT,1198WMI_TAG_TX_ADDBA_COMPLETE_EVENT,1199WMI_TAG_ROAM_EVENT,1200WMI_TAG_WOW_EVENT_INFO,1201WMI_TAG_WOW_EVENT_INFO_SECTION_BITMAP,1202WMI_TAG_RTT_EVENT_HEADER,1203WMI_TAG_RTT_ERROR_REPORT_EVENT,1204WMI_TAG_RTT_MEAS_EVENT,1205WMI_TAG_ECHO_EVENT,1206WMI_TAG_FTM_INTG_EVENT,1207WMI_TAG_VDEV_GET_KEEPALIVE_EVENT,1208WMI_TAG_GPIO_INPUT_EVENT,1209WMI_TAG_CSA_EVENT,1210WMI_TAG_GTK_OFFLOAD_STATUS_EVENT,1211WMI_TAG_IGTK_INFO,1212WMI_TAG_DCS_INTERFERENCE_EVENT,1213WMI_TAG_ATH_DCS_CW_INT,1214WMI_TAG_WLAN_DCS_CW_INT = /* ALIAS */1215WMI_TAG_ATH_DCS_CW_INT,1216WMI_TAG_ATH_DCS_WLAN_INT_STAT,1217WMI_TAG_WLAN_DCS_IM_TGT_STATS_T = /* ALIAS */1218WMI_TAG_ATH_DCS_WLAN_INT_STAT,1219WMI_TAG_WLAN_PROFILE_CTX_T,1220WMI_TAG_WLAN_PROFILE_T,1221WMI_TAG_PDEV_QVIT_EVENT,1222WMI_TAG_HOST_SWBA_EVENT,1223WMI_TAG_TIM_INFO,1224WMI_TAG_P2P_NOA_INFO,1225WMI_TAG_STATS_EVENT,1226WMI_TAG_AVOID_FREQ_RANGES_EVENT,1227WMI_TAG_AVOID_FREQ_RANGE_DESC,1228WMI_TAG_GTK_REKEY_FAIL_EVENT,1229WMI_TAG_INIT_CMD,1230WMI_TAG_RESOURCE_CONFIG,1231WMI_TAG_WLAN_HOST_MEMORY_CHUNK,1232WMI_TAG_START_SCAN_CMD,1233WMI_TAG_STOP_SCAN_CMD,1234WMI_TAG_SCAN_CHAN_LIST_CMD,1235WMI_TAG_CHANNEL,1236WMI_TAG_PDEV_SET_REGDOMAIN_CMD,1237WMI_TAG_PDEV_SET_PARAM_CMD,1238WMI_TAG_PDEV_SET_WMM_PARAMS_CMD,1239WMI_TAG_WMM_PARAMS,1240WMI_TAG_PDEV_SET_QUIET_CMD,1241WMI_TAG_VDEV_CREATE_CMD,1242WMI_TAG_VDEV_DELETE_CMD,1243WMI_TAG_VDEV_START_REQUEST_CMD,1244WMI_TAG_P2P_NOA_DESCRIPTOR,1245WMI_TAG_P2P_GO_SET_BEACON_IE,1246WMI_TAG_GTK_OFFLOAD_CMD,1247WMI_TAG_VDEV_UP_CMD,1248WMI_TAG_VDEV_STOP_CMD,1249WMI_TAG_VDEV_DOWN_CMD,1250WMI_TAG_VDEV_SET_PARAM_CMD,1251WMI_TAG_VDEV_INSTALL_KEY_CMD,1252WMI_TAG_PEER_CREATE_CMD,1253WMI_TAG_PEER_DELETE_CMD,1254WMI_TAG_PEER_FLUSH_TIDS_CMD,1255WMI_TAG_PEER_SET_PARAM_CMD,1256WMI_TAG_PEER_ASSOC_COMPLETE_CMD,1257WMI_TAG_VHT_RATE_SET,1258WMI_TAG_BCN_TMPL_CMD,1259WMI_TAG_PRB_TMPL_CMD,1260WMI_TAG_BCN_PRB_INFO,1261WMI_TAG_PEER_TID_ADDBA_CMD,1262WMI_TAG_PEER_TID_DELBA_CMD,1263WMI_TAG_STA_POWERSAVE_MODE_CMD,1264WMI_TAG_STA_POWERSAVE_PARAM_CMD,1265WMI_TAG_STA_DTIM_PS_METHOD_CMD,1266WMI_TAG_ROAM_SCAN_MODE,1267WMI_TAG_ROAM_SCAN_RSSI_THRESHOLD,1268WMI_TAG_ROAM_SCAN_PERIOD,1269WMI_TAG_ROAM_SCAN_RSSI_CHANGE_THRESHOLD,1270WMI_TAG_PDEV_SUSPEND_CMD,1271WMI_TAG_PDEV_RESUME_CMD,1272WMI_TAG_ADD_BCN_FILTER_CMD,1273WMI_TAG_RMV_BCN_FILTER_CMD,1274WMI_TAG_WOW_ENABLE_CMD,1275WMI_TAG_WOW_HOSTWAKEUP_FROM_SLEEP_CMD,1276WMI_TAG_STA_UAPSD_AUTO_TRIG_CMD,1277WMI_TAG_STA_UAPSD_AUTO_TRIG_PARAM,1278WMI_TAG_SET_ARP_NS_OFFLOAD_CMD,1279WMI_TAG_ARP_OFFLOAD_TUPLE,1280WMI_TAG_NS_OFFLOAD_TUPLE,1281WMI_TAG_FTM_INTG_CMD,1282WMI_TAG_STA_KEEPALIVE_CMD,1283WMI_TAG_STA_KEEPALVE_ARP_RESPONSE,1284WMI_TAG_P2P_SET_VENDOR_IE_DATA_CMD,1285WMI_TAG_AP_PS_PEER_CMD,1286WMI_TAG_PEER_RATE_RETRY_SCHED_CMD,1287WMI_TAG_WLAN_PROFILE_TRIGGER_CMD,1288WMI_TAG_WLAN_PROFILE_SET_HIST_INTVL_CMD,1289WMI_TAG_WLAN_PROFILE_GET_PROF_DATA_CMD,1290WMI_TAG_WLAN_PROFILE_ENABLE_PROFILE_ID_CMD,1291WMI_TAG_WOW_DEL_PATTERN_CMD,1292WMI_TAG_WOW_ADD_DEL_EVT_CMD,1293WMI_TAG_RTT_MEASREQ_HEAD,1294WMI_TAG_RTT_MEASREQ_BODY,1295WMI_TAG_RTT_TSF_CMD,1296WMI_TAG_VDEV_SPECTRAL_CONFIGURE_CMD,1297WMI_TAG_VDEV_SPECTRAL_ENABLE_CMD,1298WMI_TAG_REQUEST_STATS_CMD,1299WMI_TAG_NLO_CONFIG_CMD,1300WMI_TAG_NLO_CONFIGURED_PARAMETERS,1301WMI_TAG_CSA_OFFLOAD_ENABLE_CMD,1302WMI_TAG_CSA_OFFLOAD_CHANSWITCH_CMD,1303WMI_TAG_CHATTER_SET_MODE_CMD,1304WMI_TAG_ECHO_CMD,1305WMI_TAG_VDEV_SET_KEEPALIVE_CMD,1306WMI_TAG_VDEV_GET_KEEPALIVE_CMD,1307WMI_TAG_FORCE_FW_HANG_CMD,1308WMI_TAG_GPIO_CONFIG_CMD,1309WMI_TAG_GPIO_OUTPUT_CMD,1310WMI_TAG_PEER_ADD_WDS_ENTRY_CMD,1311WMI_TAG_PEER_REMOVE_WDS_ENTRY_CMD,1312WMI_TAG_BCN_TX_HDR,1313WMI_TAG_BCN_SEND_FROM_HOST_CMD,1314WMI_TAG_MGMT_TX_HDR,1315WMI_TAG_ADDBA_CLEAR_RESP_CMD,1316WMI_TAG_ADDBA_SEND_CMD,1317WMI_TAG_DELBA_SEND_CMD,1318WMI_TAG_ADDBA_SETRESPONSE_CMD,1319WMI_TAG_SEND_SINGLEAMSDU_CMD,1320WMI_TAG_PDEV_PKTLOG_ENABLE_CMD,1321WMI_TAG_PDEV_PKTLOG_DISABLE_CMD,1322WMI_TAG_PDEV_SET_HT_IE_CMD,1323WMI_TAG_PDEV_SET_VHT_IE_CMD,1324WMI_TAG_PDEV_SET_DSCP_TID_MAP_CMD,1325WMI_TAG_PDEV_GREEN_AP_PS_ENABLE_CMD,1326WMI_TAG_PDEV_GET_TPC_CONFIG_CMD,1327WMI_TAG_PDEV_SET_BASE_MACADDR_CMD,1328WMI_TAG_PEER_MCAST_GROUP_CMD,1329WMI_TAG_ROAM_AP_PROFILE,1330WMI_TAG_AP_PROFILE,1331WMI_TAG_SCAN_SCH_PRIORITY_TABLE_CMD,1332WMI_TAG_PDEV_DFS_ENABLE_CMD,1333WMI_TAG_PDEV_DFS_DISABLE_CMD,1334WMI_TAG_WOW_ADD_PATTERN_CMD,1335WMI_TAG_WOW_BITMAP_PATTERN_T,1336WMI_TAG_WOW_IPV4_SYNC_PATTERN_T,1337WMI_TAG_WOW_IPV6_SYNC_PATTERN_T,1338WMI_TAG_WOW_MAGIC_PATTERN_CMD,1339WMI_TAG_SCAN_UPDATE_REQUEST_CMD,1340WMI_TAG_CHATTER_PKT_COALESCING_FILTER,1341WMI_TAG_CHATTER_COALESCING_ADD_FILTER_CMD,1342WMI_TAG_CHATTER_COALESCING_DELETE_FILTER_CMD,1343WMI_TAG_CHATTER_COALESCING_QUERY_CMD,1344WMI_TAG_TXBF_CMD,1345WMI_TAG_DEBUG_LOG_CONFIG_CMD,1346WMI_TAG_NLO_EVENT,1347WMI_TAG_CHATTER_QUERY_REPLY_EVENT,1348WMI_TAG_UPLOAD_H_HDR,1349WMI_TAG_CAPTURE_H_EVENT_HDR,1350WMI_TAG_VDEV_WNM_SLEEPMODE_CMD,1351WMI_TAG_VDEV_IPSEC_NATKEEPALIVE_FILTER_CMD,1352WMI_TAG_VDEV_WMM_ADDTS_CMD,1353WMI_TAG_VDEV_WMM_DELTS_CMD,1354WMI_TAG_VDEV_SET_WMM_PARAMS_CMD,1355WMI_TAG_TDLS_SET_STATE_CMD,1356WMI_TAG_TDLS_PEER_UPDATE_CMD,1357WMI_TAG_TDLS_PEER_EVENT,1358WMI_TAG_TDLS_PEER_CAPABILITIES,1359WMI_TAG_VDEV_MCC_SET_TBTT_MODE_CMD,1360WMI_TAG_ROAM_CHAN_LIST,1361WMI_TAG_VDEV_MCC_BCN_INTVL_CHANGE_EVENT,1362WMI_TAG_RESMGR_ADAPTIVE_OCS_ENABLE_DISABLE_CMD,1363WMI_TAG_RESMGR_SET_CHAN_TIME_QUOTA_CMD,1364WMI_TAG_RESMGR_SET_CHAN_LATENCY_CMD,1365WMI_TAG_BA_REQ_SSN_CMD,1366WMI_TAG_BA_RSP_SSN_EVENT,1367WMI_TAG_STA_SMPS_FORCE_MODE_CMD,1368WMI_TAG_SET_MCASTBCAST_FILTER_CMD,1369WMI_TAG_P2P_SET_OPPPS_CMD,1370WMI_TAG_P2P_SET_NOA_CMD,1371WMI_TAG_BA_REQ_SSN_CMD_SUB_STRUCT_PARAM,1372WMI_TAG_BA_REQ_SSN_EVENT_SUB_STRUCT_PARAM,1373WMI_TAG_STA_SMPS_PARAM_CMD,1374WMI_TAG_VDEV_SET_GTX_PARAMS_CMD,1375WMI_TAG_MCC_SCHED_TRAFFIC_STATS_CMD,1376WMI_TAG_MCC_SCHED_STA_TRAFFIC_STATS,1377WMI_TAG_OFFLOAD_BCN_TX_STATUS_EVENT,1378WMI_TAG_P2P_NOA_EVENT,1379WMI_TAG_HB_SET_ENABLE_CMD,1380WMI_TAG_HB_SET_TCP_PARAMS_CMD,1381WMI_TAG_HB_SET_TCP_PKT_FILTER_CMD,1382WMI_TAG_HB_SET_UDP_PARAMS_CMD,1383WMI_TAG_HB_SET_UDP_PKT_FILTER_CMD,1384WMI_TAG_HB_IND_EVENT,1385WMI_TAG_TX_PAUSE_EVENT,1386WMI_TAG_RFKILL_EVENT,1387WMI_TAG_DFS_RADAR_EVENT,1388WMI_TAG_DFS_PHYERR_FILTER_ENA_CMD,1389WMI_TAG_DFS_PHYERR_FILTER_DIS_CMD,1390WMI_TAG_BATCH_SCAN_RESULT_SCAN_LIST,1391WMI_TAG_BATCH_SCAN_RESULT_NETWORK_INFO,1392WMI_TAG_BATCH_SCAN_ENABLE_CMD,1393WMI_TAG_BATCH_SCAN_DISABLE_CMD,1394WMI_TAG_BATCH_SCAN_TRIGGER_RESULT_CMD,1395WMI_TAG_BATCH_SCAN_ENABLED_EVENT,1396WMI_TAG_BATCH_SCAN_RESULT_EVENT,1397WMI_TAG_VDEV_PLMREQ_START_CMD,1398WMI_TAG_VDEV_PLMREQ_STOP_CMD,1399WMI_TAG_THERMAL_MGMT_CMD,1400WMI_TAG_THERMAL_MGMT_EVENT,1401WMI_TAG_PEER_INFO_REQ_CMD,1402WMI_TAG_PEER_INFO_EVENT,1403WMI_TAG_PEER_INFO,1404WMI_TAG_PEER_TX_FAIL_CNT_THR_EVENT,1405WMI_TAG_RMC_SET_MODE_CMD,1406WMI_TAG_RMC_SET_ACTION_PERIOD_CMD,1407WMI_TAG_RMC_CONFIG_CMD,1408WMI_TAG_MHF_OFFLOAD_SET_MODE_CMD,1409WMI_TAG_MHF_OFFLOAD_PLUMB_ROUTING_TABLE_CMD,1410WMI_TAG_ADD_PROACTIVE_ARP_RSP_PATTERN_CMD,1411WMI_TAG_DEL_PROACTIVE_ARP_RSP_PATTERN_CMD,1412WMI_TAG_NAN_CMD_PARAM,1413WMI_TAG_NAN_EVENT_HDR,1414WMI_TAG_PDEV_L1SS_TRACK_EVENT,1415WMI_TAG_DIAG_DATA_CONTAINER_EVENT,1416WMI_TAG_MODEM_POWER_STATE_CMD_PARAM,1417WMI_TAG_PEER_GET_ESTIMATED_LINKSPEED_CMD,1418WMI_TAG_PEER_ESTIMATED_LINKSPEED_EVENT,1419WMI_TAG_AGGR_STATE_TRIG_EVENT,1420WMI_TAG_MHF_OFFLOAD_ROUTING_TABLE_ENTRY,1421WMI_TAG_ROAM_SCAN_CMD,1422WMI_TAG_REQ_STATS_EXT_CMD,1423WMI_TAG_STATS_EXT_EVENT,1424WMI_TAG_OBSS_SCAN_ENABLE_CMD,1425WMI_TAG_OBSS_SCAN_DISABLE_CMD,1426WMI_TAG_OFFLOAD_PRB_RSP_TX_STATUS_EVENT,1427WMI_TAG_PDEV_SET_LED_CONFIG_CMD,1428WMI_TAG_HOST_AUTO_SHUTDOWN_CFG_CMD,1429WMI_TAG_HOST_AUTO_SHUTDOWN_EVENT,1430WMI_TAG_UPDATE_WHAL_MIB_STATS_EVENT,1431WMI_TAG_CHAN_AVOID_UPDATE_CMD_PARAM,1432WMI_TAG_WOW_IOAC_PKT_PATTERN_T,1433WMI_TAG_WOW_IOAC_TMR_PATTERN_T,1434WMI_TAG_WOW_IOAC_ADD_KEEPALIVE_CMD,1435WMI_TAG_WOW_IOAC_DEL_KEEPALIVE_CMD,1436WMI_TAG_WOW_IOAC_KEEPALIVE_T,1437WMI_TAG_WOW_IOAC_ADD_PATTERN_CMD,1438WMI_TAG_WOW_IOAC_DEL_PATTERN_CMD,1439WMI_TAG_START_LINK_STATS_CMD,1440WMI_TAG_CLEAR_LINK_STATS_CMD,1441WMI_TAG_REQUEST_LINK_STATS_CMD,1442WMI_TAG_IFACE_LINK_STATS_EVENT,1443WMI_TAG_RADIO_LINK_STATS_EVENT,1444WMI_TAG_PEER_STATS_EVENT,1445WMI_TAG_CHANNEL_STATS,1446WMI_TAG_RADIO_LINK_STATS,1447WMI_TAG_RATE_STATS,1448WMI_TAG_PEER_LINK_STATS,1449WMI_TAG_WMM_AC_STATS,1450WMI_TAG_IFACE_LINK_STATS,1451WMI_TAG_LPI_MGMT_SNOOPING_CONFIG_CMD,1452WMI_TAG_LPI_START_SCAN_CMD,1453WMI_TAG_LPI_STOP_SCAN_CMD,1454WMI_TAG_LPI_RESULT_EVENT,1455WMI_TAG_PEER_STATE_EVENT,1456WMI_TAG_EXTSCAN_BUCKET_CMD,1457WMI_TAG_EXTSCAN_BUCKET_CHANNEL_EVENT,1458WMI_TAG_EXTSCAN_START_CMD,1459WMI_TAG_EXTSCAN_STOP_CMD,1460WMI_TAG_EXTSCAN_CONFIGURE_WLAN_CHANGE_MONITOR_CMD,1461WMI_TAG_EXTSCAN_WLAN_CHANGE_BSSID_PARAM_CMD,1462WMI_TAG_EXTSCAN_CONFIGURE_HOTLIST_MONITOR_CMD,1463WMI_TAG_EXTSCAN_GET_CACHED_RESULTS_CMD,1464WMI_TAG_EXTSCAN_GET_WLAN_CHANGE_RESULTS_CMD,1465WMI_TAG_EXTSCAN_SET_CAPABILITIES_CMD,1466WMI_TAG_EXTSCAN_GET_CAPABILITIES_CMD,1467WMI_TAG_EXTSCAN_OPERATION_EVENT,1468WMI_TAG_EXTSCAN_START_STOP_EVENT,1469WMI_TAG_EXTSCAN_TABLE_USAGE_EVENT,1470WMI_TAG_EXTSCAN_WLAN_DESCRIPTOR_EVENT,1471WMI_TAG_EXTSCAN_RSSI_INFO_EVENT,1472WMI_TAG_EXTSCAN_CACHED_RESULTS_EVENT,1473WMI_TAG_EXTSCAN_WLAN_CHANGE_RESULTS_EVENT,1474WMI_TAG_EXTSCAN_WLAN_CHANGE_RESULT_BSSID_EVENT,1475WMI_TAG_EXTSCAN_HOTLIST_MATCH_EVENT,1476WMI_TAG_EXTSCAN_CAPABILITIES_EVENT,1477WMI_TAG_EXTSCAN_CACHE_CAPABILITIES_EVENT,1478WMI_TAG_EXTSCAN_WLAN_CHANGE_MONITOR_CAPABILITIES_EVENT,1479WMI_TAG_EXTSCAN_HOTLIST_MONITOR_CAPABILITIES_EVENT,1480WMI_TAG_D0_WOW_ENABLE_DISABLE_CMD,1481WMI_TAG_D0_WOW_DISABLE_ACK_EVENT,1482WMI_TAG_UNIT_TEST_CMD,1483WMI_TAG_ROAM_OFFLOAD_TLV_PARAM,1484WMI_TAG_ROAM_11I_OFFLOAD_TLV_PARAM,1485WMI_TAG_ROAM_11R_OFFLOAD_TLV_PARAM,1486WMI_TAG_ROAM_ESE_OFFLOAD_TLV_PARAM,1487WMI_TAG_ROAM_SYNCH_EVENT,1488WMI_TAG_ROAM_SYNCH_COMPLETE,1489WMI_TAG_EXTWOW_ENABLE_CMD,1490WMI_TAG_EXTWOW_SET_APP_TYPE1_PARAMS_CMD,1491WMI_TAG_EXTWOW_SET_APP_TYPE2_PARAMS_CMD,1492WMI_TAG_LPI_STATUS_EVENT,1493WMI_TAG_LPI_HANDOFF_EVENT,1494WMI_TAG_VDEV_RATE_STATS_EVENT,1495WMI_TAG_VDEV_RATE_HT_INFO,1496WMI_TAG_RIC_REQUEST,1497WMI_TAG_PDEV_GET_TEMPERATURE_CMD,1498WMI_TAG_PDEV_TEMPERATURE_EVENT,1499WMI_TAG_SET_DHCP_SERVER_OFFLOAD_CMD,1500WMI_TAG_TPC_CHAINMASK_CONFIG_CMD,1501WMI_TAG_RIC_TSPEC,1502WMI_TAG_TPC_CHAINMASK_CONFIG,1503WMI_TAG_IPA_OFFLOAD_ENABLE_DISABLE_CMD,1504WMI_TAG_SCAN_PROB_REQ_OUI_CMD,1505WMI_TAG_KEY_MATERIAL,1506WMI_TAG_TDLS_SET_OFFCHAN_MODE_CMD,1507WMI_TAG_SET_LED_FLASHING_CMD,1508WMI_TAG_MDNS_OFFLOAD_CMD,1509WMI_TAG_MDNS_SET_FQDN_CMD,1510WMI_TAG_MDNS_SET_RESP_CMD,1511WMI_TAG_MDNS_GET_STATS_CMD,1512WMI_TAG_MDNS_STATS_EVENT,1513WMI_TAG_ROAM_INVOKE_CMD,1514WMI_TAG_PDEV_RESUME_EVENT,1515WMI_TAG_PDEV_SET_ANTENNA_DIVERSITY_CMD,1516WMI_TAG_SAP_OFL_ENABLE_CMD,1517WMI_TAG_SAP_OFL_ADD_STA_EVENT,1518WMI_TAG_SAP_OFL_DEL_STA_EVENT,1519WMI_TAG_APFIND_CMD_PARAM,1520WMI_TAG_APFIND_EVENT_HDR,1521WMI_TAG_OCB_SET_SCHED_CMD,1522WMI_TAG_OCB_SET_SCHED_EVENT,1523WMI_TAG_OCB_SET_CONFIG_CMD,1524WMI_TAG_OCB_SET_CONFIG_RESP_EVENT,1525WMI_TAG_OCB_SET_UTC_TIME_CMD,1526WMI_TAG_OCB_START_TIMING_ADVERT_CMD,1527WMI_TAG_OCB_STOP_TIMING_ADVERT_CMD,1528WMI_TAG_OCB_GET_TSF_TIMER_CMD,1529WMI_TAG_OCB_GET_TSF_TIMER_RESP_EVENT,1530WMI_TAG_DCC_GET_STATS_CMD,1531WMI_TAG_DCC_CHANNEL_STATS_REQUEST,1532WMI_TAG_DCC_GET_STATS_RESP_EVENT,1533WMI_TAG_DCC_CLEAR_STATS_CMD,1534WMI_TAG_DCC_UPDATE_NDL_CMD,1535WMI_TAG_DCC_UPDATE_NDL_RESP_EVENT,1536WMI_TAG_DCC_STATS_EVENT,1537WMI_TAG_OCB_CHANNEL,1538WMI_TAG_OCB_SCHEDULE_ELEMENT,1539WMI_TAG_DCC_NDL_STATS_PER_CHANNEL,1540WMI_TAG_DCC_NDL_CHAN,1541WMI_TAG_QOS_PARAMETER,1542WMI_TAG_DCC_NDL_ACTIVE_STATE_CONFIG,1543WMI_TAG_ROAM_SCAN_EXTENDED_THRESHOLD_PARAM,1544WMI_TAG_ROAM_FILTER,1545WMI_TAG_PASSPOINT_CONFIG_CMD,1546WMI_TAG_PASSPOINT_EVENT_HDR,1547WMI_TAG_EXTSCAN_CONFIGURE_HOTLIST_SSID_MONITOR_CMD,1548WMI_TAG_EXTSCAN_HOTLIST_SSID_MATCH_EVENT,1549WMI_TAG_VDEV_TSF_TSTAMP_ACTION_CMD,1550WMI_TAG_VDEV_TSF_REPORT_EVENT,1551WMI_TAG_GET_FW_MEM_DUMP,1552WMI_TAG_UPDATE_FW_MEM_DUMP,1553WMI_TAG_FW_MEM_DUMP_PARAMS,1554WMI_TAG_DEBUG_MESG_FLUSH,1555WMI_TAG_DEBUG_MESG_FLUSH_COMPLETE,1556WMI_TAG_PEER_SET_RATE_REPORT_CONDITION,1557WMI_TAG_ROAM_SUBNET_CHANGE_CONFIG,1558WMI_TAG_VDEV_SET_IE_CMD,1559WMI_TAG_RSSI_BREACH_MONITOR_CONFIG,1560WMI_TAG_RSSI_BREACH_EVENT,1561WMI_TAG_WOW_EVENT_INITIAL_WAKEUP,1562WMI_TAG_SOC_SET_PCL_CMD,1563WMI_TAG_SOC_SET_HW_MODE_CMD,1564WMI_TAG_SOC_SET_HW_MODE_RESPONSE_EVENT,1565WMI_TAG_SOC_HW_MODE_TRANSITION_EVENT,1566WMI_TAG_VDEV_TXRX_STREAMS,1567WMI_TAG_SOC_SET_HW_MODE_RESPONSE_VDEV_MAC_ENTRY,1568WMI_TAG_SOC_SET_DUAL_MAC_CONFIG_CMD,1569WMI_TAG_SOC_SET_DUAL_MAC_CONFIG_RESPONSE_EVENT,1570WMI_TAG_WOW_IOAC_SOCK_PATTERN_T,1571WMI_TAG_WOW_ENABLE_ICMPV6_NA_FLT_CMD,1572WMI_TAG_DIAG_EVENT_LOG_CONFIG,1573WMI_TAG_DIAG_EVENT_LOG_SUPPORTED_EVENT_FIXED_PARAMS,1574WMI_TAG_PACKET_FILTER_CONFIG,1575WMI_TAG_PACKET_FILTER_ENABLE,1576WMI_TAG_SAP_SET_BLACKLIST_PARAM_CMD,1577WMI_TAG_MGMT_TX_SEND_CMD,1578WMI_TAG_MGMT_TX_COMPL_EVENT,1579WMI_TAG_SOC_SET_ANTENNA_MODE_CMD,1580WMI_TAG_WOW_UDP_SVC_OFLD_CMD,1581WMI_TAG_LRO_INFO_CMD,1582WMI_TAG_ROAM_EARLYSTOP_RSSI_THRES_PARAM,1583WMI_TAG_SERVICE_READY_EXT_EVENT,1584WMI_TAG_MAWC_SENSOR_REPORT_IND_CMD,1585WMI_TAG_MAWC_ENABLE_SENSOR_EVENT,1586WMI_TAG_ROAM_CONFIGURE_MAWC_CMD,1587WMI_TAG_NLO_CONFIGURE_MAWC_CMD,1588WMI_TAG_EXTSCAN_CONFIGURE_MAWC_CMD,1589WMI_TAG_PEER_ASSOC_CONF_EVENT,1590WMI_TAG_WOW_HOSTWAKEUP_GPIO_PIN_PATTERN_CONFIG_CMD,1591WMI_TAG_AP_PS_EGAP_PARAM_CMD,1592WMI_TAG_AP_PS_EGAP_INFO_EVENT,1593WMI_TAG_PMF_OFFLOAD_SET_SA_QUERY_CMD,1594WMI_TAG_TRANSFER_DATA_TO_FLASH_CMD,1595WMI_TAG_TRANSFER_DATA_TO_FLASH_COMPLETE_EVENT,1596WMI_TAG_SCPC_EVENT,1597WMI_TAG_AP_PS_EGAP_INFO_CHAINMASK_LIST,1598WMI_TAG_STA_SMPS_FORCE_MODE_COMPLETE_EVENT,1599WMI_TAG_BPF_GET_CAPABILITY_CMD,1600WMI_TAG_BPF_CAPABILITY_INFO_EVT,1601WMI_TAG_BPF_GET_VDEV_STATS_CMD,1602WMI_TAG_BPF_VDEV_STATS_INFO_EVT,1603WMI_TAG_BPF_SET_VDEV_INSTRUCTIONS_CMD,1604WMI_TAG_BPF_DEL_VDEV_INSTRUCTIONS_CMD,1605WMI_TAG_VDEV_DELETE_RESP_EVENT,1606WMI_TAG_PEER_DELETE_RESP_EVENT,1607WMI_TAG_ROAM_DENSE_THRES_PARAM,1608WMI_TAG_ENLO_CANDIDATE_SCORE_PARAM,1609WMI_TAG_PEER_UPDATE_WDS_ENTRY_CMD,1610WMI_TAG_VDEV_CONFIG_RATEMASK,1611WMI_TAG_PDEV_FIPS_CMD,1612WMI_TAG_PDEV_SMART_ANT_ENABLE_CMD,1613WMI_TAG_PDEV_SMART_ANT_SET_RX_ANTENNA_CMD,1614WMI_TAG_PEER_SMART_ANT_SET_TX_ANTENNA_CMD,1615WMI_TAG_PEER_SMART_ANT_SET_TRAIN_ANTENNA_CMD,1616WMI_TAG_PEER_SMART_ANT_SET_NODE_CONFIG_OPS_CMD,1617WMI_TAG_PDEV_SET_ANT_SWITCH_TBL_CMD,1618WMI_TAG_PDEV_SET_CTL_TABLE_CMD,1619WMI_TAG_PDEV_SET_MIMOGAIN_TABLE_CMD,1620WMI_TAG_FWTEST_SET_PARAM_CMD,1621WMI_TAG_PEER_ATF_REQUEST,1622WMI_TAG_VDEV_ATF_REQUEST,1623WMI_TAG_PDEV_GET_ANI_CCK_CONFIG_CMD,1624WMI_TAG_PDEV_GET_ANI_OFDM_CONFIG_CMD,1625WMI_TAG_INST_RSSI_STATS_RESP,1626WMI_TAG_MED_UTIL_REPORT_EVENT,1627WMI_TAG_PEER_STA_PS_STATECHANGE_EVENT,1628WMI_TAG_WDS_ADDR_EVENT,1629WMI_TAG_PEER_RATECODE_LIST_EVENT,1630WMI_TAG_PDEV_NFCAL_POWER_ALL_CHANNELS_EVENT,1631WMI_TAG_PDEV_TPC_EVENT,1632WMI_TAG_ANI_OFDM_EVENT,1633WMI_TAG_ANI_CCK_EVENT,1634WMI_TAG_PDEV_CHANNEL_HOPPING_EVENT,1635WMI_TAG_PDEV_FIPS_EVENT,1636WMI_TAG_ATF_PEER_INFO,1637WMI_TAG_PDEV_GET_TPC_CMD,1638WMI_TAG_VDEV_FILTER_NRP_CONFIG_CMD,1639WMI_TAG_QBOOST_CFG_CMD,1640WMI_TAG_PDEV_SMART_ANT_GPIO_HANDLE,1641WMI_TAG_PEER_SMART_ANT_SET_TX_ANTENNA_SERIES,1642WMI_TAG_PEER_SMART_ANT_SET_TRAIN_ANTENNA_PARAM,1643WMI_TAG_PDEV_SET_ANT_CTRL_CHAIN,1644WMI_TAG_PEER_CCK_OFDM_RATE_INFO,1645WMI_TAG_PEER_MCS_RATE_INFO,1646WMI_TAG_PDEV_NFCAL_POWER_ALL_CHANNELS_NFDBR,1647WMI_TAG_PDEV_NFCAL_POWER_ALL_CHANNELS_NFDBM,1648WMI_TAG_PDEV_NFCAL_POWER_ALL_CHANNELS_FREQNUM,1649WMI_TAG_MU_REPORT_TOTAL_MU,1650WMI_TAG_VDEV_SET_DSCP_TID_MAP_CMD,1651WMI_TAG_ROAM_SET_MBO,1652WMI_TAG_MIB_STATS_ENABLE_CMD,1653WMI_TAG_NAN_DISC_IFACE_CREATED_EVENT,1654WMI_TAG_NAN_DISC_IFACE_DELETED_EVENT,1655WMI_TAG_NAN_STARTED_CLUSTER_EVENT,1656WMI_TAG_NAN_JOINED_CLUSTER_EVENT,1657WMI_TAG_NDI_GET_CAP_REQ,1658WMI_TAG_NDP_INITIATOR_REQ,1659WMI_TAG_NDP_RESPONDER_REQ,1660WMI_TAG_NDP_END_REQ,1661WMI_TAG_NDI_CAP_RSP_EVENT,1662WMI_TAG_NDP_INITIATOR_RSP_EVENT,1663WMI_TAG_NDP_RESPONDER_RSP_EVENT,1664WMI_TAG_NDP_END_RSP_EVENT,1665WMI_TAG_NDP_INDICATION_EVENT,1666WMI_TAG_NDP_CONFIRM_EVENT,1667WMI_TAG_NDP_END_INDICATION_EVENT,1668WMI_TAG_VDEV_SET_QUIET_CMD,1669WMI_TAG_PDEV_SET_PCL_CMD,1670WMI_TAG_PDEV_SET_HW_MODE_CMD,1671WMI_TAG_PDEV_SET_MAC_CONFIG_CMD,1672WMI_TAG_PDEV_SET_ANTENNA_MODE_CMD,1673WMI_TAG_PDEV_SET_HW_MODE_RESPONSE_EVENT,1674WMI_TAG_PDEV_HW_MODE_TRANSITION_EVENT,1675WMI_TAG_PDEV_SET_HW_MODE_RESPONSE_VDEV_MAC_ENTRY,1676WMI_TAG_PDEV_SET_MAC_CONFIG_RESPONSE_EVENT,1677WMI_TAG_COEX_CONFIG_CMD,1678WMI_TAG_CONFIG_ENHANCED_MCAST_FILTER,1679WMI_TAG_CHAN_AVOID_RPT_ALLOW_CMD,1680WMI_TAG_SET_PERIODIC_CHANNEL_STATS_CONFIG,1681WMI_TAG_VDEV_SET_CUSTOM_AGGR_SIZE_CMD,1682WMI_TAG_PDEV_WAL_POWER_DEBUG_CMD,1683WMI_TAG_MAC_PHY_CAPABILITIES,1684WMI_TAG_HW_MODE_CAPABILITIES,1685WMI_TAG_SOC_MAC_PHY_HW_MODE_CAPS,1686WMI_TAG_HAL_REG_CAPABILITIES_EXT,1687WMI_TAG_SOC_HAL_REG_CAPABILITIES,1688WMI_TAG_VDEV_WISA_CMD,1689WMI_TAG_TX_POWER_LEVEL_STATS_EVT,1690WMI_TAG_SCAN_ADAPTIVE_DWELL_PARAMETERS_TLV,1691WMI_TAG_SCAN_ADAPTIVE_DWELL_CONFIG,1692WMI_TAG_WOW_SET_ACTION_WAKE_UP_CMD,1693WMI_TAG_NDP_END_RSP_PER_NDI,1694WMI_TAG_PEER_BWF_REQUEST,1695WMI_TAG_BWF_PEER_INFO,1696WMI_TAG_DBGLOG_TIME_STAMP_SYNC_CMD,1697WMI_TAG_RMC_SET_LEADER_CMD,1698WMI_TAG_RMC_MANUAL_LEADER_EVENT,1699WMI_TAG_PER_CHAIN_RSSI_STATS,1700WMI_TAG_RSSI_STATS,1701WMI_TAG_P2P_LO_START_CMD,1702WMI_TAG_P2P_LO_STOP_CMD,1703WMI_TAG_P2P_LO_STOPPED_EVENT,1704WMI_TAG_REORDER_QUEUE_SETUP_CMD,1705WMI_TAG_REORDER_QUEUE_REMOVE_CMD,1706WMI_TAG_SET_MULTIPLE_MCAST_FILTER_CMD,1707WMI_TAG_MGMT_TX_COMPL_BUNDLE_EVENT,1708WMI_TAG_READ_DATA_FROM_FLASH_CMD,1709WMI_TAG_READ_DATA_FROM_FLASH_EVENT,1710WMI_TAG_PDEV_SET_REORDER_TIMEOUT_VAL_CMD,1711WMI_TAG_PEER_SET_RX_BLOCKSIZE_CMD,1712WMI_TAG_PDEV_SET_WAKEUP_CONFIG_CMDID,1713WMI_TAG_TLV_BUF_LEN_PARAM,1714WMI_TAG_SERVICE_AVAILABLE_EVENT,1715WMI_TAG_PEER_ANTDIV_INFO_REQ_CMD,1716WMI_TAG_PEER_ANTDIV_INFO_EVENT,1717WMI_TAG_PEER_ANTDIV_INFO,1718WMI_TAG_PDEV_GET_ANTDIV_STATUS_CMD,1719WMI_TAG_PDEV_ANTDIV_STATUS_EVENT,1720WMI_TAG_MNT_FILTER_CMD,1721WMI_TAG_GET_CHIP_POWER_STATS_CMD,1722WMI_TAG_PDEV_CHIP_POWER_STATS_EVENT,1723WMI_TAG_COEX_GET_ANTENNA_ISOLATION_CMD,1724WMI_TAG_COEX_REPORT_ISOLATION_EVENT,1725WMI_TAG_CHAN_CCA_STATS,1726WMI_TAG_PEER_SIGNAL_STATS,1727WMI_TAG_TX_STATS,1728WMI_TAG_PEER_AC_TX_STATS,1729WMI_TAG_RX_STATS,1730WMI_TAG_PEER_AC_RX_STATS,1731WMI_TAG_REPORT_STATS_EVENT,1732WMI_TAG_CHAN_CCA_STATS_THRESH,1733WMI_TAG_PEER_SIGNAL_STATS_THRESH,1734WMI_TAG_TX_STATS_THRESH,1735WMI_TAG_RX_STATS_THRESH,1736WMI_TAG_PDEV_SET_STATS_THRESHOLD_CMD,1737WMI_TAG_REQUEST_WLAN_STATS_CMD,1738WMI_TAG_RX_AGGR_FAILURE_EVENT,1739WMI_TAG_RX_AGGR_FAILURE_INFO,1740WMI_TAG_VDEV_ENCRYPT_DECRYPT_DATA_REQ_CMD,1741WMI_TAG_VDEV_ENCRYPT_DECRYPT_DATA_RESP_EVENT,1742WMI_TAG_PDEV_BAND_TO_MAC,1743WMI_TAG_TBTT_OFFSET_INFO,1744WMI_TAG_TBTT_OFFSET_EXT_EVENT,1745WMI_TAG_SAR_LIMITS_CMD,1746WMI_TAG_SAR_LIMIT_CMD_ROW,1747WMI_TAG_PDEV_DFS_PHYERR_OFFLOAD_ENABLE_CMD,1748WMI_TAG_PDEV_DFS_PHYERR_OFFLOAD_DISABLE_CMD,1749WMI_TAG_VDEV_ADFS_CH_CFG_CMD,1750WMI_TAG_VDEV_ADFS_OCAC_ABORT_CMD,1751WMI_TAG_PDEV_DFS_RADAR_DETECTION_EVENT,1752WMI_TAG_VDEV_ADFS_OCAC_COMPLETE_EVENT,1753WMI_TAG_VDEV_DFS_CAC_COMPLETE_EVENT,1754WMI_TAG_VENDOR_OUI,1755WMI_TAG_REQUEST_RCPI_CMD,1756WMI_TAG_UPDATE_RCPI_EVENT,1757WMI_TAG_REQUEST_PEER_STATS_INFO_CMD,1758WMI_TAG_PEER_STATS_INFO,1759WMI_TAG_PEER_STATS_INFO_EVENT,1760WMI_TAG_PKGID_EVENT,1761WMI_TAG_CONNECTED_NLO_RSSI_PARAMS,1762WMI_TAG_SET_CURRENT_COUNTRY_CMD,1763WMI_TAG_REGULATORY_RULE_STRUCT,1764WMI_TAG_REG_CHAN_LIST_CC_EVENT,1765WMI_TAG_11D_SCAN_START_CMD,1766WMI_TAG_11D_SCAN_STOP_CMD,1767WMI_TAG_11D_NEW_COUNTRY_EVENT,1768WMI_TAG_REQUEST_RADIO_CHAN_STATS_CMD,1769WMI_TAG_RADIO_CHAN_STATS,1770WMI_TAG_RADIO_CHAN_STATS_EVENT,1771WMI_TAG_ROAM_PER_CONFIG,1772WMI_TAG_VDEV_ADD_MAC_ADDR_TO_RX_FILTER_CMD,1773WMI_TAG_VDEV_ADD_MAC_ADDR_TO_RX_FILTER_STATUS_EVENT,1774WMI_TAG_BPF_SET_VDEV_ACTIVE_MODE_CMD,1775WMI_TAG_HW_DATA_FILTER_CMD,1776WMI_TAG_CONNECTED_NLO_BSS_BAND_RSSI_PREF,1777WMI_TAG_PEER_OPER_MODE_CHANGE_EVENT,1778WMI_TAG_CHIP_POWER_SAVE_FAILURE_DETECTED,1779WMI_TAG_PDEV_MULTIPLE_VDEV_RESTART_REQUEST_CMD,1780WMI_TAG_PDEV_CSA_SWITCH_COUNT_STATUS_EVENT,1781WMI_TAG_PDEV_UPDATE_PKT_ROUTING_CMD,1782WMI_TAG_PDEV_CHECK_CAL_VERSION_CMD,1783WMI_TAG_PDEV_CHECK_CAL_VERSION_EVENT,1784WMI_TAG_PDEV_SET_DIVERSITY_GAIN_CMD,1785WMI_TAG_MAC_PHY_CHAINMASK_COMBO,1786WMI_TAG_MAC_PHY_CHAINMASK_CAPABILITY,1787WMI_TAG_VDEV_SET_ARP_STATS_CMD,1788WMI_TAG_VDEV_GET_ARP_STATS_CMD,1789WMI_TAG_VDEV_GET_ARP_STATS_EVENT,1790WMI_TAG_IFACE_OFFLOAD_STATS,1791WMI_TAG_REQUEST_STATS_CMD_SUB_STRUCT_PARAM,1792WMI_TAG_RSSI_CTL_EXT,1793WMI_TAG_SINGLE_PHYERR_EXT_RX_HDR,1794WMI_TAG_COEX_BT_ACTIVITY_EVENT,1795WMI_TAG_VDEV_GET_TX_POWER_CMD,1796WMI_TAG_VDEV_TX_POWER_EVENT,1797WMI_TAG_OFFCHAN_DATA_TX_COMPL_EVENT,1798WMI_TAG_OFFCHAN_DATA_TX_SEND_CMD,1799WMI_TAG_TX_SEND_PARAMS,1800WMI_TAG_HE_RATE_SET,1801WMI_TAG_CONGESTION_STATS,1802WMI_TAG_SET_INIT_COUNTRY_CMD,1803WMI_TAG_SCAN_DBS_DUTY_CYCLE,1804WMI_TAG_SCAN_DBS_DUTY_CYCLE_PARAM_TLV,1805WMI_TAG_PDEV_DIV_GET_RSSI_ANTID,1806WMI_TAG_THERM_THROT_CONFIG_REQUEST,1807WMI_TAG_THERM_THROT_LEVEL_CONFIG_INFO,1808WMI_TAG_THERM_THROT_STATS_EVENT,1809WMI_TAG_THERM_THROT_LEVEL_STATS_INFO,1810WMI_TAG_PDEV_DIV_RSSI_ANTID_EVENT,1811WMI_TAG_OEM_DMA_RING_CAPABILITIES,1812WMI_TAG_OEM_DMA_RING_CFG_REQ,1813WMI_TAG_OEM_DMA_RING_CFG_RSP,1814WMI_TAG_OEM_INDIRECT_DATA,1815WMI_TAG_OEM_DMA_BUF_RELEASE,1816WMI_TAG_OEM_DMA_BUF_RELEASE_ENTRY,1817WMI_TAG_PDEV_BSS_CHAN_INFO_REQUEST,1818WMI_TAG_PDEV_BSS_CHAN_INFO_EVENT,1819WMI_TAG_ROAM_LCA_DISALLOW_CONFIG,1820WMI_TAG_VDEV_LIMIT_OFFCHAN_CMD,1821WMI_TAG_ROAM_RSSI_REJECTION_OCE_CONFIG,1822WMI_TAG_UNIT_TEST_EVENT,1823WMI_TAG_ROAM_FILS_OFFLOAD,1824WMI_TAG_PDEV_UPDATE_PMK_CACHE_CMD,1825WMI_TAG_PMK_CACHE,1826WMI_TAG_PDEV_UPDATE_FILS_HLP_PKT_CMD,1827WMI_TAG_ROAM_FILS_SYNCH,1828WMI_TAG_GTK_OFFLOAD_EXTENDED,1829WMI_TAG_ROAM_BG_SCAN_ROAMING,1830WMI_TAG_OIC_PING_OFFLOAD_PARAMS_CMD,1831WMI_TAG_OIC_PING_OFFLOAD_SET_ENABLE_CMD,1832WMI_TAG_OIC_PING_HANDOFF_EVENT,1833WMI_TAG_DHCP_LEASE_RENEW_OFFLOAD_CMD,1834WMI_TAG_DHCP_LEASE_RENEW_EVENT,1835WMI_TAG_BTM_CONFIG,1836WMI_TAG_DEBUG_MESG_FW_DATA_STALL,1837WMI_TAG_WLM_CONFIG_CMD,1838WMI_TAG_PDEV_UPDATE_CTLTABLE_REQUEST,1839WMI_TAG_PDEV_UPDATE_CTLTABLE_EVENT,1840WMI_TAG_ROAM_CND_SCORING_PARAM,1841WMI_TAG_PDEV_CONFIG_VENDOR_OUI_ACTION,1842WMI_TAG_VENDOR_OUI_EXT,1843WMI_TAG_ROAM_SYNCH_FRAME_EVENT,1844WMI_TAG_FD_SEND_FROM_HOST_CMD,1845WMI_TAG_ENABLE_FILS_CMD,1846WMI_TAG_HOST_SWFDA_EVENT,1847WMI_TAG_BCN_OFFLOAD_CTRL_CMD,1848WMI_TAG_PDEV_SET_AC_TX_QUEUE_OPTIMIZED_CMD,1849WMI_TAG_STATS_PERIOD,1850WMI_TAG_NDL_SCHEDULE_UPDATE,1851WMI_TAG_PEER_TID_MSDUQ_QDEPTH_THRESH_UPDATE_CMD,1852WMI_TAG_MSDUQ_QDEPTH_THRESH_UPDATE,1853WMI_TAG_PDEV_SET_RX_FILTER_PROMISCUOUS_CMD,1854WMI_TAG_SAR2_RESULT_EVENT,1855WMI_TAG_SAR_CAPABILITIES,1856WMI_TAG_SAP_OBSS_DETECTION_CFG_CMD,1857WMI_TAG_SAP_OBSS_DETECTION_INFO_EVT,1858WMI_TAG_DMA_RING_CAPABILITIES,1859WMI_TAG_DMA_RING_CFG_REQ,1860WMI_TAG_DMA_RING_CFG_RSP,1861WMI_TAG_DMA_BUF_RELEASE,1862WMI_TAG_DMA_BUF_RELEASE_ENTRY,1863WMI_TAG_SAR_GET_LIMITS_CMD,1864WMI_TAG_SAR_GET_LIMITS_EVENT,1865WMI_TAG_SAR_GET_LIMITS_EVENT_ROW,1866WMI_TAG_OFFLOAD_11K_REPORT,1867WMI_TAG_INVOKE_NEIGHBOR_REPORT,1868WMI_TAG_NEIGHBOR_REPORT_OFFLOAD,1869WMI_TAG_VDEV_SET_CONNECTIVITY_CHECK_STATS,1870WMI_TAG_VDEV_GET_CONNECTIVITY_CHECK_STATS,1871WMI_TAG_BPF_SET_VDEV_ENABLE_CMD,1872WMI_TAG_BPF_SET_VDEV_WORK_MEMORY_CMD,1873WMI_TAG_BPF_GET_VDEV_WORK_MEMORY_CMD,1874WMI_TAG_BPF_GET_VDEV_WORK_MEMORY_RESP_EVT,1875WMI_TAG_PDEV_GET_NFCAL_POWER,1876WMI_TAG_BSS_COLOR_CHANGE_ENABLE,1877WMI_TAG_OBSS_COLOR_COLLISION_DET_CONFIG,1878WMI_TAG_OBSS_COLOR_COLLISION_EVT,1879WMI_TAG_RUNTIME_DPD_RECAL_CMD,1880WMI_TAG_TWT_ENABLE_CMD,1881WMI_TAG_TWT_DISABLE_CMD,1882WMI_TAG_TWT_ADD_DIALOG_CMD,1883WMI_TAG_TWT_DEL_DIALOG_CMD,1884WMI_TAG_TWT_PAUSE_DIALOG_CMD,1885WMI_TAG_TWT_RESUME_DIALOG_CMD,1886WMI_TAG_TWT_ENABLE_COMPLETE_EVENT,1887WMI_TAG_TWT_DISABLE_COMPLETE_EVENT,1888WMI_TAG_TWT_ADD_DIALOG_COMPLETE_EVENT,1889WMI_TAG_TWT_DEL_DIALOG_COMPLETE_EVENT,1890WMI_TAG_TWT_PAUSE_DIALOG_COMPLETE_EVENT,1891WMI_TAG_TWT_RESUME_DIALOG_COMPLETE_EVENT,1892WMI_TAG_REQUEST_ROAM_SCAN_STATS_CMD,1893WMI_TAG_ROAM_SCAN_STATS_EVENT,1894WMI_TAG_PEER_TID_CONFIGURATIONS_CMD,1895WMI_TAG_VDEV_SET_CUSTOM_SW_RETRY_TH_CMD,1896WMI_TAG_GET_TPC_POWER_CMD,1897WMI_TAG_GET_TPC_POWER_EVENT,1898WMI_TAG_DMA_BUF_RELEASE_SPECTRAL_META_DATA,1899WMI_TAG_MOTION_DET_CONFIG_PARAMS_CMD,1900WMI_TAG_MOTION_DET_BASE_LINE_CONFIG_PARAMS_CMD,1901WMI_TAG_MOTION_DET_START_STOP_CMD,1902WMI_TAG_MOTION_DET_BASE_LINE_START_STOP_CMD,1903WMI_TAG_MOTION_DET_EVENT,1904WMI_TAG_MOTION_DET_BASE_LINE_EVENT,1905WMI_TAG_NDP_TRANSPORT_IP,1906WMI_TAG_OBSS_SPATIAL_REUSE_SET_CMD,1907WMI_TAG_ESP_ESTIMATE_EVENT,1908WMI_TAG_NAN_HOST_CONFIG,1909WMI_TAG_SPECTRAL_BIN_SCALING_PARAMS,1910WMI_TAG_PEER_CFR_CAPTURE_CMD,1911WMI_TAG_PEER_CHAN_WIDTH_SWITCH_CMD,1912WMI_TAG_CHAN_WIDTH_PEER_LIST,1913WMI_TAG_OBSS_SPATIAL_REUSE_SET_DEF_OBSS_THRESH_CMD,1914WMI_TAG_PDEV_HE_TB_ACTION_FRM_CMD,1915WMI_TAG_PEER_EXTD2_STATS,1916WMI_TAG_HPCS_PULSE_START_CMD,1917WMI_TAG_PDEV_CTL_FAILSAFE_CHECK_EVENT,1918WMI_TAG_VDEV_CHAINMASK_CONFIG_CMD,1919WMI_TAG_VDEV_BCN_OFFLOAD_QUIET_CONFIG_CMD,1920WMI_TAG_NAN_EVENT_INFO,1921WMI_TAG_NDP_CHANNEL_INFO,1922WMI_TAG_NDP_CMD,1923WMI_TAG_NDP_EVENT,1924/* TODO add all the missing cmds */1925WMI_TAG_PDEV_PEER_PKTLOG_FILTER_CMD = 0x301,1926WMI_TAG_PDEV_PEER_PKTLOG_FILTER_INFO,1927WMI_TAG_SERVICE_READY_EXT2_EVENT = 0x334,1928WMI_TAG_FILS_DISCOVERY_TMPL_CMD = 0x344,1929WMI_TAG_MAC_PHY_CAPABILITIES_EXT = 0x36F,1930WMI_TAG_REGULATORY_RULE_EXT_STRUCT = 0x3A9,1931WMI_TAG_REG_CHAN_LIST_CC_EXT_EVENT,1932WMI_TAG_EHT_RATE_SET = 0x3C4,1933WMI_TAG_MAX1934};19351936enum wmi_tlv_service {1937WMI_TLV_SERVICE_BEACON_OFFLOAD = 0,1938WMI_TLV_SERVICE_SCAN_OFFLOAD = 1,1939WMI_TLV_SERVICE_ROAM_SCAN_OFFLOAD = 2,1940WMI_TLV_SERVICE_BCN_MISS_OFFLOAD = 3,1941WMI_TLV_SERVICE_STA_PWRSAVE = 4,1942WMI_TLV_SERVICE_STA_ADVANCED_PWRSAVE = 5,1943WMI_TLV_SERVICE_AP_UAPSD = 6,1944WMI_TLV_SERVICE_AP_DFS = 7,1945WMI_TLV_SERVICE_11AC = 8,1946WMI_TLV_SERVICE_BLOCKACK = 9,1947WMI_TLV_SERVICE_PHYERR = 10,1948WMI_TLV_SERVICE_BCN_FILTER = 11,1949WMI_TLV_SERVICE_RTT = 12,1950WMI_TLV_SERVICE_WOW = 13,1951WMI_TLV_SERVICE_RATECTRL_CACHE = 14,1952WMI_TLV_SERVICE_IRAM_TIDS = 15,1953WMI_TLV_SERVICE_ARPNS_OFFLOAD = 16,1954WMI_TLV_SERVICE_NLO = 17,1955WMI_TLV_SERVICE_GTK_OFFLOAD = 18,1956WMI_TLV_SERVICE_SCAN_SCH = 19,1957WMI_TLV_SERVICE_CSA_OFFLOAD = 20,1958WMI_TLV_SERVICE_CHATTER = 21,1959WMI_TLV_SERVICE_COEX_FREQAVOID = 22,1960WMI_TLV_SERVICE_PACKET_POWER_SAVE = 23,1961WMI_TLV_SERVICE_FORCE_FW_HANG = 24,1962WMI_TLV_SERVICE_GPIO = 25,1963WMI_TLV_SERVICE_STA_DTIM_PS_MODULATED_DTIM = 26,1964WMI_STA_UAPSD_BASIC_AUTO_TRIG = 27,1965WMI_STA_UAPSD_VAR_AUTO_TRIG = 28,1966WMI_TLV_SERVICE_STA_KEEP_ALIVE = 29,1967WMI_TLV_SERVICE_TX_ENCAP = 30,1968WMI_TLV_SERVICE_AP_PS_DETECT_OUT_OF_SYNC = 31,1969WMI_TLV_SERVICE_EARLY_RX = 32,1970WMI_TLV_SERVICE_STA_SMPS = 33,1971WMI_TLV_SERVICE_FWTEST = 34,1972WMI_TLV_SERVICE_STA_WMMAC = 35,1973WMI_TLV_SERVICE_TDLS = 36,1974WMI_TLV_SERVICE_BURST = 37,1975WMI_TLV_SERVICE_MCC_BCN_INTERVAL_CHANGE = 38,1976WMI_TLV_SERVICE_ADAPTIVE_OCS = 39,1977WMI_TLV_SERVICE_BA_SSN_SUPPORT = 40,1978WMI_TLV_SERVICE_FILTER_IPSEC_NATKEEPALIVE = 41,1979WMI_TLV_SERVICE_WLAN_HB = 42,1980WMI_TLV_SERVICE_LTE_ANT_SHARE_SUPPORT = 43,1981WMI_TLV_SERVICE_BATCH_SCAN = 44,1982WMI_TLV_SERVICE_QPOWER = 45,1983WMI_TLV_SERVICE_PLMREQ = 46,1984WMI_TLV_SERVICE_THERMAL_MGMT = 47,1985WMI_TLV_SERVICE_RMC = 48,1986WMI_TLV_SERVICE_MHF_OFFLOAD = 49,1987WMI_TLV_SERVICE_COEX_SAR = 50,1988WMI_TLV_SERVICE_BCN_TXRATE_OVERRIDE = 51,1989WMI_TLV_SERVICE_NAN = 52,1990WMI_TLV_SERVICE_L1SS_STAT = 53,1991WMI_TLV_SERVICE_ESTIMATE_LINKSPEED = 54,1992WMI_TLV_SERVICE_OBSS_SCAN = 55,1993WMI_TLV_SERVICE_TDLS_OFFCHAN = 56,1994WMI_TLV_SERVICE_TDLS_UAPSD_BUFFER_STA = 57,1995WMI_TLV_SERVICE_TDLS_UAPSD_SLEEP_STA = 58,1996WMI_TLV_SERVICE_IBSS_PWRSAVE = 59,1997WMI_TLV_SERVICE_LPASS = 60,1998WMI_TLV_SERVICE_EXTSCAN = 61,1999WMI_TLV_SERVICE_D0WOW = 62,2000WMI_TLV_SERVICE_HSOFFLOAD = 63,2001WMI_TLV_SERVICE_ROAM_HO_OFFLOAD = 64,2002WMI_TLV_SERVICE_RX_FULL_REORDER = 65,2003WMI_TLV_SERVICE_DHCP_OFFLOAD = 66,2004WMI_TLV_SERVICE_STA_RX_IPA_OFFLOAD_SUPPORT = 67,2005WMI_TLV_SERVICE_MDNS_OFFLOAD = 68,2006WMI_TLV_SERVICE_SAP_AUTH_OFFLOAD = 69,2007WMI_TLV_SERVICE_DUAL_BAND_SIMULTANEOUS_SUPPORT = 70,2008WMI_TLV_SERVICE_OCB = 71,2009WMI_TLV_SERVICE_AP_ARPNS_OFFLOAD = 72,2010WMI_TLV_SERVICE_PER_BAND_CHAINMASK_SUPPORT = 73,2011WMI_TLV_SERVICE_PACKET_FILTER_OFFLOAD = 74,2012WMI_TLV_SERVICE_MGMT_TX_HTT = 75,2013WMI_TLV_SERVICE_MGMT_TX_WMI = 76,2014WMI_TLV_SERVICE_EXT_MSG = 77,2015WMI_TLV_SERVICE_MAWC = 78,2016WMI_TLV_SERVICE_PEER_ASSOC_CONF = 79,2017WMI_TLV_SERVICE_EGAP = 80,2018WMI_TLV_SERVICE_STA_PMF_OFFLOAD = 81,2019WMI_TLV_SERVICE_UNIFIED_WOW_CAPABILITY = 82,2020WMI_TLV_SERVICE_ENHANCED_PROXY_STA = 83,2021WMI_TLV_SERVICE_ATF = 84,2022WMI_TLV_SERVICE_COEX_GPIO = 85,2023WMI_TLV_SERVICE_AUX_SPECTRAL_INTF = 86,2024WMI_TLV_SERVICE_AUX_CHAN_LOAD_INTF = 87,2025WMI_TLV_SERVICE_BSS_CHANNEL_INFO_64 = 88,2026WMI_TLV_SERVICE_ENTERPRISE_MESH = 89,2027WMI_TLV_SERVICE_RESTRT_CHNL_SUPPORT = 90,2028WMI_TLV_SERVICE_BPF_OFFLOAD = 91,2029WMI_TLV_SERVICE_SYNC_DELETE_CMDS = 92,2030WMI_TLV_SERVICE_SMART_ANTENNA_SW_SUPPORT = 93,2031WMI_TLV_SERVICE_SMART_ANTENNA_HW_SUPPORT = 94,2032WMI_TLV_SERVICE_RATECTRL_LIMIT_MAX_MIN_RATES = 95,2033WMI_TLV_SERVICE_NAN_DATA = 96,2034WMI_TLV_SERVICE_NAN_RTT = 97,2035WMI_TLV_SERVICE_11AX = 98,2036WMI_TLV_SERVICE_DEPRECATED_REPLACE = 99,2037WMI_TLV_SERVICE_TDLS_CONN_TRACKER_IN_HOST_MODE = 100,2038WMI_TLV_SERVICE_ENHANCED_MCAST_FILTER = 101,2039WMI_TLV_SERVICE_PERIODIC_CHAN_STAT_SUPPORT = 102,2040WMI_TLV_SERVICE_MESH_11S = 103,2041WMI_TLV_SERVICE_HALF_RATE_QUARTER_RATE_SUPPORT = 104,2042WMI_TLV_SERVICE_VDEV_RX_FILTER = 105,2043WMI_TLV_SERVICE_P2P_LISTEN_OFFLOAD_SUPPORT = 106,2044WMI_TLV_SERVICE_MARK_FIRST_WAKEUP_PACKET = 107,2045WMI_TLV_SERVICE_MULTIPLE_MCAST_FILTER_SET = 108,2046WMI_TLV_SERVICE_HOST_MANAGED_RX_REORDER = 109,2047WMI_TLV_SERVICE_FLASH_RDWR_SUPPORT = 110,2048WMI_TLV_SERVICE_WLAN_STATS_REPORT = 111,2049WMI_TLV_SERVICE_TX_MSDU_ID_NEW_PARTITION_SUPPORT = 112,2050WMI_TLV_SERVICE_DFS_PHYERR_OFFLOAD = 113,2051WMI_TLV_SERVICE_RCPI_SUPPORT = 114,2052WMI_TLV_SERVICE_FW_MEM_DUMP_SUPPORT = 115,2053WMI_TLV_SERVICE_PEER_STATS_INFO = 116,2054WMI_TLV_SERVICE_REGULATORY_DB = 117,2055WMI_TLV_SERVICE_11D_OFFLOAD = 118,2056WMI_TLV_SERVICE_HW_DATA_FILTERING = 119,2057WMI_TLV_SERVICE_MULTIPLE_VDEV_RESTART = 120,2058WMI_TLV_SERVICE_PKT_ROUTING = 121,2059WMI_TLV_SERVICE_CHECK_CAL_VERSION = 122,2060WMI_TLV_SERVICE_OFFCHAN_TX_WMI = 123,2061WMI_TLV_SERVICE_8SS_TX_BFEE = 124,2062WMI_TLV_SERVICE_EXTENDED_NSS_SUPPORT = 125,2063WMI_TLV_SERVICE_ACK_TIMEOUT = 126,2064WMI_TLV_SERVICE_PDEV_BSS_CHANNEL_INFO_64 = 127,20652066WMI_MAX_SERVICE = 128,20672068WMI_TLV_SERVICE_CHAN_LOAD_INFO = 128,2069WMI_TLV_SERVICE_TX_PPDU_INFO_STATS_SUPPORT = 129,2070WMI_TLV_SERVICE_VDEV_LIMIT_OFFCHAN_SUPPORT = 130,2071WMI_TLV_SERVICE_FILS_SUPPORT = 131,2072WMI_TLV_SERVICE_WLAN_OIC_PING_OFFLOAD = 132,2073WMI_TLV_SERVICE_WLAN_DHCP_RENEW = 133,2074WMI_TLV_SERVICE_MAWC_SUPPORT = 134,2075WMI_TLV_SERVICE_VDEV_LATENCY_CONFIG = 135,2076WMI_TLV_SERVICE_PDEV_UPDATE_CTLTABLE_SUPPORT = 136,2077WMI_TLV_SERVICE_PKTLOG_SUPPORT_OVER_HTT = 137,2078WMI_TLV_SERVICE_VDEV_MULTI_GROUP_KEY_SUPPORT = 138,2079WMI_TLV_SERVICE_SCAN_PHYMODE_SUPPORT = 139,2080WMI_TLV_SERVICE_THERM_THROT = 140,2081WMI_TLV_SERVICE_BCN_OFFLOAD_START_STOP_SUPPORT = 141,2082WMI_TLV_SERVICE_WOW_WAKEUP_BY_TIMER_PATTERN = 142,2083WMI_TLV_SERVICE_PEER_MAP_UNMAP_V2_SUPPORT = 143,2084WMI_TLV_SERVICE_OFFCHAN_DATA_TID_SUPPORT = 144,2085WMI_TLV_SERVICE_RX_PROMISC_ENABLE_SUPPORT = 145,2086WMI_TLV_SERVICE_SUPPORT_DIRECT_DMA = 146,2087WMI_TLV_SERVICE_AP_OBSS_DETECTION_OFFLOAD = 147,2088WMI_TLV_SERVICE_11K_NEIGHBOUR_REPORT_SUPPORT = 148,2089WMI_TLV_SERVICE_LISTEN_INTERVAL_OFFLOAD_SUPPORT = 149,2090WMI_TLV_SERVICE_BSS_COLOR_OFFLOAD = 150,2091WMI_TLV_SERVICE_RUNTIME_DPD_RECAL = 151,2092WMI_TLV_SERVICE_STA_TWT = 152,2093WMI_TLV_SERVICE_AP_TWT = 153,2094WMI_TLV_SERVICE_GMAC_OFFLOAD_SUPPORT = 154,2095WMI_TLV_SERVICE_SPOOF_MAC_SUPPORT = 155,2096WMI_TLV_SERVICE_PEER_TID_CONFIGS_SUPPORT = 156,2097WMI_TLV_SERVICE_VDEV_SWRETRY_PER_AC_CONFIG_SUPPORT = 157,2098WMI_TLV_SERVICE_DUAL_BEACON_ON_SINGLE_MAC_SCC_SUPPORT = 158,2099WMI_TLV_SERVICE_DUAL_BEACON_ON_SINGLE_MAC_MCC_SUPPORT = 159,2100WMI_TLV_SERVICE_MOTION_DET = 160,2101WMI_TLV_SERVICE_INFRA_MBSSID = 161,2102WMI_TLV_SERVICE_OBSS_SPATIAL_REUSE = 162,2103WMI_TLV_SERVICE_VDEV_DIFFERENT_BEACON_INTERVAL_SUPPORT = 163,2104WMI_TLV_SERVICE_NAN_DBS_SUPPORT = 164,2105WMI_TLV_SERVICE_NDI_DBS_SUPPORT = 165,2106WMI_TLV_SERVICE_NAN_SAP_SUPPORT = 166,2107WMI_TLV_SERVICE_NDI_SAP_SUPPORT = 167,2108WMI_TLV_SERVICE_CFR_CAPTURE_SUPPORT = 168,2109WMI_TLV_SERVICE_CFR_CAPTURE_IND_MSG_TYPE_1 = 169,2110WMI_TLV_SERVICE_ESP_SUPPORT = 170,2111WMI_TLV_SERVICE_PEER_CHWIDTH_CHANGE = 171,2112WMI_TLV_SERVICE_WLAN_HPCS_PULSE = 172,2113WMI_TLV_SERVICE_PER_VDEV_CHAINMASK_CONFIG_SUPPORT = 173,2114WMI_TLV_SERVICE_TX_DATA_MGMT_ACK_RSSI = 174,2115WMI_TLV_SERVICE_NAN_DISABLE_SUPPORT = 175,2116WMI_TLV_SERVICE_HTT_H2T_NO_HTC_HDR_LEN_IN_MSG_LEN = 176,2117WMI_TLV_SERVICE_COEX_SUPPORT_UNEQUAL_ISOLATION = 177,2118WMI_TLV_SERVICE_HW_DB2DBM_CONVERSION_SUPPORT = 178,2119WMI_TLV_SERVICE_SUPPORT_EXTEND_ADDRESS = 179,2120WMI_TLV_SERVICE_BEACON_RECEPTION_STATS = 180,2121WMI_TLV_SERVICE_FETCH_TX_PN = 181,2122WMI_TLV_SERVICE_PEER_UNMAP_RESPONSE_SUPPORT = 182,2123WMI_TLV_SERVICE_TX_PER_PEER_AMPDU_SIZE = 183,2124WMI_TLV_SERVICE_BSS_COLOR_SWITCH_COUNT = 184,2125WMI_TLV_SERVICE_HTT_PEER_STATS_SUPPORT = 185,2126WMI_TLV_SERVICE_UL_RU26_ALLOWED = 186,2127WMI_TLV_SERVICE_GET_MWS_COEX_STATE = 187,2128WMI_TLV_SERVICE_GET_MWS_DPWB_STATE = 188,2129WMI_TLV_SERVICE_GET_MWS_TDM_STATE = 189,2130WMI_TLV_SERVICE_GET_MWS_IDRX_STATE = 190,2131WMI_TLV_SERVICE_GET_MWS_ANTENNA_SHARING_STATE = 191,2132WMI_TLV_SERVICE_ENHANCED_TPC_CONFIG_EVENT = 192,2133WMI_TLV_SERVICE_WLM_STATS_REQUEST = 193,2134WMI_TLV_SERVICE_EXT_PEER_TID_CONFIGS_SUPPORT = 194,2135WMI_TLV_SERVICE_WPA3_FT_SAE_SUPPORT = 195,2136WMI_TLV_SERVICE_WPA3_FT_SUITE_B_SUPPORT = 196,2137WMI_TLV_SERVICE_VOW_ENABLE = 197,2138WMI_TLV_SERVICE_CFR_CAPTURE_IND_EVT_TYPE_1 = 198,2139WMI_TLV_SERVICE_BROADCAST_TWT = 199,2140WMI_TLV_SERVICE_RAP_DETECTION_SUPPORT = 200,2141WMI_TLV_SERVICE_PS_TDCC = 201,2142WMI_TLV_SERVICE_THREE_WAY_COEX_CONFIG_LEGACY = 202,2143WMI_TLV_SERVICE_THREE_WAY_COEX_CONFIG_OVERRIDE = 203,2144WMI_TLV_SERVICE_TX_PWR_PER_PEER = 204,2145WMI_TLV_SERVICE_STA_PLUS_STA_SUPPORT = 205,2146WMI_TLV_SERVICE_WPA3_FT_FILS = 206,2147WMI_TLV_SERVICE_ADAPTIVE_11R_ROAM = 207,2148WMI_TLV_SERVICE_CHAN_RF_CHARACTERIZATION_INFO = 208,2149WMI_TLV_SERVICE_FW_IFACE_COMBINATION_SUPPORT = 209,2150WMI_TLV_SERVICE_TX_COMPL_TSF64 = 210,2151WMI_TLV_SERVICE_DSM_ROAM_FILTER = 211,2152WMI_TLV_SERVICE_PACKET_CAPTURE_SUPPORT = 212,2153WMI_TLV_SERVICE_PER_PEER_HTT_STATS_RESET = 213,2154WMI_TLV_SERVICE_FREQINFO_IN_METADATA = 219,2155WMI_TLV_SERVICE_EXT2_MSG = 220,21562157WMI_MAX_EXT_SERVICE = 256,21582159WMI_TLV_SERVICE_REG_CC_EXT_EVENT_SUPPORT = 281,2160WMI_MAX_EXT2_SERVICE,2161};21622163enum {2164WMI_SMPS_FORCED_MODE_NONE = 0,2165WMI_SMPS_FORCED_MODE_DISABLED,2166WMI_SMPS_FORCED_MODE_STATIC,2167WMI_SMPS_FORCED_MODE_DYNAMIC2168};21692170enum wmi_tpc_chainmask {2171WMI_TPC_CHAINMASK_CONFIG_BAND_2G = 0,2172WMI_TPC_CHAINMASK_CONFIG_BAND_5G = 1,2173WMI_NUM_SUPPORTED_BAND_MAX = 2,2174};21752176enum wmi_peer_param {2177WMI_PEER_MIMO_PS_STATE = 1,2178WMI_PEER_AMPDU = 2,2179WMI_PEER_AUTHORIZE = 3,2180WMI_PEER_CHWIDTH = 4,2181WMI_PEER_NSS = 5,2182WMI_PEER_USE_4ADDR = 6,2183WMI_PEER_MEMBERSHIP = 7,2184WMI_PEER_USERPOS = 8,2185WMI_PEER_CRIT_PROTO_HINT_ENABLED = 9,2186WMI_PEER_TX_FAIL_CNT_THR = 10,2187WMI_PEER_SET_HW_RETRY_CTS2S = 11,2188WMI_PEER_IBSS_ATIM_WINDOW_LENGTH = 12,2189WMI_PEER_PHYMODE = 13,2190WMI_PEER_USE_FIXED_PWR = 14,2191WMI_PEER_PARAM_FIXED_RATE = 15,2192WMI_PEER_SET_MU_WHITELIST = 16,2193WMI_PEER_SET_MAX_TX_RATE = 17,2194WMI_PEER_SET_MIN_TX_RATE = 18,2195WMI_PEER_SET_DEFAULT_ROUTING = 19,2196};21972198enum wmi_slot_time {2199WMI_VDEV_SLOT_TIME_LONG = 1,2200WMI_VDEV_SLOT_TIME_SHORT = 2,2201};22022203enum wmi_preamble {2204WMI_VDEV_PREAMBLE_LONG = 1,2205WMI_VDEV_PREAMBLE_SHORT = 2,2206};22072208enum wmi_peer_smps_state {2209WMI_PEER_SMPS_PS_NONE = 0,2210WMI_PEER_SMPS_STATIC = 1,2211WMI_PEER_SMPS_DYNAMIC = 22212};22132214enum wmi_peer_chwidth {2215WMI_PEER_CHWIDTH_20MHZ = 0,2216WMI_PEER_CHWIDTH_40MHZ = 1,2217WMI_PEER_CHWIDTH_80MHZ = 2,2218WMI_PEER_CHWIDTH_160MHZ = 3,2219};22202221enum wmi_beacon_gen_mode {2222WMI_BEACON_STAGGERED_MODE = 0,2223WMI_BEACON_BURST_MODE = 12224};22252226enum wmi_direct_buffer_module {2227WMI_DIRECT_BUF_SPECTRAL = 0,2228WMI_DIRECT_BUF_CFR = 1,22292230/* keep it last */2231WMI_DIRECT_BUF_MAX2232};22332234struct ath12k_wmi_pdev_band_arg {2235u32 pdev_id;2236u32 start_freq;2237u32 end_freq;2238};22392240struct ath12k_wmi_ppe_threshold_arg {2241u32 numss_m1;2242u32 ru_bit_mask;2243u32 ppet16_ppet8_ru3_ru0[WMI_MAX_NUM_SS];2244};22452246#define PSOC_HOST_MAX_PHY_SIZE (3)2247#define ATH12K_11B_SUPPORT BIT(0)2248#define ATH12K_11G_SUPPORT BIT(1)2249#define ATH12K_11A_SUPPORT BIT(2)2250#define ATH12K_11N_SUPPORT BIT(3)2251#define ATH12K_11AC_SUPPORT BIT(4)2252#define ATH12K_11AX_SUPPORT BIT(5)22532254struct ath12k_wmi_hal_reg_capabilities_ext_arg {2255u32 phy_id;2256u32 eeprom_reg_domain;2257u32 eeprom_reg_domain_ext;2258u32 regcap1;2259u32 regcap2;2260u32 wireless_modes;2261u32 low_2ghz_chan;2262u32 high_2ghz_chan;2263u32 low_5ghz_chan;2264u32 high_5ghz_chan;2265};22662267#define WMI_HOST_MAX_PDEV 322682269struct ath12k_wmi_host_mem_chunk_params {2270__le32 tlv_header;2271__le32 req_id;2272__le32 ptr;2273__le32 size;2274} __packed;22752276struct ath12k_wmi_host_mem_chunk_arg {2277void *vaddr;2278dma_addr_t paddr;2279u32 len;2280u32 req_id;2281};22822283struct ath12k_wmi_resource_config_arg {2284u32 num_vdevs;2285u32 num_peers;2286u32 num_active_peers;2287u32 num_offload_peers;2288u32 num_offload_reorder_buffs;2289u32 num_peer_keys;2290u32 num_tids;2291u32 ast_skid_limit;2292u32 tx_chain_mask;2293u32 rx_chain_mask;2294u32 rx_timeout_pri[4];2295u32 rx_decap_mode;2296u32 scan_max_pending_req;2297u32 bmiss_offload_max_vdev;2298u32 roam_offload_max_vdev;2299u32 roam_offload_max_ap_profiles;2300u32 num_mcast_groups;2301u32 num_mcast_table_elems;2302u32 mcast2ucast_mode;2303u32 tx_dbg_log_size;2304u32 num_wds_entries;2305u32 dma_burst_size;2306u32 mac_aggr_delim;2307u32 rx_skip_defrag_timeout_dup_detection_check;2308u32 vow_config;2309u32 gtk_offload_max_vdev;2310u32 num_msdu_desc;2311u32 max_frag_entries;2312u32 max_peer_ext_stats;2313u32 smart_ant_cap;2314u32 bk_minfree;2315u32 be_minfree;2316u32 vi_minfree;2317u32 vo_minfree;2318u32 rx_batchmode;2319u32 tt_support;2320u32 atf_config;2321u32 iphdr_pad_config;2322u32 qwrap_config:16,2323alloc_frag_desc_for_data_pkt:16;2324u32 num_tdls_vdevs;2325u32 num_tdls_conn_table_entries;2326u32 beacon_tx_offload_max_vdev;2327u32 num_multicast_filter_entries;2328u32 num_wow_filters;2329u32 num_keep_alive_pattern;2330u32 keep_alive_pattern_size;2331u32 max_tdls_concurrent_sleep_sta;2332u32 max_tdls_concurrent_buffer_sta;2333u32 wmi_send_separate;2334u32 num_ocb_vdevs;2335u32 num_ocb_channels;2336u32 num_ocb_schedules;2337u32 num_ns_ext_tuples_cfg;2338u32 bpf_instruction_size;2339u32 max_bssid_rx_filters;2340u32 use_pdev_id;2341u32 peer_map_unmap_version;2342u32 sched_params;2343u32 twt_ap_pdev_count;2344u32 twt_ap_sta_count;2345bool is_reg_cc_ext_event_supported;2346};23472348struct ath12k_wmi_init_cmd_arg {2349struct ath12k_wmi_resource_config_arg res_cfg;2350u8 num_mem_chunks;2351struct ath12k_wmi_host_mem_chunk_arg *mem_chunks;2352u32 hw_mode_id;2353u32 num_band_to_mac;2354struct ath12k_wmi_pdev_band_arg band_to_mac[WMI_HOST_MAX_PDEV];2355};23562357struct ath12k_wmi_pdev_band_to_mac_params {2358__le32 tlv_header;2359__le32 pdev_id;2360__le32 start_freq;2361__le32 end_freq;2362} __packed;23632364/* This is both individual command WMI_PDEV_SET_HW_MODE_CMDID and also part2365* of WMI_TAG_INIT_CMD.2366*/2367struct ath12k_wmi_pdev_set_hw_mode_cmd {2368__le32 tlv_header;2369__le32 pdev_id;2370__le32 hw_mode_index;2371__le32 num_band_to_mac;2372} __packed;23732374struct ath12k_wmi_ppe_threshold_params {2375__le32 numss_m1; /** NSS - 1*/2376__le32 ru_info;2377__le32 ppet16_ppet8_ru3_ru0[WMI_MAX_NUM_SS];2378} __packed;23792380#define HW_BD_INFO_SIZE 523812382struct ath12k_wmi_abi_version_params {2383__le32 abi_version_0;2384__le32 abi_version_1;2385__le32 abi_version_ns_0;2386__le32 abi_version_ns_1;2387__le32 abi_version_ns_2;2388__le32 abi_version_ns_3;2389} __packed;23902391struct wmi_init_cmd {2392__le32 tlv_header;2393struct ath12k_wmi_abi_version_params host_abi_vers;2394__le32 num_host_mem_chunks;2395} __packed;23962397#define WMI_RSRC_CFG_HOST_SVC_FLAG_REG_CC_EXT_SUPPORT_BIT 423982399struct ath12k_wmi_resource_config_params {2400__le32 tlv_header;2401__le32 num_vdevs;2402__le32 num_peers;2403__le32 num_offload_peers;2404__le32 num_offload_reorder_buffs;2405__le32 num_peer_keys;2406__le32 num_tids;2407__le32 ast_skid_limit;2408__le32 tx_chain_mask;2409__le32 rx_chain_mask;2410__le32 rx_timeout_pri[4];2411__le32 rx_decap_mode;2412__le32 scan_max_pending_req;2413__le32 bmiss_offload_max_vdev;2414__le32 roam_offload_max_vdev;2415__le32 roam_offload_max_ap_profiles;2416__le32 num_mcast_groups;2417__le32 num_mcast_table_elems;2418__le32 mcast2ucast_mode;2419__le32 tx_dbg_log_size;2420__le32 num_wds_entries;2421__le32 dma_burst_size;2422__le32 mac_aggr_delim;2423__le32 rx_skip_defrag_timeout_dup_detection_check;2424__le32 vow_config;2425__le32 gtk_offload_max_vdev;2426__le32 num_msdu_desc;2427__le32 max_frag_entries;2428__le32 num_tdls_vdevs;2429__le32 num_tdls_conn_table_entries;2430__le32 beacon_tx_offload_max_vdev;2431__le32 num_multicast_filter_entries;2432__le32 num_wow_filters;2433__le32 num_keep_alive_pattern;2434__le32 keep_alive_pattern_size;2435__le32 max_tdls_concurrent_sleep_sta;2436__le32 max_tdls_concurrent_buffer_sta;2437__le32 wmi_send_separate;2438__le32 num_ocb_vdevs;2439__le32 num_ocb_channels;2440__le32 num_ocb_schedules;2441__le32 flag1;2442__le32 smart_ant_cap;2443__le32 bk_minfree;2444__le32 be_minfree;2445__le32 vi_minfree;2446__le32 vo_minfree;2447__le32 alloc_frag_desc_for_data_pkt;2448__le32 num_ns_ext_tuples_cfg;2449__le32 bpf_instruction_size;2450__le32 max_bssid_rx_filters;2451__le32 use_pdev_id;2452__le32 max_num_dbs_scan_duty_cycle;2453__le32 max_num_group_keys;2454__le32 peer_map_unmap_version;2455__le32 sched_params;2456__le32 twt_ap_pdev_count;2457__le32 twt_ap_sta_count;2458__le32 max_nlo_ssids;2459__le32 num_pkt_filters;2460__le32 num_max_sta_vdevs;2461__le32 max_bssid_indicator;2462__le32 ul_resp_config;2463__le32 msdu_flow_override_config0;2464__le32 msdu_flow_override_config1;2465__le32 flags2;2466__le32 host_service_flags;2467__le32 max_rnr_neighbours;2468__le32 ema_max_vap_cnt;2469__le32 ema_max_profile_period;2470} __packed;24712472struct wmi_service_ready_event {2473__le32 fw_build_vers;2474struct ath12k_wmi_abi_version_params fw_abi_vers;2475__le32 phy_capability;2476__le32 max_frag_entry;2477__le32 num_rf_chains;2478__le32 ht_cap_info;2479__le32 vht_cap_info;2480__le32 vht_supp_mcs;2481__le32 hw_min_tx_power;2482__le32 hw_max_tx_power;2483__le32 sys_cap_info;2484__le32 min_pkt_size_enable;2485__le32 max_bcn_ie_size;2486__le32 num_mem_reqs;2487__le32 max_num_scan_channels;2488__le32 hw_bd_id;2489__le32 hw_bd_info[HW_BD_INFO_SIZE];2490__le32 max_supported_macs;2491__le32 wmi_fw_sub_feat_caps;2492__le32 num_dbs_hw_modes;2493/* txrx_chainmask2494* [7:0] - 2G band tx chain mask2495* [15:8] - 2G band rx chain mask2496* [23:16] - 5G band tx chain mask2497* [31:24] - 5G band rx chain mask2498*/2499__le32 txrx_chainmask;2500__le32 default_dbs_hw_mode_index;2501__le32 num_msdu_desc;2502} __packed;25032504#define WMI_SERVICE_BM_SIZE ((WMI_MAX_SERVICE + sizeof(u32) - 1) / sizeof(u32))25052506#define WMI_SERVICE_SEGMENT_BM_SIZE32 4 /* 4x u32 = 128 bits */2507#define WMI_SERVICE_EXT_BM_SIZE (WMI_SERVICE_SEGMENT_BM_SIZE32 * sizeof(u32))2508#define WMI_AVAIL_SERVICE_BITS_IN_SIZE32 322509#define WMI_SERVICE_BITS_IN_SIZE32 425102511struct wmi_service_ready_ext_event {2512__le32 default_conc_scan_config_bits;2513__le32 default_fw_config_bits;2514struct ath12k_wmi_ppe_threshold_params ppet;2515__le32 he_cap_info;2516__le32 mpdu_density;2517__le32 max_bssid_rx_filters;2518__le32 fw_build_vers_ext;2519__le32 max_nlo_ssids;2520__le32 max_bssid_indicator;2521__le32 he_cap_info_ext;2522} __packed;25232524struct ath12k_wmi_soc_mac_phy_hw_mode_caps_params {2525__le32 num_hw_modes;2526__le32 num_chainmask_tables;2527} __packed;25282529struct ath12k_wmi_hw_mode_cap_params {2530__le32 tlv_header;2531__le32 hw_mode_id;2532__le32 phy_id_map;2533__le32 hw_mode_config_type;2534} __packed;25352536#define WMI_MAX_HECAP_PHY_SIZE (3)25372538struct ath12k_wmi_mac_phy_caps_params {2539__le32 hw_mode_id;2540__le32 pdev_id;2541__le32 phy_id;2542__le32 supported_flags;2543__le32 supported_bands;2544__le32 ampdu_density;2545__le32 max_bw_supported_2g;2546__le32 ht_cap_info_2g;2547__le32 vht_cap_info_2g;2548__le32 vht_supp_mcs_2g;2549__le32 he_cap_info_2g;2550__le32 he_supp_mcs_2g;2551__le32 tx_chain_mask_2g;2552__le32 rx_chain_mask_2g;2553__le32 max_bw_supported_5g;2554__le32 ht_cap_info_5g;2555__le32 vht_cap_info_5g;2556__le32 vht_supp_mcs_5g;2557__le32 he_cap_info_5g;2558__le32 he_supp_mcs_5g;2559__le32 tx_chain_mask_5g;2560__le32 rx_chain_mask_5g;2561__le32 he_cap_phy_info_2g[WMI_MAX_HECAP_PHY_SIZE];2562__le32 he_cap_phy_info_5g[WMI_MAX_HECAP_PHY_SIZE];2563struct ath12k_wmi_ppe_threshold_params he_ppet2g;2564struct ath12k_wmi_ppe_threshold_params he_ppet5g;2565__le32 chainmask_table_id;2566__le32 lmac_id;2567__le32 he_cap_info_2g_ext;2568__le32 he_cap_info_5g_ext;2569__le32 he_cap_info_internal;2570} __packed;25712572struct ath12k_wmi_hal_reg_caps_ext_params {2573__le32 tlv_header;2574__le32 phy_id;2575__le32 eeprom_reg_domain;2576__le32 eeprom_reg_domain_ext;2577__le32 regcap1;2578__le32 regcap2;2579__le32 wireless_modes;2580__le32 low_2ghz_chan;2581__le32 high_2ghz_chan;2582__le32 low_5ghz_chan;2583__le32 high_5ghz_chan;2584} __packed;25852586struct ath12k_wmi_soc_hal_reg_caps_params {2587__le32 num_phy;2588} __packed;25892590#define WMI_MAX_EHTCAP_MAC_SIZE 22591#define WMI_MAX_EHTCAP_PHY_SIZE 32592#define WMI_MAX_EHTCAP_RATE_SET 325932594/* Used for EHT MCS-NSS array. Data at each array index follows the format given2595* in IEEE P802.11be/D2.0, May 20229.4.2.313.4.2596*2597* Index interpretation:2598* 0 - 20 MHz only sta, all 4 bytes valid2599* 1 - index for bandwidths <= 80 MHz except 20 MHz-only, first 3 bytes valid2600* 2 - index for 160 MHz, first 3 bytes valid2601* 3 - index for 320 MHz, first 3 bytes valid2602*/2603#define WMI_MAX_EHT_SUPP_MCS_2G_SIZE 22604#define WMI_MAX_EHT_SUPP_MCS_5G_SIZE 426052606#define WMI_EHTCAP_TXRX_MCS_NSS_IDX_80 02607#define WMI_EHTCAP_TXRX_MCS_NSS_IDX_160 12608#define WMI_EHTCAP_TXRX_MCS_NSS_IDX_320 226092610#define WMI_EHT_MCS_NSS_0_7 GENMASK(3, 0)2611#define WMI_EHT_MCS_NSS_8_9 GENMASK(7, 4)2612#define WMI_EHT_MCS_NSS_10_11 GENMASK(11, 8)2613#define WMI_EHT_MCS_NSS_12_13 GENMASK(15, 12)26142615struct wmi_service_ready_ext2_event {2616__le32 reg_db_version;2617__le32 hw_min_max_tx_power_2ghz;2618__le32 hw_min_max_tx_power_5ghz;2619__le32 chwidth_num_peer_caps;2620__le32 preamble_puncture_bw;2621__le32 max_user_per_ppdu_ofdma;2622__le32 max_user_per_ppdu_mumimo;2623__le32 target_cap_flags;2624__le32 eht_cap_mac_info[WMI_MAX_EHTCAP_MAC_SIZE];2625__le32 max_num_linkview_peers;2626__le32 max_num_msduq_supported_per_tid;2627__le32 default_num_msduq_supported_per_tid;2628} __packed;26292630struct ath12k_wmi_caps_ext_params {2631__le32 hw_mode_id;2632union {2633struct {2634__le16 pdev_id;2635__le16 hw_link_id;2636} __packed ath12k_wmi_pdev_to_link_map;2637__le32 pdev_id;2638};2639__le32 phy_id;2640__le32 wireless_modes_ext;2641__le32 eht_cap_mac_info_2ghz[WMI_MAX_EHTCAP_MAC_SIZE];2642__le32 eht_cap_mac_info_5ghz[WMI_MAX_EHTCAP_MAC_SIZE];2643__le32 rsvd0[2];2644__le32 eht_cap_phy_info_2ghz[WMI_MAX_EHTCAP_PHY_SIZE];2645__le32 eht_cap_phy_info_5ghz[WMI_MAX_EHTCAP_PHY_SIZE];2646struct ath12k_wmi_ppe_threshold_params eht_ppet_2ghz;2647struct ath12k_wmi_ppe_threshold_params eht_ppet_5ghz;2648__le32 eht_cap_info_internal;2649__le32 eht_supp_mcs_ext_2ghz[WMI_MAX_EHT_SUPP_MCS_2G_SIZE];2650__le32 eht_supp_mcs_ext_5ghz[WMI_MAX_EHT_SUPP_MCS_5G_SIZE];2651} __packed;26522653/* 2 word representation of MAC addr */2654struct ath12k_wmi_mac_addr_params {2655u8 addr[ETH_ALEN];2656u8 padding[2];2657} __packed;26582659struct ath12k_wmi_dma_ring_caps_params {2660__le32 tlv_header;2661__le32 pdev_id;2662__le32 module_id;2663__le32 min_elem;2664__le32 min_buf_sz;2665__le32 min_buf_align;2666} __packed;26672668struct ath12k_wmi_ready_event_min_params {2669struct ath12k_wmi_abi_version_params fw_abi_vers;2670struct ath12k_wmi_mac_addr_params mac_addr;2671__le32 status;2672__le32 num_dscp_table;2673__le32 num_extra_mac_addr;2674__le32 num_total_peers;2675__le32 num_extra_peers;2676} __packed;26772678struct wmi_ready_event {2679struct ath12k_wmi_ready_event_min_params ready_event_min;2680__le32 max_ast_index;2681__le32 pktlog_defs_checksum;2682} __packed;26832684struct wmi_service_available_event {2685__le32 wmi_service_segment_offset;2686__le32 wmi_service_segment_bitmap[WMI_SERVICE_SEGMENT_BM_SIZE32];2687} __packed;26882689struct ath12k_wmi_vdev_create_arg {2690u8 if_id;2691u32 type;2692u32 subtype;2693struct {2694u8 tx;2695u8 rx;2696} chains[NUM_NL80211_BANDS];2697u32 pdev_id;2698u8 if_stats_id;2699};27002701#define ATH12K_MAX_VDEV_STATS_ID 0x302702#define ATH12K_INVAL_VDEV_STATS_ID 0xFF27032704struct wmi_vdev_create_cmd {2705__le32 tlv_header;2706__le32 vdev_id;2707__le32 vdev_type;2708__le32 vdev_subtype;2709struct ath12k_wmi_mac_addr_params vdev_macaddr;2710__le32 num_cfg_txrx_streams;2711__le32 pdev_id;2712__le32 vdev_stats_id;2713} __packed;27142715struct ath12k_wmi_vdev_txrx_streams_params {2716__le32 tlv_header;2717u32 band;2718u32 supported_tx_streams;2719u32 supported_rx_streams;2720} __packed;27212722struct wmi_vdev_delete_cmd {2723__le32 tlv_header;2724__le32 vdev_id;2725} __packed;27262727struct wmi_vdev_up_cmd {2728__le32 tlv_header;2729__le32 vdev_id;2730__le32 vdev_assoc_id;2731struct ath12k_wmi_mac_addr_params vdev_bssid;2732struct ath12k_wmi_mac_addr_params trans_bssid;2733__le32 profile_idx;2734__le32 profile_num;2735} __packed;27362737struct wmi_vdev_stop_cmd {2738__le32 tlv_header;2739__le32 vdev_id;2740} __packed;27412742struct wmi_vdev_down_cmd {2743__le32 tlv_header;2744__le32 vdev_id;2745} __packed;27462747#define WMI_VDEV_START_HIDDEN_SSID BIT(0)2748#define WMI_VDEV_START_PMF_ENABLED BIT(1)2749#define WMI_VDEV_START_LDPC_RX_ENABLED BIT(3)27502751#define ATH12K_WMI_SSID_LEN 3227522753struct ath12k_wmi_ssid_params {2754__le32 ssid_len;2755u8 ssid[ATH12K_WMI_SSID_LEN];2756} __packed;27572758#define ATH12K_VDEV_SETUP_TIMEOUT_HZ (5 * HZ)27592760struct wmi_vdev_start_request_cmd {2761__le32 tlv_header;2762__le32 vdev_id;2763__le32 requestor_id;2764__le32 beacon_interval;2765__le32 dtim_period;2766__le32 flags;2767struct ath12k_wmi_ssid_params ssid;2768__le32 bcn_tx_rate;2769__le32 bcn_txpower;2770__le32 num_noa_descriptors;2771__le32 disable_hw_ack;2772__le32 preferred_tx_streams;2773__le32 preferred_rx_streams;2774__le32 he_ops;2775__le32 cac_duration_ms;2776__le32 regdomain;2777__le32 min_data_rate;2778__le32 mbssid_flags;2779__le32 mbssid_tx_vdev_id;2780__le32 eht_ops;2781__le32 punct_bitmap;2782} __packed;27832784#define MGMT_TX_DL_FRM_LEN 6427852786struct ath12k_wmi_channel_arg {2787u8 chan_id;2788u8 pwr;2789u32 mhz;2790u32 half_rate:1,2791quarter_rate:1,2792dfs_set:1,2793dfs_set_cfreq2:1,2794is_chan_passive:1,2795allow_ht:1,2796allow_vht:1,2797allow_he:1,2798set_agile:1,2799psc_channel:1;2800u32 phy_mode;2801u32 cfreq1;2802u32 cfreq2;2803char maxpower;2804char minpower;2805char maxregpower;2806u8 antennamax;2807u8 reg_class_id;2808};28092810enum wmi_phy_mode {2811MODE_11A = 0,2812MODE_11G = 1, /* 11b/g Mode */2813MODE_11B = 2, /* 11b Mode */2814MODE_11GONLY = 3, /* 11g only Mode */2815MODE_11NA_HT20 = 4,2816MODE_11NG_HT20 = 5,2817MODE_11NA_HT40 = 6,2818MODE_11NG_HT40 = 7,2819MODE_11AC_VHT20 = 8,2820MODE_11AC_VHT40 = 9,2821MODE_11AC_VHT80 = 10,2822MODE_11AC_VHT20_2G = 11,2823MODE_11AC_VHT40_2G = 12,2824MODE_11AC_VHT80_2G = 13,2825MODE_11AC_VHT80_80 = 14,2826MODE_11AC_VHT160 = 15,2827MODE_11AX_HE20 = 16,2828MODE_11AX_HE40 = 17,2829MODE_11AX_HE80 = 18,2830MODE_11AX_HE80_80 = 19,2831MODE_11AX_HE160 = 20,2832MODE_11AX_HE20_2G = 21,2833MODE_11AX_HE40_2G = 22,2834MODE_11AX_HE80_2G = 23,2835MODE_11BE_EHT20 = 24,2836MODE_11BE_EHT40 = 25,2837MODE_11BE_EHT80 = 26,2838MODE_11BE_EHT80_80 = 27,2839MODE_11BE_EHT160 = 28,2840MODE_11BE_EHT160_160 = 29,2841MODE_11BE_EHT320 = 30,2842MODE_11BE_EHT20_2G = 31,2843MODE_11BE_EHT40_2G = 32,2844MODE_UNKNOWN = 33,2845MODE_MAX = 33,2846};28472848struct wmi_vdev_start_req_arg {2849u32 vdev_id;2850u32 freq;2851u32 band_center_freq1;2852u32 band_center_freq2;2853bool passive;2854bool allow_ibss;2855bool allow_ht;2856bool allow_vht;2857bool ht40plus;2858bool chan_radar;2859bool freq2_radar;2860bool allow_he;2861u32 min_power;2862u32 max_power;2863u32 max_reg_power;2864u32 max_antenna_gain;2865enum wmi_phy_mode mode;2866u32 bcn_intval;2867u32 dtim_period;2868u8 *ssid;2869u32 ssid_len;2870u32 bcn_tx_rate;2871u32 bcn_tx_power;2872bool disable_hw_ack;2873bool hidden_ssid;2874bool pmf_enabled;2875u32 he_ops;2876u32 cac_duration_ms;2877u32 regdomain;2878u32 pref_rx_streams;2879u32 pref_tx_streams;2880u32 num_noa_descriptors;2881u32 min_data_rate;2882u32 mbssid_flags;2883u32 mbssid_tx_vdev_id;2884u32 punct_bitmap;2885};28862887struct ath12k_wmi_peer_create_arg {2888const u8 *peer_addr;2889u32 peer_type;2890u32 vdev_id;2891};28922893struct ath12k_wmi_pdev_set_regdomain_arg {2894u16 current_rd_in_use;2895u16 current_rd_2g;2896u16 current_rd_5g;2897u32 ctl_2g;2898u32 ctl_5g;2899u8 dfs_domain;2900u32 pdev_id;2901};29022903struct ath12k_wmi_rx_reorder_queue_remove_arg {2904u8 *peer_macaddr;2905u16 vdev_id;2906u32 peer_tid_bitmap;2907};29082909#define WMI_HOST_PDEV_ID_SOC 0xFF2910#define WMI_HOST_PDEV_ID_0 02911#define WMI_HOST_PDEV_ID_1 12912#define WMI_HOST_PDEV_ID_2 229132914#define WMI_PDEV_ID_SOC 02915#define WMI_PDEV_ID_1ST 12916#define WMI_PDEV_ID_2ND 22917#define WMI_PDEV_ID_3RD 329182919/* Freq units in MHz */2920#define REG_RULE_START_FREQ 0x0000ffff2921#define REG_RULE_END_FREQ 0xffff00002922#define REG_RULE_FLAGS 0x0000ffff2923#define REG_RULE_MAX_BW 0x0000ffff2924#define REG_RULE_REG_PWR 0x00ff00002925#define REG_RULE_ANT_GAIN 0xff0000002926#define REG_RULE_PSD_INFO BIT(2)2927#define REG_RULE_PSD_EIRP 0xffff000029282929#define WMI_VDEV_PARAM_TXBF_SU_TX_BFEE BIT(0)2930#define WMI_VDEV_PARAM_TXBF_MU_TX_BFEE BIT(1)2931#define WMI_VDEV_PARAM_TXBF_SU_TX_BFER BIT(2)2932#define WMI_VDEV_PARAM_TXBF_MU_TX_BFER BIT(3)29332934#define HECAP_PHYDWORD_0 02935#define HECAP_PHYDWORD_1 12936#define HECAP_PHYDWORD_2 229372938#define HECAP_PHY_SU_BFER BIT(31)2939#define HECAP_PHY_SU_BFEE BIT(0)2940#define HECAP_PHY_MU_BFER BIT(1)2941#define HECAP_PHY_UL_MUMIMO BIT(22)2942#define HECAP_PHY_UL_MUOFDMA BIT(23)29432944#define HECAP_PHY_SUBFMR_GET(hecap_phy) \2945u32_get_bits(hecap_phy[HECAP_PHYDWORD_0], HECAP_PHY_SU_BFER)29462947#define HECAP_PHY_SUBFME_GET(hecap_phy) \2948u32_get_bits(hecap_phy[HECAP_PHYDWORD_1], HECAP_PHY_SU_BFEE)29492950#define HECAP_PHY_MUBFMR_GET(hecap_phy) \2951u32_get_bits(hecap_phy[HECAP_PHYDWORD_1], HECAP_PHY_MU_BFER)29522953#define HECAP_PHY_ULMUMIMO_GET(hecap_phy) \2954u32_get_bits(hecap_phy[HECAP_PHYDWORD_0], HECAP_PHY_UL_MUMIMO)29552956#define HECAP_PHY_ULOFDMA_GET(hecap_phy) \2957u32_get_bits(hecap_phy[HECAP_PHYDWORD_0], HECAP_PHY_UL_MUOFDMA)29582959#define HE_MODE_SU_TX_BFEE BIT(0)2960#define HE_MODE_SU_TX_BFER BIT(1)2961#define HE_MODE_MU_TX_BFEE BIT(2)2962#define HE_MODE_MU_TX_BFER BIT(3)2963#define HE_MODE_DL_OFDMA BIT(4)2964#define HE_MODE_UL_OFDMA BIT(5)2965#define HE_MODE_UL_MUMIMO BIT(6)29662967#define HE_DL_MUOFDMA_ENABLE 12968#define HE_UL_MUOFDMA_ENABLE 12969#define HE_DL_MUMIMO_ENABLE 12970#define HE_MU_BFEE_ENABLE 12971#define HE_SU_BFEE_ENABLE 129722973#define HE_VHT_SOUNDING_MODE_ENABLE 12974#define HE_SU_MU_SOUNDING_MODE_ENABLE 12975#define HE_TRIG_NONTRIG_SOUNDING_MODE_ENABLE 129762977/* HE or VHT Sounding */2978#define HE_VHT_SOUNDING_MODE BIT(0)2979/* SU or MU Sounding */2980#define HE_SU_MU_SOUNDING_MODE BIT(2)2981/* Trig or Non-Trig Sounding */2982#define HE_TRIG_NONTRIG_SOUNDING_MODE BIT(3)29832984#define WMI_TXBF_STS_CAP_OFFSET_LSB 42985#define WMI_TXBF_STS_CAP_OFFSET_MASK 0x702986#define WMI_BF_SOUND_DIM_OFFSET_LSB 82987#define WMI_BF_SOUND_DIM_OFFSET_MASK 0x70029882989enum wmi_peer_type {2990WMI_PEER_TYPE_DEFAULT = 0,2991WMI_PEER_TYPE_BSS = 1,2992WMI_PEER_TYPE_TDLS = 2,2993};29942995struct wmi_peer_create_cmd {2996__le32 tlv_header;2997__le32 vdev_id;2998struct ath12k_wmi_mac_addr_params peer_macaddr;2999__le32 peer_type;3000} __packed;30013002struct wmi_peer_delete_cmd {3003__le32 tlv_header;3004__le32 vdev_id;3005struct ath12k_wmi_mac_addr_params peer_macaddr;3006} __packed;30073008struct wmi_peer_reorder_queue_setup_cmd {3009__le32 tlv_header;3010__le32 vdev_id;3011struct ath12k_wmi_mac_addr_params peer_macaddr;3012__le32 tid;3013__le32 queue_ptr_lo;3014__le32 queue_ptr_hi;3015__le32 queue_no;3016__le32 ba_window_size_valid;3017__le32 ba_window_size;3018} __packed;30193020struct wmi_peer_reorder_queue_remove_cmd {3021__le32 tlv_header;3022__le32 vdev_id;3023struct ath12k_wmi_mac_addr_params peer_macaddr;3024__le32 tid_mask;3025} __packed;30263027enum wmi_bss_chan_info_req_type {3028WMI_BSS_SURVEY_REQ_TYPE_READ = 1,3029WMI_BSS_SURVEY_REQ_TYPE_READ_CLEAR,3030};30313032struct wmi_pdev_set_param_cmd {3033__le32 tlv_header;3034__le32 pdev_id;3035__le32 param_id;3036__le32 param_value;3037} __packed;30383039struct wmi_pdev_set_ps_mode_cmd {3040__le32 tlv_header;3041__le32 vdev_id;3042__le32 sta_ps_mode;3043} __packed;30443045struct wmi_pdev_suspend_cmd {3046__le32 tlv_header;3047__le32 pdev_id;3048__le32 suspend_opt;3049} __packed;30503051struct wmi_pdev_resume_cmd {3052__le32 tlv_header;3053__le32 pdev_id;3054} __packed;30553056struct wmi_pdev_bss_chan_info_req_cmd {3057__le32 tlv_header;3058/* ref wmi_bss_chan_info_req_type */3059__le32 req_type;3060} __packed;30613062struct wmi_ap_ps_peer_cmd {3063__le32 tlv_header;3064__le32 vdev_id;3065struct ath12k_wmi_mac_addr_params peer_macaddr;3066__le32 param;3067__le32 value;3068} __packed;30693070struct wmi_sta_powersave_param_cmd {3071__le32 tlv_header;3072__le32 vdev_id;3073__le32 param;3074__le32 value;3075} __packed;30763077struct wmi_pdev_set_regdomain_cmd {3078__le32 tlv_header;3079__le32 pdev_id;3080__le32 reg_domain;3081__le32 reg_domain_2g;3082__le32 reg_domain_5g;3083__le32 conformance_test_limit_2g;3084__le32 conformance_test_limit_5g;3085__le32 dfs_domain;3086} __packed;30873088struct wmi_peer_set_param_cmd {3089__le32 tlv_header;3090__le32 vdev_id;3091struct ath12k_wmi_mac_addr_params peer_macaddr;3092__le32 param_id;3093__le32 param_value;3094} __packed;30953096struct wmi_peer_flush_tids_cmd {3097__le32 tlv_header;3098__le32 vdev_id;3099struct ath12k_wmi_mac_addr_params peer_macaddr;3100__le32 peer_tid_bitmap;3101} __packed;31023103struct wmi_dfs_phyerr_offload_cmd {3104__le32 tlv_header;3105__le32 pdev_id;3106} __packed;31073108struct wmi_bcn_offload_ctrl_cmd {3109__le32 tlv_header;3110__le32 vdev_id;3111__le32 bcn_ctrl_op;3112} __packed;31133114enum scan_dwelltime_adaptive_mode {3115SCAN_DWELL_MODE_DEFAULT = 0,3116SCAN_DWELL_MODE_CONSERVATIVE = 1,3117SCAN_DWELL_MODE_MODERATE = 2,3118SCAN_DWELL_MODE_AGGRESSIVE = 3,3119SCAN_DWELL_MODE_STATIC = 43120};31213122#define WLAN_SCAN_MAX_NUM_SSID 103123#define WLAN_SCAN_MAX_NUM_BSSID 1031243125struct ath12k_wmi_element_info_arg {3126u32 len;3127u8 *ptr;3128};31293130#define WMI_IE_BITMAP_SIZE 831313132#define WMI_SCAN_MAX_NUM_SSID 0x0A3133/* prefix used by scan requestor ids on the host */3134#define WMI_HOST_SCAN_REQUESTOR_ID_PREFIX 0xA00031353136/* prefix used by scan request ids generated on the host */3137/* host cycles through the lower 12 bits to generate ids */3138#define WMI_HOST_SCAN_REQ_ID_PREFIX 0xA00031393140#define WLAN_SCAN_PARAMS_MAX_SSID 163141#define WLAN_SCAN_PARAMS_MAX_BSSID 43142#define WLAN_SCAN_PARAMS_MAX_IE_LEN 25631433144/* Values lower than this may be refused by some firmware revisions with a scan3145* completion with a timedout reason.3146*/3147#define WMI_SCAN_CHAN_MIN_TIME_MSEC 4031483149/* Scan priority numbers must be sequential, starting with 0 */3150enum wmi_scan_priority {3151WMI_SCAN_PRIORITY_VERY_LOW = 0,3152WMI_SCAN_PRIORITY_LOW,3153WMI_SCAN_PRIORITY_MEDIUM,3154WMI_SCAN_PRIORITY_HIGH,3155WMI_SCAN_PRIORITY_VERY_HIGH,3156WMI_SCAN_PRIORITY_COUNT /* number of priorities supported */3157};31583159enum wmi_scan_event_type {3160WMI_SCAN_EVENT_STARTED = BIT(0),3161WMI_SCAN_EVENT_COMPLETED = BIT(1),3162WMI_SCAN_EVENT_BSS_CHANNEL = BIT(2),3163WMI_SCAN_EVENT_FOREIGN_CHAN = BIT(3),3164WMI_SCAN_EVENT_DEQUEUED = BIT(4),3165/* possibly by high-prio scan */3166WMI_SCAN_EVENT_PREEMPTED = BIT(5),3167WMI_SCAN_EVENT_START_FAILED = BIT(6),3168WMI_SCAN_EVENT_RESTARTED = BIT(7),3169WMI_SCAN_EVENT_FOREIGN_CHAN_EXIT = BIT(8),3170WMI_SCAN_EVENT_SUSPENDED = BIT(9),3171WMI_SCAN_EVENT_RESUMED = BIT(10),3172WMI_SCAN_EVENT_MAX = BIT(15),3173};31743175enum wmi_scan_completion_reason {3176WMI_SCAN_REASON_COMPLETED,3177WMI_SCAN_REASON_CANCELLED,3178WMI_SCAN_REASON_PREEMPTED,3179WMI_SCAN_REASON_TIMEDOUT,3180WMI_SCAN_REASON_INTERNAL_FAILURE,3181WMI_SCAN_REASON_MAX,3182};31833184struct wmi_start_scan_cmd {3185__le32 tlv_header;3186__le32 scan_id;3187__le32 scan_req_id;3188__le32 vdev_id;3189__le32 scan_priority;3190__le32 notify_scan_events;3191__le32 dwell_time_active;3192__le32 dwell_time_passive;3193__le32 min_rest_time;3194__le32 max_rest_time;3195__le32 repeat_probe_time;3196__le32 probe_spacing_time;3197__le32 idle_time;3198__le32 max_scan_time;3199__le32 probe_delay;3200__le32 scan_ctrl_flags;3201__le32 burst_duration;3202__le32 num_chan;3203__le32 num_bssid;3204__le32 num_ssids;3205__le32 ie_len;3206__le32 n_probes;3207struct ath12k_wmi_mac_addr_params mac_addr;3208struct ath12k_wmi_mac_addr_params mac_mask;3209u32 ie_bitmap[WMI_IE_BITMAP_SIZE];3210__le32 num_vendor_oui;3211__le32 scan_ctrl_flags_ext;3212__le32 dwell_time_active_2g;3213__le32 dwell_time_active_6g;3214__le32 dwell_time_passive_6g;3215__le32 scan_start_offset;3216} __packed;32173218#define WMI_SCAN_FLAG_PASSIVE 0x13219#define WMI_SCAN_ADD_BCAST_PROBE_REQ 0x23220#define WMI_SCAN_ADD_CCK_RATES 0x43221#define WMI_SCAN_ADD_OFDM_RATES 0x83222#define WMI_SCAN_CHAN_STAT_EVENT 0x103223#define WMI_SCAN_FILTER_PROBE_REQ 0x203224#define WMI_SCAN_BYPASS_DFS_CHN 0x403225#define WMI_SCAN_CONTINUE_ON_ERROR 0x803226#define WMI_SCAN_FILTER_PROMISCUOS 0x1003227#define WMI_SCAN_FLAG_FORCE_ACTIVE_ON_DFS 0x2003228#define WMI_SCAN_ADD_TPC_IE_IN_PROBE_REQ 0x4003229#define WMI_SCAN_ADD_DS_IE_IN_PROBE_REQ 0x8003230#define WMI_SCAN_ADD_SPOOF_MAC_IN_PROBE_REQ 0x10003231#define WMI_SCAN_OFFCHAN_MGMT_TX 0x20003232#define WMI_SCAN_OFFCHAN_DATA_TX 0x40003233#define WMI_SCAN_CAPTURE_PHY_ERROR 0x80003234#define WMI_SCAN_FLAG_STRICT_PASSIVE_ON_PCHN 0x100003235#define WMI_SCAN_FLAG_HALF_RATE_SUPPORT 0x200003236#define WMI_SCAN_FLAG_QUARTER_RATE_SUPPORT 0x400003237#define WMI_SCAN_RANDOM_SEQ_NO_IN_PROBE_REQ 0x800003238#define WMI_SCAN_ENABLE_IE_WHTELIST_IN_PROBE_REQ 0x10000032393240#define WMI_SCAN_DWELL_MODE_MASK GENMASK(23, 21)32413242enum {3243WMI_SCAN_DWELL_MODE_DEFAULT = 0,3244WMI_SCAN_DWELL_MODE_CONSERVATIVE = 1,3245WMI_SCAN_DWELL_MODE_MODERATE = 2,3246WMI_SCAN_DWELL_MODE_AGGRESSIVE = 3,3247WMI_SCAN_DWELL_MODE_STATIC = 4,3248};32493250struct ath12k_wmi_hint_short_ssid_arg {3251u32 freq_flags;3252u32 short_ssid;3253};32543255struct ath12k_wmi_hint_bssid_arg {3256u32 freq_flags;3257struct ath12k_wmi_mac_addr_params bssid;3258};32593260struct ath12k_wmi_scan_req_arg {3261u32 scan_id;3262u32 scan_req_id;3263u32 vdev_id;3264u32 pdev_id;3265enum wmi_scan_priority scan_priority;3266union {3267struct {3268u32 scan_ev_started:1,3269scan_ev_completed:1,3270scan_ev_bss_chan:1,3271scan_ev_foreign_chan:1,3272scan_ev_dequeued:1,3273scan_ev_preempted:1,3274scan_ev_start_failed:1,3275scan_ev_restarted:1,3276scan_ev_foreign_chn_exit:1,3277scan_ev_invalid:1,3278scan_ev_gpio_timeout:1,3279scan_ev_suspended:1,3280scan_ev_resumed:1;3281};3282u32 scan_events;3283};3284u32 dwell_time_active;3285u32 dwell_time_active_2g;3286u32 dwell_time_passive;3287u32 dwell_time_active_6g;3288u32 dwell_time_passive_6g;3289u32 min_rest_time;3290u32 max_rest_time;3291u32 repeat_probe_time;3292u32 probe_spacing_time;3293u32 idle_time;3294u32 max_scan_time;3295u32 probe_delay;3296union {3297struct {3298u32 scan_f_passive:1,3299scan_f_bcast_probe:1,3300scan_f_cck_rates:1,3301scan_f_ofdm_rates:1,3302scan_f_chan_stat_evnt:1,3303scan_f_filter_prb_req:1,3304scan_f_bypass_dfs_chn:1,3305scan_f_continue_on_err:1,3306scan_f_offchan_mgmt_tx:1,3307scan_f_offchan_data_tx:1,3308scan_f_promisc_mode:1,3309scan_f_capture_phy_err:1,3310scan_f_strict_passive_pch:1,3311scan_f_half_rate:1,3312scan_f_quarter_rate:1,3313scan_f_force_active_dfs_chn:1,3314scan_f_add_tpc_ie_in_probe:1,3315scan_f_add_ds_ie_in_probe:1,3316scan_f_add_spoofed_mac_in_probe:1,3317scan_f_add_rand_seq_in_probe:1,3318scan_f_en_ie_whitelist_in_probe:1,3319scan_f_forced:1,3320scan_f_2ghz:1,3321scan_f_5ghz:1,3322scan_f_80mhz:1;3323};3324u32 scan_flags;3325};3326enum scan_dwelltime_adaptive_mode adaptive_dwell_time_mode;3327u32 burst_duration;3328u32 num_chan;3329u32 num_bssid;3330u32 num_ssids;3331u32 n_probes;3332u32 *chan_list;3333u32 notify_scan_events;3334struct cfg80211_ssid ssid[WLAN_SCAN_MAX_NUM_SSID];3335struct ath12k_wmi_mac_addr_params bssid_list[WLAN_SCAN_MAX_NUM_BSSID];3336struct ath12k_wmi_element_info_arg extraie;3337u32 num_hint_s_ssid;3338u32 num_hint_bssid;3339struct ath12k_wmi_hint_short_ssid_arg hint_s_ssid[WLAN_SCAN_MAX_HINT_S_SSID];3340struct ath12k_wmi_hint_bssid_arg hint_bssid[WLAN_SCAN_MAX_HINT_BSSID];3341};33423343struct wmi_ssid_arg {3344int len;3345const u8 *ssid;3346};33473348struct wmi_bssid_arg {3349const u8 *bssid;3350};33513352struct wmi_start_scan_arg {3353u32 scan_id;3354u32 scan_req_id;3355u32 vdev_id;3356u32 scan_priority;3357u32 notify_scan_events;3358u32 dwell_time_active;3359u32 dwell_time_passive;3360u32 min_rest_time;3361u32 max_rest_time;3362u32 repeat_probe_time;3363u32 probe_spacing_time;3364u32 idle_time;3365u32 max_scan_time;3366u32 probe_delay;3367u32 scan_ctrl_flags;33683369u32 ie_len;3370u32 n_channels;3371u32 n_ssids;3372u32 n_bssids;33733374u8 ie[WLAN_SCAN_PARAMS_MAX_IE_LEN];3375u32 channels[64];3376struct wmi_ssid_arg ssids[WLAN_SCAN_PARAMS_MAX_SSID];3377struct wmi_bssid_arg bssids[WLAN_SCAN_PARAMS_MAX_BSSID];3378};33793380#define WMI_SCAN_STOP_ONE 0x000000003381#define WMI_SCAN_STOP_VAP_ALL 0x010000003382#define WMI_SCAN_STOP_ALL 0x0400000033833384/* Prefix 0xA000 indicates that the scan request3385* is trigger by HOST3386*/3387#define ATH12K_SCAN_ID 0xA00033883389enum scan_cancel_req_type {3390WLAN_SCAN_CANCEL_SINGLE = 1,3391WLAN_SCAN_CANCEL_VDEV_ALL,3392WLAN_SCAN_CANCEL_PDEV_ALL,3393};33943395struct ath12k_wmi_scan_cancel_arg {3396u32 requester;3397u32 scan_id;3398enum scan_cancel_req_type req_type;3399u32 vdev_id;3400u32 pdev_id;3401};34023403struct wmi_bcn_send_from_host_cmd {3404__le32 tlv_header;3405__le32 vdev_id;3406__le32 data_len;3407union {3408__le32 frag_ptr;3409__le32 frag_ptr_lo;3410};3411__le32 frame_ctrl;3412__le32 dtim_flag;3413__le32 bcn_antenna;3414__le32 frag_ptr_hi;3415};34163417#define WMI_CHAN_INFO_MODE GENMASK(5, 0)3418#define WMI_CHAN_INFO_HT40_PLUS BIT(6)3419#define WMI_CHAN_INFO_PASSIVE BIT(7)3420#define WMI_CHAN_INFO_ADHOC_ALLOWED BIT(8)3421#define WMI_CHAN_INFO_AP_DISABLED BIT(9)3422#define WMI_CHAN_INFO_DFS BIT(10)3423#define WMI_CHAN_INFO_ALLOW_HT BIT(11)3424#define WMI_CHAN_INFO_ALLOW_VHT BIT(12)3425#define WMI_CHAN_INFO_CHAN_CHANGE_CAUSE_CSA BIT(13)3426#define WMI_CHAN_INFO_HALF_RATE BIT(14)3427#define WMI_CHAN_INFO_QUARTER_RATE BIT(15)3428#define WMI_CHAN_INFO_DFS_FREQ2 BIT(16)3429#define WMI_CHAN_INFO_ALLOW_HE BIT(17)3430#define WMI_CHAN_INFO_PSC BIT(18)34313432#define WMI_CHAN_REG_INFO1_MIN_PWR GENMASK(7, 0)3433#define WMI_CHAN_REG_INFO1_MAX_PWR GENMASK(15, 8)3434#define WMI_CHAN_REG_INFO1_MAX_REG_PWR GENMASK(23, 16)3435#define WMI_CHAN_REG_INFO1_REG_CLS GENMASK(31, 24)34363437#define WMI_CHAN_REG_INFO2_ANT_MAX GENMASK(7, 0)3438#define WMI_CHAN_REG_INFO2_MAX_TX_PWR GENMASK(15, 8)34393440struct ath12k_wmi_channel_params {3441__le32 tlv_header;3442__le32 mhz;3443__le32 band_center_freq1;3444__le32 band_center_freq2;3445__le32 info;3446__le32 reg_info_1;3447__le32 reg_info_2;3448} __packed;34493450enum wmi_sta_ps_mode {3451WMI_STA_PS_MODE_DISABLED = 0,3452WMI_STA_PS_MODE_ENABLED = 1,3453};34543455#define WMI_SMPS_MASK_LOWER_16BITS 0xFF3456#define WMI_SMPS_MASK_UPPER_3BITS 0x73457#define WMI_SMPS_PARAM_VALUE_SHIFT 2934583459#define ATH12K_WMI_FW_HANG_ASSERT_TYPE 13460#define ATH12K_WMI_FW_HANG_DELAY 034613462/* type, 0:unused 1: ASSERT 2: not respond detect command3463* delay_time_ms, the simulate will delay time3464*/34653466struct wmi_force_fw_hang_cmd {3467__le32 tlv_header;3468__le32 type;3469__le32 delay_time_ms;3470} __packed;34713472struct wmi_vdev_set_param_cmd {3473__le32 tlv_header;3474__le32 vdev_id;3475__le32 param_id;3476__le32 param_value;3477} __packed;34783479struct wmi_get_pdev_temperature_cmd {3480__le32 tlv_header;3481__le32 param;3482__le32 pdev_id;3483} __packed;34843485#define WMI_BEACON_TX_BUFFER_SIZE 51234863487struct wmi_bcn_tmpl_cmd {3488__le32 tlv_header;3489__le32 vdev_id;3490__le32 tim_ie_offset;3491__le32 buf_len;3492__le32 csa_switch_count_offset;3493__le32 ext_csa_switch_count_offset;3494__le32 csa_event_bitmap;3495__le32 mbssid_ie_offset;3496__le32 esp_ie_offset;3497} __packed;34983499struct wmi_vdev_install_key_cmd {3500__le32 tlv_header;3501__le32 vdev_id;3502struct ath12k_wmi_mac_addr_params peer_macaddr;3503__le32 key_idx;3504__le32 key_flags;3505__le32 key_cipher;3506__le64 key_rsc_counter;3507__le64 key_global_rsc_counter;3508__le64 key_tsc_counter;3509u8 wpi_key_rsc_counter[16];3510u8 wpi_key_tsc_counter[16];3511__le32 key_len;3512__le32 key_txmic_len;3513__le32 key_rxmic_len;3514__le32 is_group_key_id_valid;3515__le32 group_key_id;35163517/* Followed by key_data containing key followed by3518* tx mic and then rx mic3519*/3520} __packed;35213522struct wmi_vdev_install_key_arg {3523u32 vdev_id;3524const u8 *macaddr;3525u32 key_idx;3526u32 key_flags;3527u32 key_cipher;3528u32 key_len;3529u32 key_txmic_len;3530u32 key_rxmic_len;3531u64 key_rsc_counter;3532const void *key_data;3533};35343535#define WMI_MAX_SUPPORTED_RATES 1283536#define WMI_HOST_MAX_HECAP_PHY_SIZE 33537#define WMI_HOST_MAX_HE_RATE_SET 33538#define WMI_HECAP_TXRX_MCS_NSS_IDX_80 03539#define WMI_HECAP_TXRX_MCS_NSS_IDX_160 13540#define WMI_HECAP_TXRX_MCS_NSS_IDX_80_80 235413542struct wmi_rate_set_arg {3543u32 num_rates;3544u8 rates[WMI_MAX_SUPPORTED_RATES];3545};35463547struct ath12k_wmi_peer_assoc_arg {3548u32 vdev_id;3549u32 peer_new_assoc;3550u32 peer_associd;3551u32 peer_flags;3552u32 peer_caps;3553u32 peer_listen_intval;3554u32 peer_ht_caps;3555u32 peer_max_mpdu;3556u32 peer_mpdu_density;3557u32 peer_rate_caps;3558u32 peer_nss;3559u32 peer_vht_caps;3560u32 peer_phymode;3561u32 peer_ht_info[2];3562struct wmi_rate_set_arg peer_legacy_rates;3563struct wmi_rate_set_arg peer_ht_rates;3564u32 rx_max_rate;3565u32 rx_mcs_set;3566u32 tx_max_rate;3567u32 tx_mcs_set;3568u8 vht_capable;3569u8 min_data_rate;3570u32 tx_max_mcs_nss;3571u32 peer_bw_rxnss_override;3572bool is_pmf_enabled;3573bool is_wme_set;3574bool qos_flag;3575bool apsd_flag;3576bool ht_flag;3577bool bw_40;3578bool bw_80;3579bool bw_160;3580bool bw_320;3581bool stbc_flag;3582bool ldpc_flag;3583bool static_mimops_flag;3584bool dynamic_mimops_flag;3585bool spatial_mux_flag;3586bool vht_flag;3587bool vht_ng_flag;3588bool need_ptk_4_way;3589bool need_gtk_2_way;3590bool auth_flag;3591bool safe_mode_enabled;3592bool amsdu_disable;3593/* Use common structure */3594u8 peer_mac[ETH_ALEN];35953596bool he_flag;3597u32 peer_he_cap_macinfo[2];3598u32 peer_he_cap_macinfo_internal;3599u32 peer_he_caps_6ghz;3600u32 peer_he_ops;3601u32 peer_he_cap_phyinfo[WMI_HOST_MAX_HECAP_PHY_SIZE];3602u32 peer_he_mcs_count;3603u32 peer_he_rx_mcs_set[WMI_HOST_MAX_HE_RATE_SET];3604u32 peer_he_tx_mcs_set[WMI_HOST_MAX_HE_RATE_SET];3605bool twt_responder;3606bool twt_requester;3607struct ath12k_wmi_ppe_threshold_arg peer_ppet;3608bool eht_flag;3609u32 peer_eht_cap_mac[WMI_MAX_EHTCAP_MAC_SIZE];3610u32 peer_eht_cap_phy[WMI_MAX_EHTCAP_PHY_SIZE];3611u32 peer_eht_mcs_count;3612u32 peer_eht_rx_mcs_set[WMI_MAX_EHTCAP_RATE_SET];3613u32 peer_eht_tx_mcs_set[WMI_MAX_EHTCAP_RATE_SET];3614struct ath12k_wmi_ppe_threshold_arg peer_eht_ppet;3615u32 punct_bitmap;3616};36173618struct wmi_peer_assoc_complete_cmd {3619__le32 tlv_header;3620struct ath12k_wmi_mac_addr_params peer_macaddr;3621__le32 vdev_id;3622__le32 peer_new_assoc;3623__le32 peer_associd;3624__le32 peer_flags;3625__le32 peer_caps;3626__le32 peer_listen_intval;3627__le32 peer_ht_caps;3628__le32 peer_max_mpdu;3629__le32 peer_mpdu_density;3630__le32 peer_rate_caps;3631__le32 peer_nss;3632__le32 peer_vht_caps;3633__le32 peer_phymode;3634__le32 peer_ht_info[2];3635__le32 num_peer_legacy_rates;3636__le32 num_peer_ht_rates;3637__le32 peer_bw_rxnss_override;3638struct ath12k_wmi_ppe_threshold_params peer_ppet;3639__le32 peer_he_cap_info;3640__le32 peer_he_ops;3641__le32 peer_he_cap_phy[WMI_MAX_HECAP_PHY_SIZE];3642__le32 peer_he_mcs;3643__le32 peer_he_cap_info_ext;3644__le32 peer_he_cap_info_internal;3645__le32 min_data_rate;3646__le32 peer_he_caps_6ghz;3647__le32 sta_type;3648__le32 bss_max_idle_option;3649__le32 auth_mode;3650__le32 peer_flags_ext;3651__le32 punct_bitmap;3652__le32 peer_eht_cap_mac[WMI_MAX_EHTCAP_MAC_SIZE];3653__le32 peer_eht_cap_phy[WMI_MAX_EHTCAP_PHY_SIZE];3654__le32 peer_eht_ops;3655struct ath12k_wmi_ppe_threshold_params peer_eht_ppet;3656} __packed;36573658struct wmi_stop_scan_cmd {3659__le32 tlv_header;3660__le32 requestor;3661__le32 scan_id;3662__le32 req_type;3663__le32 vdev_id;3664__le32 pdev_id;3665} __packed;36663667struct ath12k_wmi_scan_chan_list_arg {3668u32 pdev_id;3669u16 nallchans;3670struct ath12k_wmi_channel_arg channel[];3671};36723673struct wmi_scan_chan_list_cmd {3674__le32 tlv_header;3675__le32 num_scan_chans;3676__le32 flags;3677__le32 pdev_id;3678} __packed;36793680#define WMI_MGMT_SEND_DOWNLD_LEN 6436813682#define WMI_TX_PARAMS_DWORD0_POWER GENMASK(7, 0)3683#define WMI_TX_PARAMS_DWORD0_MCS_MASK GENMASK(19, 8)3684#define WMI_TX_PARAMS_DWORD0_NSS_MASK GENMASK(27, 20)3685#define WMI_TX_PARAMS_DWORD0_RETRY_LIMIT GENMASK(31, 28)36863687#define WMI_TX_PARAMS_DWORD1_CHAIN_MASK GENMASK(7, 0)3688#define WMI_TX_PARAMS_DWORD1_BW_MASK GENMASK(14, 8)3689#define WMI_TX_PARAMS_DWORD1_PREAMBLE_TYPE GENMASK(19, 15)3690#define WMI_TX_PARAMS_DWORD1_FRAME_TYPE BIT(20)3691#define WMI_TX_PARAMS_DWORD1_RSVD GENMASK(31, 21)36923693struct wmi_mgmt_send_cmd {3694__le32 tlv_header;3695__le32 vdev_id;3696__le32 desc_id;3697__le32 chanfreq;3698__le32 paddr_lo;3699__le32 paddr_hi;3700__le32 frame_len;3701__le32 buf_len;3702__le32 tx_params_valid;37033704/* This TLV is followed by struct wmi_mgmt_frame */37053706/* Followed by struct wmi_mgmt_send_params */3707} __packed;37083709struct wmi_sta_powersave_mode_cmd {3710__le32 tlv_header;3711__le32 vdev_id;3712__le32 sta_ps_mode;3713} __packed;37143715struct wmi_sta_smps_force_mode_cmd {3716__le32 tlv_header;3717__le32 vdev_id;3718__le32 forced_mode;3719} __packed;37203721struct wmi_sta_smps_param_cmd {3722__le32 tlv_header;3723__le32 vdev_id;3724__le32 param;3725__le32 value;3726} __packed;37273728struct ath12k_wmi_bcn_prb_info_params {3729__le32 tlv_header;3730__le32 caps;3731__le32 erp;3732} __packed;37333734enum {3735WMI_PDEV_SUSPEND,3736WMI_PDEV_SUSPEND_AND_DISABLE_INTR,3737};37383739struct wmi_pdev_green_ap_ps_enable_cmd_param {3740__le32 tlv_header;3741__le32 pdev_id;3742__le32 enable;3743} __packed;37443745struct ath12k_wmi_ap_ps_arg {3746u32 vdev_id;3747u32 param;3748u32 value;3749};37503751enum set_init_cc_type {3752WMI_COUNTRY_INFO_TYPE_ALPHA,3753WMI_COUNTRY_INFO_TYPE_COUNTRY_CODE,3754WMI_COUNTRY_INFO_TYPE_REGDOMAIN,3755};37563757enum set_init_cc_flags {3758INVALID_CC,3759CC_IS_SET,3760REGDMN_IS_SET,3761ALPHA_IS_SET,3762};37633764struct ath12k_wmi_init_country_arg {3765union {3766u16 country_code;3767u16 regdom_id;3768u8 alpha2[3];3769} cc_info;3770enum set_init_cc_flags flags;3771};37723773struct wmi_init_country_cmd {3774__le32 tlv_header;3775__le32 pdev_id;3776__le32 init_cc_type;3777union {3778__le32 country_code;3779__le32 regdom_id;3780__le32 alpha2;3781} cc_info;3782} __packed;37833784struct wmi_delba_send_cmd {3785__le32 tlv_header;3786__le32 vdev_id;3787struct ath12k_wmi_mac_addr_params peer_macaddr;3788__le32 tid;3789__le32 initiator;3790__le32 reasoncode;3791} __packed;37923793struct wmi_addba_setresponse_cmd {3794__le32 tlv_header;3795__le32 vdev_id;3796struct ath12k_wmi_mac_addr_params peer_macaddr;3797__le32 tid;3798__le32 statuscode;3799} __packed;38003801struct wmi_addba_send_cmd {3802__le32 tlv_header;3803__le32 vdev_id;3804struct ath12k_wmi_mac_addr_params peer_macaddr;3805__le32 tid;3806__le32 buffersize;3807} __packed;38083809struct wmi_addba_clear_resp_cmd {3810__le32 tlv_header;3811__le32 vdev_id;3812struct ath12k_wmi_mac_addr_params peer_macaddr;3813} __packed;38143815#define DFS_PHYERR_UNIT_TEST_CMD 03816#define DFS_UNIT_TEST_MODULE 0x2b3817#define DFS_UNIT_TEST_TOKEN 0xAA38183819enum dfs_test_args_idx {3820DFS_TEST_CMDID = 0,3821DFS_TEST_PDEV_ID,3822DFS_TEST_RADAR_PARAM,3823DFS_MAX_TEST_ARGS,3824};38253826struct wmi_dfs_unit_test_arg {3827u32 cmd_id;3828u32 pdev_id;3829u32 radar_param;3830};38313832struct wmi_unit_test_cmd {3833__le32 tlv_header;3834__le32 vdev_id;3835__le32 module_id;3836__le32 num_args;3837__le32 diag_token;3838/* Followed by test args*/3839} __packed;38403841#define MAX_SUPPORTED_RATES 12838423843#define WMI_PEER_AUTH 0x000000013844#define WMI_PEER_QOS 0x000000023845#define WMI_PEER_NEED_PTK_4_WAY 0x000000043846#define WMI_PEER_NEED_GTK_2_WAY 0x000000103847#define WMI_PEER_HE 0x000004003848#define WMI_PEER_APSD 0x000008003849#define WMI_PEER_HT 0x000010003850#define WMI_PEER_40MHZ 0x000020003851#define WMI_PEER_STBC 0x000080003852#define WMI_PEER_LDPC 0x000100003853#define WMI_PEER_DYN_MIMOPS 0x000200003854#define WMI_PEER_STATIC_MIMOPS 0x000400003855#define WMI_PEER_SPATIAL_MUX 0x002000003856#define WMI_PEER_TWT_REQ 0x004000003857#define WMI_PEER_TWT_RESP 0x008000003858#define WMI_PEER_VHT 0x020000003859#define WMI_PEER_80MHZ 0x040000003860#define WMI_PEER_PMF 0x080000003861/* TODO: Place holder for WLAN_PEER_F_PS_PRESEND_REQUIRED = 0x10000000.3862* Need to be cleaned up3863*/3864#define WMI_PEER_IS_P2P_CAPABLE 0x200000003865#define WMI_PEER_160MHZ 0x400000003866#define WMI_PEER_SAFEMODE_EN 0x8000000038673868struct ath12k_wmi_vht_rate_set_params {3869__le32 tlv_header;3870__le32 rx_max_rate;3871__le32 rx_mcs_set;3872__le32 tx_max_rate;3873__le32 tx_mcs_set;3874__le32 tx_max_mcs_nss;3875} __packed;38763877struct ath12k_wmi_he_rate_set_params {3878__le32 tlv_header;3879__le32 rx_mcs_set;3880__le32 tx_mcs_set;3881} __packed;38823883struct ath12k_wmi_eht_rate_set_params {3884__le32 tlv_header;3885__le32 rx_mcs_set;3886__le32 tx_mcs_set;3887} __packed;38883889#define MAX_REG_RULES 103890#define REG_ALPHA2_LEN 23891#define MAX_6G_REG_RULES 53892#define REG_US_5G_NUM_REG_RULES 438933894enum wmi_start_event_param {3895WMI_VDEV_START_RESP_EVENT = 0,3896WMI_VDEV_RESTART_RESP_EVENT,3897};38983899struct wmi_vdev_start_resp_event {3900__le32 vdev_id;3901__le32 requestor_id;3902/* enum wmi_start_event_param */3903__le32 resp_type;3904__le32 status;3905__le32 chain_mask;3906__le32 smps_mode;3907union {3908__le32 mac_id;3909__le32 pdev_id;3910};3911__le32 cfgd_tx_streams;3912__le32 cfgd_rx_streams;3913} __packed;39143915/* VDEV start response status codes */3916enum wmi_vdev_start_resp_status_code {3917WMI_VDEV_START_RESPONSE_STATUS_SUCCESS = 0,3918WMI_VDEV_START_RESPONSE_INVALID_VDEVID = 1,3919WMI_VDEV_START_RESPONSE_NOT_SUPPORTED = 2,3920WMI_VDEV_START_RESPONSE_DFS_VIOLATION = 3,3921WMI_VDEV_START_RESPONSE_INVALID_REGDOMAIN = 4,3922};39233924enum wmi_reg_6g_ap_type {3925WMI_REG_INDOOR_AP = 0,3926WMI_REG_STD_POWER_AP = 1,3927WMI_REG_VLP_AP = 2,3928WMI_REG_CURRENT_MAX_AP_TYPE,3929WMI_REG_MAX_SUPP_AP_TYPE = WMI_REG_VLP_AP,3930WMI_REG_MAX_AP_TYPE = 7,3931};39323933enum wmi_reg_6g_client_type {3934WMI_REG_DEFAULT_CLIENT = 0,3935WMI_REG_SUBORDINATE_CLIENT = 1,3936WMI_REG_MAX_CLIENT_TYPE = 2,3937};39383939/* Regulatory Rule Flags Passed by FW */3940#define REGULATORY_CHAN_DISABLED BIT(0)3941#define REGULATORY_CHAN_NO_IR BIT(1)3942#define REGULATORY_CHAN_RADAR BIT(3)3943#define REGULATORY_CHAN_NO_OFDM BIT(6)3944#define REGULATORY_CHAN_INDOOR_ONLY BIT(9)39453946#define REGULATORY_CHAN_NO_HT40 BIT(4)3947#define REGULATORY_CHAN_NO_80MHZ BIT(7)3948#define REGULATORY_CHAN_NO_160MHZ BIT(8)3949#define REGULATORY_CHAN_NO_20MHZ BIT(11)3950#define REGULATORY_CHAN_NO_10MHZ BIT(12)39513952enum {3953WMI_REG_SET_CC_STATUS_PASS = 0,3954WMI_REG_CURRENT_ALPHA2_NOT_FOUND = 1,3955WMI_REG_INIT_ALPHA2_NOT_FOUND = 2,3956WMI_REG_SET_CC_CHANGE_NOT_ALLOWED = 3,3957WMI_REG_SET_CC_STATUS_NO_MEMORY = 4,3958WMI_REG_SET_CC_STATUS_FAIL = 5,3959};39603961#define WMI_REG_CLIENT_MAX 439623963struct wmi_reg_chan_list_cc_ext_event {3964__le32 status_code;3965__le32 phy_id;3966__le32 alpha2;3967__le32 num_phy;3968__le32 country_id;3969__le32 domain_code;3970__le32 dfs_region;3971__le32 phybitmap;3972__le32 min_bw_2g;3973__le32 max_bw_2g;3974__le32 min_bw_5g;3975__le32 max_bw_5g;3976__le32 num_2g_reg_rules;3977__le32 num_5g_reg_rules;3978__le32 client_type;3979__le32 rnr_tpe_usable;3980__le32 unspecified_ap_usable;3981__le32 domain_code_6g_ap_lpi;3982__le32 domain_code_6g_ap_sp;3983__le32 domain_code_6g_ap_vlp;3984__le32 domain_code_6g_client_lpi[WMI_REG_CLIENT_MAX];3985__le32 domain_code_6g_client_sp[WMI_REG_CLIENT_MAX];3986__le32 domain_code_6g_client_vlp[WMI_REG_CLIENT_MAX];3987__le32 domain_code_6g_super_id;3988__le32 min_bw_6g_ap_sp;3989__le32 max_bw_6g_ap_sp;3990__le32 min_bw_6g_ap_lpi;3991__le32 max_bw_6g_ap_lpi;3992__le32 min_bw_6g_ap_vlp;3993__le32 max_bw_6g_ap_vlp;3994__le32 min_bw_6g_client_sp[WMI_REG_CLIENT_MAX];3995__le32 max_bw_6g_client_sp[WMI_REG_CLIENT_MAX];3996__le32 min_bw_6g_client_lpi[WMI_REG_CLIENT_MAX];3997__le32 max_bw_6g_client_lpi[WMI_REG_CLIENT_MAX];3998__le32 min_bw_6g_client_vlp[WMI_REG_CLIENT_MAX];3999__le32 max_bw_6g_client_vlp[WMI_REG_CLIENT_MAX];4000__le32 num_6g_reg_rules_ap_sp;4001__le32 num_6g_reg_rules_ap_lpi;4002__le32 num_6g_reg_rules_ap_vlp;4003__le32 num_6g_reg_rules_cl_sp[WMI_REG_CLIENT_MAX];4004__le32 num_6g_reg_rules_cl_lpi[WMI_REG_CLIENT_MAX];4005__le32 num_6g_reg_rules_cl_vlp[WMI_REG_CLIENT_MAX];4006} __packed;40074008struct ath12k_wmi_reg_rule_ext_params {4009__le32 tlv_header;4010__le32 freq_info;4011__le32 bw_pwr_info;4012__le32 flag_info;4013__le32 psd_power_info;4014} __packed;40154016struct wmi_vdev_delete_resp_event {4017__le32 vdev_id;4018} __packed;40194020struct wmi_peer_delete_resp_event {4021__le32 vdev_id;4022struct ath12k_wmi_mac_addr_params peer_macaddr;4023} __packed;40244025struct wmi_bcn_tx_status_event {4026__le32 vdev_id;4027__le32 tx_status;4028} __packed;40294030struct wmi_vdev_stopped_event {4031__le32 vdev_id;4032} __packed;40334034struct wmi_pdev_bss_chan_info_event {4035__le32 pdev_id;4036__le32 freq; /* Units in MHz */4037__le32 noise_floor; /* units are dBm */4038/* rx clear - how often the channel was unused */4039__le32 rx_clear_count_low;4040__le32 rx_clear_count_high;4041/* cycle count - elapsed time during measured period, in clock ticks */4042__le32 cycle_count_low;4043__le32 cycle_count_high;4044/* tx cycle count - elapsed time spent in tx, in clock ticks */4045__le32 tx_cycle_count_low;4046__le32 tx_cycle_count_high;4047/* rx cycle count - elapsed time spent in rx, in clock ticks */4048__le32 rx_cycle_count_low;4049__le32 rx_cycle_count_high;4050/*rx_cycle cnt for my bss in 64bits format */4051__le32 rx_bss_cycle_count_low;4052__le32 rx_bss_cycle_count_high;4053} __packed;40544055#define WMI_VDEV_INSTALL_KEY_COMPL_STATUS_SUCCESS 040564057struct wmi_vdev_install_key_compl_event {4058__le32 vdev_id;4059struct ath12k_wmi_mac_addr_params peer_macaddr;4060__le32 key_idx;4061__le32 key_flags;4062__le32 status;4063} __packed;40644065struct wmi_vdev_install_key_complete_arg {4066u32 vdev_id;4067const u8 *macaddr;4068u32 key_idx;4069u32 key_flags;4070u32 status;4071};40724073struct wmi_peer_assoc_conf_event {4074__le32 vdev_id;4075struct ath12k_wmi_mac_addr_params peer_macaddr;4076} __packed;40774078struct wmi_peer_assoc_conf_arg {4079u32 vdev_id;4080const u8 *macaddr;4081};40824083struct wmi_fils_discovery_event {4084__le32 vdev_id;4085__le32 fils_tt;4086__le32 tbtt;4087} __packed;40884089struct wmi_probe_resp_tx_status_event {4090__le32 vdev_id;4091__le32 tx_status;4092} __packed;40934094struct wmi_pdev_ctl_failsafe_chk_event {4095__le32 pdev_id;4096__le32 ctl_failsafe_status;4097} __packed;40984099struct ath12k_wmi_pdev_csa_event {4100__le32 pdev_id;4101__le32 current_switch_count;4102__le32 num_vdevs;4103} __packed;41044105struct ath12k_wmi_pdev_radar_event {4106__le32 pdev_id;4107__le32 detection_mode;4108__le32 chan_freq;4109__le32 chan_width;4110__le32 detector_id;4111__le32 segment_id;4112__le32 timestamp;4113__le32 is_chirp;4114a_sle32 freq_offset;4115a_sle32 sidx;4116} __packed;41174118struct wmi_pdev_temperature_event {4119/* temperature value in Celsius degree */4120a_sle32 temp;4121__le32 pdev_id;4122} __packed;41234124#define WMI_RX_STATUS_OK 0x004125#define WMI_RX_STATUS_ERR_CRC 0x014126#define WMI_RX_STATUS_ERR_DECRYPT 0x084127#define WMI_RX_STATUS_ERR_MIC 0x104128#define WMI_RX_STATUS_ERR_KEY_CACHE_MISS 0x2041294130#define WLAN_MGMT_TXRX_HOST_MAX_ANTENNA 441314132struct ath12k_wmi_mgmt_rx_arg {4133u32 chan_freq;4134u32 channel;4135u32 snr;4136u8 rssi_ctl[WLAN_MGMT_TXRX_HOST_MAX_ANTENNA];4137u32 rate;4138enum wmi_phy_mode phy_mode;4139u32 buf_len;4140int status;4141u32 flags;4142int rssi;4143u32 tsf_delta;4144u8 pdev_id;4145};41464147#define ATH_MAX_ANTENNA 441484149struct ath12k_wmi_mgmt_rx_params {4150__le32 channel;4151__le32 snr;4152__le32 rate;4153__le32 phy_mode;4154__le32 buf_len;4155__le32 status;4156__le32 rssi_ctl[ATH_MAX_ANTENNA];4157__le32 flags;4158a_sle32 rssi;4159__le32 tsf_delta;4160__le32 rx_tsf_l32;4161__le32 rx_tsf_u32;4162__le32 pdev_id;4163__le32 chan_freq;4164} __packed;41654166#define MAX_ANTENNA_EIGHT 841674168struct wmi_mgmt_tx_compl_event {4169__le32 desc_id;4170__le32 status;4171__le32 pdev_id;4172} __packed;41734174struct wmi_scan_event {4175__le32 event_type; /* %WMI_SCAN_EVENT_ */4176__le32 reason; /* %WMI_SCAN_REASON_ */4177__le32 channel_freq; /* only valid for WMI_SCAN_EVENT_FOREIGN_CHANNEL */4178__le32 scan_req_id;4179__le32 scan_id;4180__le32 vdev_id;4181/* TSF Timestamp when the scan event (%WMI_SCAN_EVENT_) is completed4182* In case of AP it is TSF of the AP vdev4183* In case of STA connected state, this is the TSF of the AP4184* In case of STA not connected, it will be the free running HW timer4185*/4186__le32 tsf_timestamp;4187} __packed;41884189struct wmi_peer_sta_kickout_arg {4190const u8 *mac_addr;4191};41924193struct wmi_peer_sta_kickout_event {4194struct ath12k_wmi_mac_addr_params peer_macaddr;4195} __packed;41964197enum wmi_roam_reason {4198WMI_ROAM_REASON_BETTER_AP = 1,4199WMI_ROAM_REASON_BEACON_MISS = 2,4200WMI_ROAM_REASON_LOW_RSSI = 3,4201WMI_ROAM_REASON_SUITABLE_AP_FOUND = 4,4202WMI_ROAM_REASON_HO_FAILED = 5,42034204/* keep last */4205WMI_ROAM_REASON_MAX,4206};42074208struct wmi_roam_event {4209__le32 vdev_id;4210__le32 reason;4211__le32 rssi;4212} __packed;42134214#define WMI_CHAN_INFO_START_RESP 04215#define WMI_CHAN_INFO_END_RESP 142164217struct wmi_chan_info_event {4218__le32 err_code;4219__le32 freq;4220__le32 cmd_flags;4221__le32 noise_floor;4222__le32 rx_clear_count;4223__le32 cycle_count;4224__le32 chan_tx_pwr_range;4225__le32 chan_tx_pwr_tp;4226__le32 rx_frame_count;4227__le32 my_bss_rx_cycle_count;4228__le32 rx_11b_mode_data_duration;4229__le32 tx_frame_cnt;4230__le32 mac_clk_mhz;4231__le32 vdev_id;4232} __packed;42334234struct ath12k_wmi_target_cap_arg {4235u32 phy_capability;4236u32 max_frag_entry;4237u32 num_rf_chains;4238u32 ht_cap_info;4239u32 vht_cap_info;4240u32 vht_supp_mcs;4241u32 hw_min_tx_power;4242u32 hw_max_tx_power;4243u32 sys_cap_info;4244u32 min_pkt_size_enable;4245u32 max_bcn_ie_size;4246u32 max_num_scan_channels;4247u32 max_supported_macs;4248u32 wmi_fw_sub_feat_caps;4249u32 txrx_chainmask;4250u32 default_dbs_hw_mode_index;4251u32 num_msdu_desc;4252};42534254enum wmi_vdev_type {4255WMI_VDEV_TYPE_AP = 1,4256WMI_VDEV_TYPE_STA = 2,4257WMI_VDEV_TYPE_IBSS = 3,4258WMI_VDEV_TYPE_MONITOR = 4,4259};42604261enum wmi_vdev_subtype {4262WMI_VDEV_SUBTYPE_NONE,4263WMI_VDEV_SUBTYPE_P2P_DEVICE,4264WMI_VDEV_SUBTYPE_P2P_CLIENT,4265WMI_VDEV_SUBTYPE_P2P_GO,4266WMI_VDEV_SUBTYPE_PROXY_STA,4267WMI_VDEV_SUBTYPE_MESH_NON_11S,4268WMI_VDEV_SUBTYPE_MESH_11S,4269};42704271enum wmi_sta_powersave_param {4272WMI_STA_PS_PARAM_RX_WAKE_POLICY = 0,4273WMI_STA_PS_PARAM_TX_WAKE_THRESHOLD = 1,4274WMI_STA_PS_PARAM_PSPOLL_COUNT = 2,4275WMI_STA_PS_PARAM_INACTIVITY_TIME = 3,4276WMI_STA_PS_PARAM_UAPSD = 4,4277};42784279enum wmi_sta_ps_param_uapsd {4280WMI_STA_PS_UAPSD_AC0_DELIVERY_EN = (1 << 0),4281WMI_STA_PS_UAPSD_AC0_TRIGGER_EN = (1 << 1),4282WMI_STA_PS_UAPSD_AC1_DELIVERY_EN = (1 << 2),4283WMI_STA_PS_UAPSD_AC1_TRIGGER_EN = (1 << 3),4284WMI_STA_PS_UAPSD_AC2_DELIVERY_EN = (1 << 4),4285WMI_STA_PS_UAPSD_AC2_TRIGGER_EN = (1 << 5),4286WMI_STA_PS_UAPSD_AC3_DELIVERY_EN = (1 << 6),4287WMI_STA_PS_UAPSD_AC3_TRIGGER_EN = (1 << 7),4288};42894290enum wmi_sta_ps_param_tx_wake_threshold {4291WMI_STA_PS_TX_WAKE_THRESHOLD_NEVER = 0,4292WMI_STA_PS_TX_WAKE_THRESHOLD_ALWAYS = 1,42934294/* Values greater than one indicate that many TX attempts per beacon4295* interval before the STA will wake up4296*/4297};42984299/* The maximum number of PS-Poll frames the FW will send in response to4300* traffic advertised in TIM before waking up (by sending a null frame with PS4301* = 0). Value 0 has a special meaning: there is no maximum count and the FW4302* will send as many PS-Poll as are necessary to retrieve buffered BU. This4303* parameter is used when the RX wake policy is4304* WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD and ignored when the RX wake4305* policy is WMI_STA_PS_RX_WAKE_POLICY_WAKE.4306*/4307enum wmi_sta_ps_param_pspoll_count {4308WMI_STA_PS_PSPOLL_COUNT_NO_MAX = 0,4309/* Values greater than 0 indicate the maximum number of PS-Poll frames4310* FW will send before waking up.4311*/4312};43134314/* U-APSD configuration of peer station from (re)assoc request and TSPECs */4315enum wmi_ap_ps_param_uapsd {4316WMI_AP_PS_UAPSD_AC0_DELIVERY_EN = (1 << 0),4317WMI_AP_PS_UAPSD_AC0_TRIGGER_EN = (1 << 1),4318WMI_AP_PS_UAPSD_AC1_DELIVERY_EN = (1 << 2),4319WMI_AP_PS_UAPSD_AC1_TRIGGER_EN = (1 << 3),4320WMI_AP_PS_UAPSD_AC2_DELIVERY_EN = (1 << 4),4321WMI_AP_PS_UAPSD_AC2_TRIGGER_EN = (1 << 5),4322WMI_AP_PS_UAPSD_AC3_DELIVERY_EN = (1 << 6),4323WMI_AP_PS_UAPSD_AC3_TRIGGER_EN = (1 << 7),4324};43254326/* U-APSD maximum service period of peer station */4327enum wmi_ap_ps_peer_param_max_sp {4328WMI_AP_PS_PEER_PARAM_MAX_SP_UNLIMITED = 0,4329WMI_AP_PS_PEER_PARAM_MAX_SP_2 = 1,4330WMI_AP_PS_PEER_PARAM_MAX_SP_4 = 2,4331WMI_AP_PS_PEER_PARAM_MAX_SP_6 = 3,4332MAX_WMI_AP_PS_PEER_PARAM_MAX_SP,4333};43344335enum wmi_ap_ps_peer_param {4336/** Set uapsd configuration for a given peer.4337*4338* This include the delivery and trigger enabled state for each AC.4339* The host MLME needs to set this based on AP capability and stations4340* request Set in the association request received from the station.4341*4342* Lower 8 bits of the value specify the UAPSD configuration.4343*4344* (see enum wmi_ap_ps_param_uapsd)4345* The default value is 0.4346*/4347WMI_AP_PS_PEER_PARAM_UAPSD = 0,43484349/**4350* Set the service period for a UAPSD capable station4351*4352* The service period from wme ie in the (re)assoc request frame.4353*4354* (see enum wmi_ap_ps_peer_param_max_sp)4355*/4356WMI_AP_PS_PEER_PARAM_MAX_SP = 1,43574358/** Time in seconds for aging out buffered frames4359* for STA in power save4360*/4361WMI_AP_PS_PEER_PARAM_AGEOUT_TIME = 2,43624363/** Specify frame types that are considered SIFS4364* RESP trigger frame4365*/4366WMI_AP_PS_PEER_PARAM_SIFS_RESP_FRMTYPE = 3,43674368/** Specifies the trigger state of TID.4369* Valid only for UAPSD frame type4370*/4371WMI_AP_PS_PEER_PARAM_SIFS_RESP_UAPSD = 4,43724373/* Specifies the WNM sleep state of a STA */4374WMI_AP_PS_PEER_PARAM_WNM_SLEEP = 5,4375};43764377#define DISABLE_SIFS_RESPONSE_TRIGGER 043784379#define WMI_MAX_KEY_INDEX 34380#define WMI_MAX_KEY_LEN 3243814382enum wmi_key_type {4383WMI_KEY_PAIRWISE = 0,4384WMI_KEY_GROUP = 1,4385};43864387enum wmi_cipher_type {4388WMI_CIPHER_NONE = 0, /* clear key */4389WMI_CIPHER_WEP = 1,4390WMI_CIPHER_TKIP = 2,4391WMI_CIPHER_AES_OCB = 3,4392WMI_CIPHER_AES_CCM = 4,4393WMI_CIPHER_WAPI = 5,4394WMI_CIPHER_CKIP = 6,4395WMI_CIPHER_AES_CMAC = 7,4396WMI_CIPHER_ANY = 8,4397WMI_CIPHER_AES_GCM = 9,4398WMI_CIPHER_AES_GMAC = 10,4399};44004401/* Value to disable fixed rate setting */4402#define WMI_FIXED_RATE_NONE (0xffff)44034404#define ATH12K_RC_VERSION_OFFSET 284405#define ATH12K_RC_PREAMBLE_OFFSET 84406#define ATH12K_RC_NSS_OFFSET 544074408#define ATH12K_HW_RATE_CODE(rate, nss, preamble) \4409((1 << ATH12K_RC_VERSION_OFFSET) | \4410((nss) << ATH12K_RC_NSS_OFFSET) | \4411((preamble) << ATH12K_RC_PREAMBLE_OFFSET) | \4412(rate))44134414/* Preamble types to be used with VDEV fixed rate configuration */4415enum wmi_rate_preamble {4416WMI_RATE_PREAMBLE_OFDM,4417WMI_RATE_PREAMBLE_CCK,4418WMI_RATE_PREAMBLE_HT,4419WMI_RATE_PREAMBLE_VHT,4420WMI_RATE_PREAMBLE_HE,4421};44224423/**4424* enum wmi_rtscts_prot_mode - Enable/Disable RTS/CTS and CTS2Self Protection.4425* @WMI_RTS_CTS_DISABLED: RTS/CTS protection is disabled.4426* @WMI_USE_RTS_CTS: RTS/CTS Enabled.4427* @WMI_USE_CTS2SELF: CTS to self protection Enabled.4428*/4429enum wmi_rtscts_prot_mode {4430WMI_RTS_CTS_DISABLED = 0,4431WMI_USE_RTS_CTS = 1,4432WMI_USE_CTS2SELF = 2,4433};44344435/**4436* enum wmi_rtscts_profile - Selection of RTS CTS profile along with enabling4437* protection mode.4438* @WMI_RTSCTS_FOR_NO_RATESERIES: Neither of rate-series should use RTS-CTS4439* @WMI_RTSCTS_FOR_SECOND_RATESERIES: Only second rate-series will use RTS-CTS4440* @WMI_RTSCTS_ACROSS_SW_RETRIES: Only the second rate-series will use RTS-CTS,4441* but if there's a sw retry, both the rate4442* series will use RTS-CTS.4443* @WMI_RTSCTS_ERP: RTS/CTS used for ERP protection for every PPDU.4444* @WMI_RTSCTS_FOR_ALL_RATESERIES: Enable RTS-CTS for all rate series.4445*/4446enum wmi_rtscts_profile {4447WMI_RTSCTS_FOR_NO_RATESERIES = 0,4448WMI_RTSCTS_FOR_SECOND_RATESERIES = 1,4449WMI_RTSCTS_ACROSS_SW_RETRIES = 2,4450WMI_RTSCTS_ERP = 3,4451WMI_RTSCTS_FOR_ALL_RATESERIES = 4,4452};44534454#define WMI_SKB_HEADROOM sizeof(struct wmi_cmd_hdr)44554456enum wmi_sta_ps_param_rx_wake_policy {4457WMI_STA_PS_RX_WAKE_POLICY_WAKE = 0,4458WMI_STA_PS_RX_WAKE_POLICY_POLL_UAPSD = 1,4459};44604461/* Do not change existing values! Used by ath12k_frame_mode parameter4462* module parameter.4463*/4464enum ath12k_hw_txrx_mode {4465ATH12K_HW_TXRX_RAW = 0,4466ATH12K_HW_TXRX_NATIVE_WIFI = 1,4467ATH12K_HW_TXRX_ETHERNET = 2,4468};44694470struct wmi_wmm_params {4471__le32 tlv_header;4472__le32 cwmin;4473__le32 cwmax;4474__le32 aifs;4475__le32 txoplimit;4476__le32 acm;4477__le32 no_ack;4478} __packed;44794480struct wmi_wmm_params_arg {4481u8 acm;4482u8 aifs;4483u16 cwmin;4484u16 cwmax;4485u16 txop;4486u8 no_ack;4487};44884489struct wmi_vdev_set_wmm_params_cmd {4490__le32 tlv_header;4491__le32 vdev_id;4492struct wmi_wmm_params wmm_params[4];4493__le32 wmm_param_type;4494} __packed;44954496struct wmi_wmm_params_all_arg {4497struct wmi_wmm_params_arg ac_be;4498struct wmi_wmm_params_arg ac_bk;4499struct wmi_wmm_params_arg ac_vi;4500struct wmi_wmm_params_arg ac_vo;4501};45024503#define ATH12K_TWT_DEF_STA_CONG_TIMER_MS 50004504#define ATH12K_TWT_DEF_DEFAULT_SLOT_SIZE 104505#define ATH12K_TWT_DEF_CONGESTION_THRESH_SETUP 504506#define ATH12K_TWT_DEF_CONGESTION_THRESH_TEARDOWN 204507#define ATH12K_TWT_DEF_CONGESTION_THRESH_CRITICAL 1004508#define ATH12K_TWT_DEF_INTERFERENCE_THRESH_TEARDOWN 804509#define ATH12K_TWT_DEF_INTERFERENCE_THRESH_SETUP 504510#define ATH12K_TWT_DEF_MIN_NO_STA_SETUP 104511#define ATH12K_TWT_DEF_MIN_NO_STA_TEARDOWN 24512#define ATH12K_TWT_DEF_NO_OF_BCAST_MCAST_SLOTS 24513#define ATH12K_TWT_DEF_MIN_NO_TWT_SLOTS 24514#define ATH12K_TWT_DEF_MAX_NO_STA_TWT 5004515#define ATH12K_TWT_DEF_MODE_CHECK_INTERVAL 100004516#define ATH12K_TWT_DEF_ADD_STA_SLOT_INTERVAL 10004517#define ATH12K_TWT_DEF_REMOVE_STA_SLOT_INTERVAL 500045184519struct wmi_twt_enable_params_cmd {4520__le32 tlv_header;4521__le32 pdev_id;4522__le32 sta_cong_timer_ms;4523__le32 mbss_support;4524__le32 default_slot_size;4525__le32 congestion_thresh_setup;4526__le32 congestion_thresh_teardown;4527__le32 congestion_thresh_critical;4528__le32 interference_thresh_teardown;4529__le32 interference_thresh_setup;4530__le32 min_no_sta_setup;4531__le32 min_no_sta_teardown;4532__le32 no_of_bcast_mcast_slots;4533__le32 min_no_twt_slots;4534__le32 max_no_sta_twt;4535__le32 mode_check_interval;4536__le32 add_sta_slot_interval;4537__le32 remove_sta_slot_interval;4538} __packed;45394540struct wmi_twt_disable_params_cmd {4541__le32 tlv_header;4542__le32 pdev_id;4543} __packed;45444545struct wmi_obss_spatial_reuse_params_cmd {4546__le32 tlv_header;4547__le32 pdev_id;4548__le32 enable;4549a_sle32 obss_min;4550a_sle32 obss_max;4551__le32 vdev_id;4552} __packed;45534554#define ATH12K_BSS_COLOR_COLLISION_SCAN_PERIOD_MS 2004555#define ATH12K_OBSS_COLOR_COLLISION_DETECTION_DISABLE 04556#define ATH12K_OBSS_COLOR_COLLISION_DETECTION 145574558#define ATH12K_BSS_COLOR_STA_PERIODS 100004559#define ATH12K_BSS_COLOR_AP_PERIODS 500045604561struct wmi_obss_color_collision_cfg_params_cmd {4562__le32 tlv_header;4563__le32 vdev_id;4564__le32 flags;4565__le32 evt_type;4566__le32 current_bss_color;4567__le32 detection_period_ms;4568__le32 scan_period_ms;4569__le32 free_slot_expiry_time_ms;4570} __packed;45714572struct wmi_bss_color_change_enable_params_cmd {4573__le32 tlv_header;4574__le32 vdev_id;4575__le32 enable;4576} __packed;45774578#define ATH12K_IPV4_TH_SEED_SIZE 54579#define ATH12K_IPV6_TH_SEED_SIZE 1145804581struct ath12k_wmi_pdev_lro_config_cmd {4582__le32 tlv_header;4583__le32 lro_enable;4584__le32 res;4585u32 th_4[ATH12K_IPV4_TH_SEED_SIZE];4586u32 th_6[ATH12K_IPV6_TH_SEED_SIZE];4587__le32 pdev_id;4588} __packed;45894590#define ATH12K_WMI_SPECTRAL_COUNT_DEFAULT 04591#define ATH12K_WMI_SPECTRAL_PERIOD_DEFAULT 2244592#define ATH12K_WMI_SPECTRAL_PRIORITY_DEFAULT 14593#define ATH12K_WMI_SPECTRAL_FFT_SIZE_DEFAULT 74594#define ATH12K_WMI_SPECTRAL_GC_ENA_DEFAULT 14595#define ATH12K_WMI_SPECTRAL_RESTART_ENA_DEFAULT 04596#define ATH12K_WMI_SPECTRAL_NOISE_FLOOR_REF_DEFAULT -964597#define ATH12K_WMI_SPECTRAL_INIT_DELAY_DEFAULT 804598#define ATH12K_WMI_SPECTRAL_NB_TONE_THR_DEFAULT 124599#define ATH12K_WMI_SPECTRAL_STR_BIN_THR_DEFAULT 84600#define ATH12K_WMI_SPECTRAL_WB_RPT_MODE_DEFAULT 04601#define ATH12K_WMI_SPECTRAL_RSSI_RPT_MODE_DEFAULT 04602#define ATH12K_WMI_SPECTRAL_RSSI_THR_DEFAULT 0xf04603#define ATH12K_WMI_SPECTRAL_PWR_FORMAT_DEFAULT 04604#define ATH12K_WMI_SPECTRAL_RPT_MODE_DEFAULT 24605#define ATH12K_WMI_SPECTRAL_BIN_SCALE_DEFAULT 14606#define ATH12K_WMI_SPECTRAL_DBM_ADJ_DEFAULT 14607#define ATH12K_WMI_SPECTRAL_CHN_MASK_DEFAULT 146084609struct ath12k_wmi_vdev_spectral_conf_arg {4610u32 vdev_id;4611u32 scan_count;4612u32 scan_period;4613u32 scan_priority;4614u32 scan_fft_size;4615u32 scan_gc_ena;4616u32 scan_restart_ena;4617u32 scan_noise_floor_ref;4618u32 scan_init_delay;4619u32 scan_nb_tone_thr;4620u32 scan_str_bin_thr;4621u32 scan_wb_rpt_mode;4622u32 scan_rssi_rpt_mode;4623u32 scan_rssi_thr;4624u32 scan_pwr_format;4625u32 scan_rpt_mode;4626u32 scan_bin_scale;4627u32 scan_dbm_adj;4628u32 scan_chn_mask;4629};46304631struct ath12k_wmi_vdev_spectral_conf_cmd {4632__le32 tlv_header;4633__le32 vdev_id;4634__le32 scan_count;4635__le32 scan_period;4636__le32 scan_priority;4637__le32 scan_fft_size;4638__le32 scan_gc_ena;4639__le32 scan_restart_ena;4640__le32 scan_noise_floor_ref;4641__le32 scan_init_delay;4642__le32 scan_nb_tone_thr;4643__le32 scan_str_bin_thr;4644__le32 scan_wb_rpt_mode;4645__le32 scan_rssi_rpt_mode;4646__le32 scan_rssi_thr;4647__le32 scan_pwr_format;4648__le32 scan_rpt_mode;4649__le32 scan_bin_scale;4650__le32 scan_dbm_adj;4651__le32 scan_chn_mask;4652} __packed;46534654#define ATH12K_WMI_SPECTRAL_TRIGGER_CMD_TRIGGER 14655#define ATH12K_WMI_SPECTRAL_TRIGGER_CMD_CLEAR 24656#define ATH12K_WMI_SPECTRAL_ENABLE_CMD_ENABLE 14657#define ATH12K_WMI_SPECTRAL_ENABLE_CMD_DISABLE 246584659struct ath12k_wmi_vdev_spectral_enable_cmd {4660__le32 tlv_header;4661__le32 vdev_id;4662__le32 trigger_cmd;4663__le32 enable_cmd;4664} __packed;46654666struct ath12k_wmi_pdev_dma_ring_cfg_arg {4667u32 tlv_header;4668u32 pdev_id;4669u32 module_id;4670u32 base_paddr_lo;4671u32 base_paddr_hi;4672u32 head_idx_paddr_lo;4673u32 head_idx_paddr_hi;4674u32 tail_idx_paddr_lo;4675u32 tail_idx_paddr_hi;4676u32 num_elems;4677u32 buf_size;4678u32 num_resp_per_event;4679u32 event_timeout_ms;4680};46814682struct ath12k_wmi_pdev_dma_ring_cfg_req_cmd {4683__le32 tlv_header;4684__le32 pdev_id;4685__le32 module_id; /* see enum wmi_direct_buffer_module */4686__le32 base_paddr_lo;4687__le32 base_paddr_hi;4688__le32 head_idx_paddr_lo;4689__le32 head_idx_paddr_hi;4690__le32 tail_idx_paddr_lo;4691__le32 tail_idx_paddr_hi;4692__le32 num_elems; /* Number of elems in the ring */4693__le32 buf_size; /* size of allocated buffer in bytes */46944695/* Number of wmi_dma_buf_release_entry packed together */4696__le32 num_resp_per_event;46974698/* Target should timeout and send whatever resp4699* it has if this time expires, units in milliseconds4700*/4701__le32 event_timeout_ms;4702} __packed;47034704struct ath12k_wmi_dma_buf_release_fixed_params {4705__le32 pdev_id;4706__le32 module_id;4707__le32 num_buf_release_entry;4708__le32 num_meta_data_entry;4709} __packed;47104711struct ath12k_wmi_dma_buf_release_entry_params {4712__le32 tlv_header;4713__le32 paddr_lo;47144715/* Bits 11:0: address of data4716* Bits 31:12: host context data4717*/4718__le32 paddr_hi;4719} __packed;47204721#define WMI_SPECTRAL_META_INFO1_FREQ1 GENMASK(15, 0)4722#define WMI_SPECTRAL_META_INFO1_FREQ2 GENMASK(31, 16)47234724#define WMI_SPECTRAL_META_INFO2_CHN_WIDTH GENMASK(7, 0)47254726struct ath12k_wmi_dma_buf_release_meta_data_params {4727__le32 tlv_header;4728a_sle32 noise_floor[WMI_MAX_CHAINS];4729__le32 reset_delay;4730__le32 freq1;4731__le32 freq2;4732__le32 ch_width;4733} __packed;47344735enum wmi_fils_discovery_cmd_type {4736WMI_FILS_DISCOVERY_CMD,4737WMI_UNSOL_BCAST_PROBE_RESP,4738};47394740struct wmi_fils_discovery_cmd {4741__le32 tlv_header;4742__le32 vdev_id;4743__le32 interval;4744__le32 config; /* enum wmi_fils_discovery_cmd_type */4745} __packed;47464747struct wmi_fils_discovery_tmpl_cmd {4748__le32 tlv_header;4749__le32 vdev_id;4750__le32 buf_len;4751} __packed;47524753struct wmi_probe_tmpl_cmd {4754__le32 tlv_header;4755__le32 vdev_id;4756__le32 buf_len;4757} __packed;47584759#define WMI_MAX_MEM_REQS 3247604761#define MAX_RADIOS 347624763#define WMI_SERVICE_READY_TIMEOUT_HZ (5 * HZ)4764#define WMI_SEND_TIMEOUT_HZ (3 * HZ)47654766struct ath12k_wmi_pdev {4767struct ath12k_wmi_base *wmi_ab;4768enum ath12k_htc_ep_id eid;4769const struct wmi_peer_flags_map *peer_flags;4770u32 rx_decap_mode;4771};47724773struct ath12k_wmi_base {4774struct ath12k_base *ab;4775struct ath12k_wmi_pdev wmi[MAX_RADIOS];4776enum ath12k_htc_ep_id wmi_endpoint_id[MAX_RADIOS];4777u32 max_msg_len[MAX_RADIOS];47784779struct completion service_ready;4780struct completion unified_ready;4781DECLARE_BITMAP(svc_map, WMI_MAX_EXT2_SERVICE);4782wait_queue_head_t tx_credits_wq;4783const struct wmi_peer_flags_map *peer_flags;4784u32 num_mem_chunks;4785u32 rx_decap_mode;4786struct ath12k_wmi_host_mem_chunk_arg mem_chunks[WMI_MAX_MEM_REQS];47874788enum wmi_host_hw_mode_config_type preferred_hw_mode;47894790struct ath12k_wmi_target_cap_arg *targ_cap;4791};47924793#define ATH12K_FW_STATS_BUF_SIZE (1024 * 1024)47944795void ath12k_wmi_init_qcn9274(struct ath12k_base *ab,4796struct ath12k_wmi_resource_config_arg *config);4797void ath12k_wmi_init_wcn7850(struct ath12k_base *ab,4798struct ath12k_wmi_resource_config_arg *config);4799int ath12k_wmi_cmd_send(struct ath12k_wmi_pdev *wmi, struct sk_buff *skb,4800u32 cmd_id);4801struct sk_buff *ath12k_wmi_alloc_skb(struct ath12k_wmi_base *wmi_sc, u32 len);4802int ath12k_wmi_mgmt_send(struct ath12k *ar, u32 vdev_id, u32 buf_id,4803struct sk_buff *frame);4804int ath12k_wmi_bcn_tmpl(struct ath12k *ar, u32 vdev_id,4805struct ieee80211_mutable_offsets *offs,4806struct sk_buff *bcn);4807int ath12k_wmi_vdev_down(struct ath12k *ar, u8 vdev_id);4808int ath12k_wmi_vdev_up(struct ath12k *ar, u32 vdev_id, u32 aid,4809const u8 *bssid);4810int ath12k_wmi_vdev_stop(struct ath12k *ar, u8 vdev_id);4811int ath12k_wmi_vdev_start(struct ath12k *ar, struct wmi_vdev_start_req_arg *arg,4812bool restart);4813int ath12k_wmi_set_peer_param(struct ath12k *ar, const u8 *peer_addr,4814u32 vdev_id, u32 param_id, u32 param_val);4815int ath12k_wmi_pdev_set_param(struct ath12k *ar, u32 param_id,4816u32 param_value, u8 pdev_id);4817int ath12k_wmi_pdev_set_ps_mode(struct ath12k *ar, int vdev_id, u32 enable);4818int ath12k_wmi_wait_for_unified_ready(struct ath12k_base *ab);4819int ath12k_wmi_cmd_init(struct ath12k_base *ab);4820int ath12k_wmi_wait_for_service_ready(struct ath12k_base *ab);4821int ath12k_wmi_connect(struct ath12k_base *ab);4822int ath12k_wmi_pdev_attach(struct ath12k_base *ab,4823u8 pdev_id);4824int ath12k_wmi_attach(struct ath12k_base *ab);4825void ath12k_wmi_detach(struct ath12k_base *ab);4826int ath12k_wmi_vdev_create(struct ath12k *ar, u8 *macaddr,4827struct ath12k_wmi_vdev_create_arg *arg);4828int ath12k_wmi_send_peer_create_cmd(struct ath12k *ar,4829struct ath12k_wmi_peer_create_arg *arg);4830int ath12k_wmi_vdev_set_param_cmd(struct ath12k *ar, u32 vdev_id,4831u32 param_id, u32 param_value);48324833int ath12k_wmi_set_sta_ps_param(struct ath12k *ar, u32 vdev_id,4834u32 param, u32 param_value);4835int ath12k_wmi_force_fw_hang_cmd(struct ath12k *ar, u32 type, u32 delay_time_ms);4836int ath12k_wmi_send_peer_delete_cmd(struct ath12k *ar,4837const u8 *peer_addr, u8 vdev_id);4838int ath12k_wmi_vdev_delete(struct ath12k *ar, u8 vdev_id);4839void ath12k_wmi_start_scan_init(struct ath12k *ar,4840struct ath12k_wmi_scan_req_arg *arg);4841int ath12k_wmi_send_scan_start_cmd(struct ath12k *ar,4842struct ath12k_wmi_scan_req_arg *arg);4843int ath12k_wmi_send_scan_stop_cmd(struct ath12k *ar,4844struct ath12k_wmi_scan_cancel_arg *arg);4845int ath12k_wmi_send_wmm_update_cmd(struct ath12k *ar, u32 vdev_id,4846struct wmi_wmm_params_all_arg *param);4847int ath12k_wmi_pdev_suspend(struct ath12k *ar, u32 suspend_opt,4848u32 pdev_id);4849int ath12k_wmi_pdev_resume(struct ath12k *ar, u32 pdev_id);48504851int ath12k_wmi_send_peer_assoc_cmd(struct ath12k *ar,4852struct ath12k_wmi_peer_assoc_arg *arg);4853int ath12k_wmi_vdev_install_key(struct ath12k *ar,4854struct wmi_vdev_install_key_arg *arg);4855int ath12k_wmi_pdev_bss_chan_info_request(struct ath12k *ar,4856enum wmi_bss_chan_info_req_type type);4857int ath12k_wmi_send_stats_request_cmd(struct ath12k *ar, u32 stats_id,4858u32 vdev_id, u32 pdev_id);4859int ath12k_wmi_send_pdev_temperature_cmd(struct ath12k *ar);4860int ath12k_wmi_send_peer_flush_tids_cmd(struct ath12k *ar,4861u8 peer_addr[ETH_ALEN],4862u32 peer_tid_bitmap,4863u8 vdev_id);4864int ath12k_wmi_send_set_ap_ps_param_cmd(struct ath12k *ar, u8 *peer_addr,4865struct ath12k_wmi_ap_ps_arg *arg);4866int ath12k_wmi_send_scan_chan_list_cmd(struct ath12k *ar,4867struct ath12k_wmi_scan_chan_list_arg *arg);4868int ath12k_wmi_send_dfs_phyerr_offload_enable_cmd(struct ath12k *ar,4869u32 pdev_id);4870int ath12k_wmi_addba_clear_resp(struct ath12k *ar, u32 vdev_id, const u8 *mac);4871int ath12k_wmi_addba_send(struct ath12k *ar, u32 vdev_id, const u8 *mac,4872u32 tid, u32 buf_size);4873int ath12k_wmi_addba_set_resp(struct ath12k *ar, u32 vdev_id, const u8 *mac,4874u32 tid, u32 status);4875int ath12k_wmi_delba_send(struct ath12k *ar, u32 vdev_id, const u8 *mac,4876u32 tid, u32 initiator, u32 reason);4877int ath12k_wmi_send_bcn_offload_control_cmd(struct ath12k *ar,4878u32 vdev_id, u32 bcn_ctrl_op);4879int ath12k_wmi_send_init_country_cmd(struct ath12k *ar,4880struct ath12k_wmi_init_country_arg *arg);4881int ath12k_wmi_peer_rx_reorder_queue_setup(struct ath12k *ar,4882int vdev_id, const u8 *addr,4883dma_addr_t paddr, u8 tid,4884u8 ba_window_size_valid,4885u32 ba_window_size);4886int4887ath12k_wmi_rx_reord_queue_remove(struct ath12k *ar,4888struct ath12k_wmi_rx_reorder_queue_remove_arg *arg);4889int ath12k_wmi_send_pdev_set_regdomain(struct ath12k *ar,4890struct ath12k_wmi_pdev_set_regdomain_arg *arg);4891int ath12k_wmi_simulate_radar(struct ath12k *ar);4892int ath12k_wmi_send_twt_enable_cmd(struct ath12k *ar, u32 pdev_id);4893int ath12k_wmi_send_twt_disable_cmd(struct ath12k *ar, u32 pdev_id);4894int ath12k_wmi_send_obss_spr_cmd(struct ath12k *ar, u32 vdev_id,4895struct ieee80211_he_obss_pd *he_obss_pd);4896int ath12k_wmi_obss_color_cfg_cmd(struct ath12k *ar, u32 vdev_id,4897u8 bss_color, u32 period,4898bool enable);4899int ath12k_wmi_send_bss_color_change_enable_cmd(struct ath12k *ar, u32 vdev_id,4900bool enable);4901int ath12k_wmi_pdev_lro_cfg(struct ath12k *ar, int pdev_id);4902int ath12k_wmi_pdev_dma_ring_cfg(struct ath12k *ar,4903struct ath12k_wmi_pdev_dma_ring_cfg_arg *arg);4904int ath12k_wmi_vdev_spectral_enable(struct ath12k *ar, u32 vdev_id,4905u32 trigger, u32 enable);4906int ath12k_wmi_vdev_spectral_conf(struct ath12k *ar,4907struct ath12k_wmi_vdev_spectral_conf_arg *arg);4908int ath12k_wmi_fils_discovery_tmpl(struct ath12k *ar, u32 vdev_id,4909struct sk_buff *tmpl);4910int ath12k_wmi_fils_discovery(struct ath12k *ar, u32 vdev_id, u32 interval,4911bool unsol_bcast_probe_resp_enabled);4912int ath12k_wmi_probe_resp_tmpl(struct ath12k *ar, u32 vdev_id,4913struct sk_buff *tmpl);4914int ath12k_wmi_set_hw_mode(struct ath12k_base *ab,4915enum wmi_host_hw_mode_config_type mode);49164917#endif491849194920