]> git.ipfire.org Git - thirdparty/hostap.git/blobdiff - src/common/qca-vendor.h
Document the attributes used by QCA_NL80211_VENDOR_SUBCMD_ROAM
[thirdparty/hostap.git] / src / common / qca-vendor.h
index e428e4b2621b9c98f2ab622cae915172f9a537b6..baff71c7ba8f0a3ffe3abb3c19da264007ccfa33 100644 (file)
@@ -1,7 +1,7 @@
 /*
  * Qualcomm Atheros OUI and vendor specific assignments
  * Copyright (c) 2014-2017, Qualcomm Atheros, Inc.
- * Copyright (c) 2018, The Linux Foundation
+ * Copyright (c) 2018-2019, The Linux Foundation
  *
  * This software may be distributed under the terms of the BSD license.
  * See README for more details.
@@ -42,15 +42,22 @@ enum qca_radiotap_vendor_ids {
  *
  * @QCA_NL80211_VENDOR_SUBCMD_AVOID_FREQUENCY: Recommendation of frequency
  *     ranges to avoid to reduce issues due to interference or internal
- *     co-existence information in the driver. The event data structure is
- *     defined in struct qca_avoid_freq_list.
+ *     co-existence information in the driver. These frequencies aim to
+ *     minimize the traffic but not to totally avoid the traffic. That said
+ *     for a P2P use case, these frequencies are allowed for the P2P
+ *     discovery/negotiation but avoid the group to get formed on these
+ *     frequencies. The event data structure is defined in
+ *     struct qca_avoid_freq_list.
  *
  * @QCA_NL80211_VENDOR_SUBCMD_DFS_CAPABILITY: Command to check driver support
  *     for DFS offloading.
  *
  * @QCA_NL80211_VENDOR_SUBCMD_NAN: NAN command/event which is used to pass
  *     NAN Request/Response and NAN Indication messages. These messages are
- *     interpreted between the framework and the firmware component.
+ *     interpreted between the framework and the firmware component. While
+ *     sending the command from userspace to the driver, payload is not
+ *     encapsulated inside any attribute. Attribute QCA_WLAN_VENDOR_ATTR_NAN
+ *     is used when receiving vendor events in userspace from the driver.
  *
  * @QCA_NL80211_VENDOR_SUBCMD_KEY_MGMT_SET_KEY: Set key operation that can be
  *     used to configure PMK to the driver even when not connected. This can
@@ -91,6 +98,9 @@ enum qca_radiotap_vendor_ids {
  *     which supports DFS offloading, to indicate a radar pattern has been
  *     detected. The channel is now unusable.
  *
+ * @QCA_NL80211_VENDOR_SUBCMD_GET_WIFI_INFO: Get information from the driver.
+ *     Attributes defined in enum qca_wlan_vendor_attr_get_wifi_info.
+ *
  * @QCA_NL80211_VENDOR_SUBCMD_GET_LOGGER_FEATURE_SET: Get the feature bitmap
  *     based on enum wifi_logger_supported_features. Attributes defined in
  *     enum qca_wlan_vendor_attr_get_logger_features.
@@ -155,6 +165,11 @@ enum qca_radiotap_vendor_ids {
  *     timer value. Uses the attributes defines in
  *     enum qca_wlan_vendor_attr_ocb_get_tsf_resp.
  *
+ * @QCA_NL80211_VENDOR_SUBCMD_LINK_PROPERTIES: Command/event to update the
+ *     link properties of the respective interface. As an event, is used
+ *     to notify the connected station's status. The attributes for this
+ *     command are defined in enum qca_wlan_vendor_attr_link_properties.
+ *
  * @QCA_NL80211_VENDOR_SUBCMD_P2P_LISTEN_OFFLOAD_START: Command used to
  *     start the P2P Listen offload function in device and pass the listen
  *     channel, period, interval, count, device types, and vendor specific
@@ -361,7 +376,9 @@ enum qca_radiotap_vendor_ids {
  * @QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_START: Start spectral scan. The scan
  *     parameters are specified by enum qca_wlan_vendor_attr_spectral_scan.
  *     This returns a cookie (%QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_COOKIE)
- *     identifying the operation in success case.
+ *     identifying the operation in success case. In failure cases an
+ *     error code (%QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_ERROR_CODE)
+ *     describing the reason for the failure is returned.
  *
  * @QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_STOP: Stop spectral scan. This uses
  *     a cookie (%QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_COOKIE) from
@@ -453,6 +470,124 @@ enum qca_radiotap_vendor_ids {
  *     and STA MAC addresses added by the user. This command is also used to
  *     fetch the statistics of unassociated stations. The attributes used with
  *     this command are defined in enum qca_wlan_vendor_attr_bss_filter.
+ *
+ * @QCA_NL80211_VENDOR_SUBCMD_NAN_EXT: An extendable version of NAN vendor
+ *     command. The earlier command for NAN, QCA_NL80211_VENDOR_SUBCMD_NAN,
+ *     carried a payload which was a binary blob of data. The command was not
+ *     extendable to send more information. The newer version carries the
+ *     legacy blob encapsulated within an attribute and can be extended with
+ *     additional vendor attributes that can enhance the NAN command interface.
+ * @QCA_NL80211_VENDOR_SUBCMD_ROAM_SCAN_EVENT: Event to indicate scan triggered
+ *     or stopped within driver/firmware in order to initiate roaming. The
+ *     attributes used with this event are defined in enum
+ *     qca_wlan_vendor_attr_roam_scan. Some drivers may not send these events
+ *     in few cases, e.g., if the host processor is sleeping when this event
+ *     is generated in firmware.
+ *
+ * @QCA_NL80211_VENDOR_SUBCMD_PEER_CFR_CAPTURE_CFG: This command is used to
+ *     configure parameters per peer to capture Channel Frequency Response
+ *     (CFR) and enable Periodic CFR capture. The attributes for this command
+ *     are defined in enum qca_wlan_vendor_peer_cfr_capture_attr.
+ *
+ * @QCA_NL80211_VENDOR_SUBCMD_THROUGHPUT_CHANGE_EVENT: Event to indicate changes
+ *     in throughput dynamically. The driver estimates the throughput based on
+ *     number of packets being transmitted/received per second and indicates
+ *     the changes in throughput to user space. Userspace tools can use this
+ *     information to configure kernel's TCP parameters in order to achieve
+ *     peak throughput. Optionally, the driver will also send guidance on
+ *     modifications to kernel's TCP parameters which can be referred by
+ *     userspace tools. The attributes used with this event are defined in enum
+ *     qca_wlan_vendor_attr_throughput_change.
+ *
+ * @QCA_NL80211_VENDOR_SUBCMD_COEX_CONFIG: This command is used to set
+ *     priorities among different types of traffic during coex scenarios.
+ *     Current supported prioritization is among WLAN/BT/ZIGBEE with different
+ *     profiles mentioned in enum qca_coex_config_profiles. The associated
+ *     attributes used with this command are defined in enum
+ *     qca_vendor_attr_coex_config.
+ *
+ *     Based on the config provided, FW will boost the weight and prioritize
+ *     the traffic for that subsystem (WLAN/BT/Zigbee).
+ *
+ * @QCA_NL80211_VENDOR_SUBCMD_GET_SUPPORTED_AKMS: This command is used to query
+ *     the supported AKM suite selectorss from the driver. It returns the list
+ *     of supported AKMs in the attribute NL80211_ATTR_AKM_SUITES.
+ * @QCA_NL80211_VENDOR_SUBCMD_GET_FW_STATE: This command is used to get firmware
+ *     state from the driver. It returns the firmware state in the attribute
+ *     QCA_WLAN_VENDOR_ATTR_FW_STATE.
+ * @QCA_NL80211_VENDOR_SUBCMD_PEER_STATS_CACHE_FLUSH: This vendor subcommand
+ *     is used by the driver to flush per-peer cached statistics to user space
+ *     application. This interface is used as an event from the driver to
+ *     user space application. Attributes for this event are specified in
+ *     enum qca_wlan_vendor_attr_peer_stats_cache_params.
+ *     QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_DATA attribute is expected to be
+ *     sent in the event.
+ * @QCA_NL80211_VENDOR_SUBCMD_MPTA_HELPER_CONFIG: This sub command is used to
+ *     improve the success rate of Zigbee joining network.
+ *     Due to PTA master limitation, Zigbee joining network success rate is
+ *     low while WLAN is working. The WLAN driver needs to configure some
+ *     parameters including Zigbee state and specific WLAN periods to enhance
+ *     PTA master. All these parameters are delivered by the attributes
+ *     defined in enum qca_mpta_helper_vendor_attr.
+ * @QCA_NL80211_VENDOR_SUBCMD_BEACON_REPORTING: This sub command is used to
+ *     implement Beacon frame reporting feature.
+ *
+ *     Userspace can request the driver/firmware to periodically report
+ *     received Beacon frames whose BSSID is same as the current connected
+ *     BSS's MAC address.
+ *
+ *     In case the STA seamlessly (without sending disconnect indication to
+ *     userspace) roams to a different BSS, Beacon frame reporting will be
+ *     automatically enabled for the Beacon frames whose BSSID is same as the
+ *     MAC address of the new BSS. Beacon reporting will be stopped when the
+ *     STA is disconnected (when the disconnect indication is sent to
+ *     userspace) and need to be explicitly enabled by userspace for next
+ *     connection.
+ *
+ *     When a Beacon frame matching configured conditions is received, and if
+ *     userspace has requested to send asynchronous beacon reports, the
+ *     driver/firmware will encapsulate the details of the Beacon frame in an
+ *     event and send it to userspace along with updating the BSS information
+ *     in cfg80211 scan cache, otherwise driver will only update the cfg80211
+ *     scan cache with the information from the received Beacon frame but will
+ *     not send any active report to userspace.
+ *
+ *     The userspace can request the driver/firmware to stop reporting Beacon
+ *     frames. If the driver/firmware is not able to receive Beacon frames due
+ *     to other Wi-Fi operations such as off-channel activities, etc., the
+ *     driver/firmware will send a pause event to userspace and stop reporting
+ *     Beacon frames. Whether the beacon reporting will be automatically
+ *     resumed or not by the driver/firmware later will be reported to
+ *     userspace using the QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_AUTO_RESUMES
+ *     flag. The beacon reporting shall be resumed for all the cases except
+ *     either when userspace sets
+ *     QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_DO_NOT_RESUME flag in the command
+ *     which triggered the current beacon reporting or during any disconnection
+ *     case as indicated by setting
+ *     QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_PAUSE_REASON to
+ *     QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_DISCONNECTED by the
+ *     driver.
+ *
+ *     After QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_PAUSE event is received
+ *     by userspace with QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_AUTO_RESUMES
+ *     flag not set, the next first
+ *     QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO event from the driver
+ *     shall be considered as un-pause event.
+ *
+ *     All the attributes used with this command are defined in
+ *     enum qca_wlan_vendor_attr_beacon_reporting_params.
+ * @QCA_NL80211_VENDOR_SUBCMD_INTEROP_ISSUES_AP: In practice, some APs have
+ *     interop issues with the DUT. This sub command is used to transfer the
+ *     AP info between the driver and user space. This works both as a command
+ *     and an event. As a command, it configures the stored list of APs from
+ *     user space to firmware; as an event, it indicates the AP info detected
+ *     by the firmware to user space for persistent storage. The attributes
+ *     defined in enum qca_vendor_attr_interop_issues_ap are used to deliver
+ *     the parameters.
+ * @QCA_NL80211_VENDOR_SUBCMD_OEM_DATA: This command is used to send OEM data
+ *     binary blobs from application/service to firmware. The attributes
+ *     defined in enum qca_wlan_vendor_attr_oem_data_params are used to deliver
+ *     the parameters.
  */
 enum qca_nl80211_vendor_subcmds {
        QCA_NL80211_VENDOR_SUBCMD_UNSPEC = 0,
@@ -612,13 +747,28 @@ enum qca_nl80211_vendor_subcmds {
        QCA_NL80211_VENDOR_SUBCMD_WIFI_TEST_CONFIGURATION = 169,
        /* Frame filter operations for other BSSs/unassociated STAs */
        QCA_NL80211_VENDOR_SUBCMD_BSS_FILTER = 170,
+       QCA_NL80211_VENDOR_SUBCMD_NAN_EXT = 171,
+       QCA_NL80211_VENDOR_SUBCMD_ROAM_SCAN_EVENT = 172,
+       QCA_NL80211_VENDOR_SUBCMD_PEER_CFR_CAPTURE_CFG = 173,
+       QCA_NL80211_VENDOR_SUBCMD_THROUGHPUT_CHANGE_EVENT = 174,
+       QCA_NL80211_VENDOR_SUBCMD_COEX_CONFIG = 175,
+       QCA_NL80211_VENDOR_SUBCMD_GET_SUPPORTED_AKMS = 176,
+       QCA_NL80211_VENDOR_SUBCMD_GET_FW_STATE = 177,
+       QCA_NL80211_VENDOR_SUBCMD_PEER_STATS_CACHE_FLUSH = 178,
+       QCA_NL80211_VENDOR_SUBCMD_MPTA_HELPER_CONFIG = 179,
+       QCA_NL80211_VENDOR_SUBCMD_BEACON_REPORTING = 180,
+       QCA_NL80211_VENDOR_SUBCMD_INTEROP_ISSUES_AP = 181,
+       QCA_NL80211_VENDOR_SUBCMD_OEM_DATA = 182,
 };
 
 enum qca_wlan_vendor_attr {
        QCA_WLAN_VENDOR_ATTR_INVALID = 0,
        /* used by QCA_NL80211_VENDOR_SUBCMD_DFS_CAPABILITY */
        QCA_WLAN_VENDOR_ATTR_DFS     = 1,
-       /* used by QCA_NL80211_VENDOR_SUBCMD_NAN */
+       /* Used only when driver sends vendor events to the userspace under the
+        * command QCA_NL80211_VENDOR_SUBCMD_NAN. Not used when userspace sends
+        * commands to the driver.
+        */
        QCA_WLAN_VENDOR_ATTR_NAN     = 2,
        /* used by QCA_NL80211_VENDOR_SUBCMD_STATS_EXT */
        QCA_WLAN_VENDOR_ATTR_STATS_EXT     = 3,
@@ -789,6 +939,18 @@ enum qca_wlan_vendor_attr {
         * to report the corresponding antenna index to the chain RSSI value
         */
        QCA_WLAN_VENDOR_ATTR_ANTENNA_INFO = 40,
+       /* Used in QCA_NL80211_VENDOR_SUBCMD_GET_CHAIN_RSSI command to report
+        * the specific antenna EVM value (unsigned 32 bit value). With a
+        * determinate group of antennas, the driver specifies the EVM value
+        * for each antenna ID, and application extract them in user space.
+        */
+       QCA_WLAN_VENDOR_ATTR_CHAIN_EVM = 41,
+       /*
+        * Used in QCA_NL80211_VENDOR_SUBCMD_GET_FW_STATE command to report
+        * wlan firmware current state. FW state is an unsigned 8 bit value,
+        * one of the values in enum qca_wlan_vendor_attr_fw_state.
+        */
+       QCA_WLAN_VENDOR_ATTR_FW_STATE = 42,
 
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_AFTER_LAST,
@@ -800,6 +962,49 @@ enum qca_roaming_policy {
        QCA_ROAMING_ALLOWED_WITHIN_ESS,
 };
 
+/**
+ * enum qca_roam_reason - Represents the reason codes for roaming. Used by
+ * QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_REASON.
+ *
+ * @QCA_ROAM_REASON_UNKNOWN: Any reason that do not classify under the below
+ * reasons.
+ *
+ * @QCA_ROAM_REASON_PER: Roam triggered when packet error rates (PER) breached
+ * the configured threshold.
+ *
+ * @QCA_ROAM_REASON_BEACON_MISS: Roam triggered due to the continuous configured
+ * beacon misses from the then connected AP.
+ *
+ * @QCA_ROAM_REASON_POOR_RSSI: Roam triggered due to the poor RSSI reported
+ * by the connected AP.
+ *
+ * @QCA_ROAM_REASON_BETTER_RSSI: Roam triggered for finding a BSS with a better
+ * RSSI than the connected BSS. Here the RSSI of the current BSS is not poor.
+ *
+ * @QCA_ROAM_REASON_CONGESTION: Roam triggered considering the connected channel
+ * or environment being very noisy or congested.
+ *
+ * @QCA_ROAM_REASON_EXPLICIT_REQUEST: Roam triggered due to an explicit request
+ * from the user (user space).
+ *
+ * @QCA_ROAM_REASON_BTM: Roam triggered due to BTM Request frame received from
+ * the connected AP.
+ *
+ * @QCA_ROAM_REASON_BSS_LOAD: Roam triggered due to the channel utilization
+ * breaching out the configured threshold.
+ */
+enum qca_roam_reason {
+       QCA_ROAM_REASON_UNKNOWN,
+       QCA_ROAM_REASON_PER,
+       QCA_ROAM_REASON_BEACON_MISS,
+       QCA_ROAM_REASON_POOR_RSSI,
+       QCA_ROAM_REASON_BETTER_RSSI,
+       QCA_ROAM_REASON_CONGESTION,
+       QCA_ROAM_REASON_USER_TRIGGER,
+       QCA_ROAM_REASON_BTM,
+       QCA_ROAM_REASON_BSS_LOAD,
+};
+
 enum qca_wlan_vendor_attr_roam_auth {
        QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_INVALID = 0,
        QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_BSSID,
@@ -842,6 +1047,11 @@ enum qca_wlan_vendor_attr_roam_auth {
         * doing subsequent ERP based connections in the same realm.
         */
        QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_FILS_ERP_NEXT_SEQ_NUM = 13,
+       /* A 16-bit unsigned value representing the reasons for the roaming.
+        * Defined by enum qca_roam_reason.
+        */
+       QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_REASON = 14,
+
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_ROAM_AUTH_MAX =
@@ -940,6 +1150,7 @@ enum qca_wlan_vendor_acs_hw_mode {
  *     only OCE STA-CFON functionalities.
  * @QCA_WLAN_VENDOR_FEATURE_SELF_MANAGED_REGULATORY: Device supports self
  *     managed regulatory.
+ * @QCA_WLAN_VENDOR_FEATURE_TWT: Device supports TWT (Target Wake Time).
  * @NUM_QCA_WLAN_VENDOR_FEATURES: Number of assigned feature bits
  */
 enum qca_wlan_vendor_features {
@@ -951,6 +1162,7 @@ enum qca_wlan_vendor_features {
        QCA_WLAN_VENDOR_FEATURE_OCE_AP                  = 5,
        QCA_WLAN_VENDOR_FEATURE_OCE_STA_CFON            = 6,
        QCA_WLAN_VENDOR_FEATURE_SELF_MANAGED_REGULATORY = 7,
+       QCA_WLAN_VENDOR_FEATURE_TWT                     = 8,
        NUM_QCA_WLAN_VENDOR_FEATURES /* keep last */
 };
 
@@ -1643,6 +1855,30 @@ enum qca_wlan_vendor_attr_config {
         */
        QCA_WLAN_VENDOR_ATTR_CONFIG_GTX = 57,
 
+       /* Attribute to configure disconnect IEs to the driver.
+        * This carries an array of unsigned 8-bit characters.
+        *
+        * If this is configured, driver shall fill the IEs in disassoc/deauth
+        * frame.
+        * These IEs are expected to be considered only for the next
+        * immediate disconnection (disassoc/deauth frame) originated by
+        * the DUT, irrespective of the entity (user space/driver/firmware)
+        * triggering the disconnection.
+        * The host drivers are not expected to use the IEs set through
+        * this interface for further disconnections after the first immediate
+        * disconnection initiated post the configuration.
+        * If the IEs are also updated through cfg80211 interface (after the
+        * enhancement to cfg80211_disconnect), host driver is expected to
+        * take the union of IEs from both of these interfaces and send in
+        * further disassoc/deauth frames.
+        */
+       QCA_WLAN_VENDOR_ATTR_DISCONNECT_IES = 58,
+
+       /* 8-bit unsigned value for ELNA bypass.
+        * 1-Enable, 0-Disable
+        */
+       QCA_WLAN_VENDOR_ATTR_CONFIG_ELNA_BYPASS = 59,
+
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_CONFIG_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_CONFIG_MAX =
@@ -2383,6 +2619,18 @@ enum qca_wlan_vendor_attr_dmg_rf_sector_type {
        QCA_WLAN_VENDOR_ATTR_DMG_RF_SECTOR_TYPE_MAX
 };
 
+/**
+ * enum qca_wlan_vendor_attr_fw_state - State of firmware
+ *
+ * @QCA_WLAN_VENDOR_ATTR_FW_STATE_ERROR: FW is in bad state
+ * @QCA_WLAN_VENDOR_ATTR_FW_STATE_ACTIVE: FW is active
+ */
+enum qca_wlan_vendor_attr_fw_state {
+       QCA_WLAN_VENDOR_ATTR_FW_STATE_ERROR,
+       QCA_WLAN_VENDOR_ATTR_FW_STATE_ACTIVE,
+       QCA_WLAN_VENDOR_ATTR_FW_STATE_MAX
+};
+
 /**
  * BRP antenna limit mode
  *
@@ -3047,11 +3295,28 @@ enum qca_vendor_attr_sar_limits {
 /**
  * enum qca_wlan_vendor_attr_get_wifi_info: Attributes for data used by
  * QCA_NL80211_VENDOR_SUBCMD_GET_WIFI_INFO sub command.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_WIFI_INFO_DRIVER_VERSION: In a request this attribute
+ *     should be set to any U8 value to indicate that the driver version
+ *     should be returned. When enabled in this manner, in a response this
+ *     attribute will contain a string representation of the driver version.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_WIFI_INFO_FIRMWARE_VERSION: In a request this attribute
+ *     should be set to any U8 value to indicate that the firmware version
+ *     should be returned. When enabled in this manner, in a response this
+ *     attribute will contain a string representation of the firmware version.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_WIFI_INFO_RADIO_INDEX: In a request this attribute
+ *     should be set to any U32 value to indicate that the current radio
+ *     index should be returned. When enabled in this manner, in a response
+ *     this attribute will contain a U32 radio index value.
+ *
  */
 enum qca_wlan_vendor_attr_get_wifi_info {
        QCA_WLAN_VENDOR_ATTR_WIFI_INFO_GET_INVALID = 0,
        QCA_WLAN_VENDOR_ATTR_WIFI_INFO_DRIVER_VERSION = 1,
        QCA_WLAN_VENDOR_ATTR_WIFI_INFO_FIRMWARE_VERSION = 2,
+       QCA_WLAN_VENDOR_ATTR_WIFI_INFO_RADIO_INDEX = 3,
 
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_WIFI_INFO_GET_AFTER_LAST,
@@ -3094,6 +3359,97 @@ enum qca_wlan_vendor_attr_logger_results {
        QCA_WLAN_VENDOR_ATTR_LOGGER_RESULTS_AFTER_LAST - 1,
 };
 
+/*
+ * enum qca_wlan_vendor_attr_roaming_config_params: Attributes for data used by
+ * QCA_NL80211_VENDOR_SUBCMD_ROAM sub command.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_SUBCMD: Unsigned 32-bit value.
+ *     Represents the different roam sub commands referred by
+ *     enum qca_wlan_vendor_attr_roam_subcmd.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_REQ_ID: Unsigned 32-bit value.
+ *     Represents the Request ID for the specific set of commands.
+ *     This also helps to map specific set of commands to the respective
+ *     ID / client. e.g., helps to identify the user entity configuring the
+ *     Blacklist BSSID and accordingly clear the respective ones with the
+ *     matching ID.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID_NUM_NETWORKS: Unsigned
+ *     32-bit value.Represents the number of whitelist SSIDs configured.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID_LIST: Nested attribute
+ *     to carry the list of Whitelist SSIDs.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID: SSID (binary attribute,
+ *     0..32 octets). Represents the white list SSID. Whitelist SSIDs
+ *     represent the list of SSIDs to which the firmware/driver can consider
+ *     to roam to.
+ *
+ * The following PARAM_A_BAND_XX attributes are applied to 5GHz BSSIDs when
+ * comparing with a 2.4GHz BSSID. They are not applied when comparing two
+ * 5GHz BSSIDs.The following attributes are set through the Roaming SUBCMD -
+ * QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_GSCAN_ROAM_PARAMS.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_A_BAND_BOOST_THRESHOLD: Signed 32-bit
+ *     value, RSSI threshold above which 5GHz RSSI is favored.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_A_BAND_PENALTY_THRESHOLD: Signed 32-bit
+ *     value, RSSI threshold below which 5GHz RSSI is penalized.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_A_BAND_BOOST_FACTOR: Unsigned 32-bit
+ *     value, factor by which 5GHz RSSI is boosted.
+ *     boost=(RSSI_measured-5GHz_boost_threshold)*5GHz_boost_factor
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_A_BAND_PENALTY_FACTOR: Unsigned 32-bit
+ *     value, factor by which 5GHz RSSI is penalized.
+ *     penalty=(5GHz_penalty_threshold-RSSI_measured)*5GHz_penalty_factor
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_A_BAND_MAX_BOOST: Unsigned 32-bit
+ *     value, maximum boost that can be applied to a 5GHz RSSI.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_LAZY_ROAM_HISTERESYS: Unsigned 32-bit
+ *     value, boost applied to current BSSID to ensure the currently
+ *     associated BSSID is favored so as to prevent ping-pong situations.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_ALERT_ROAM_RSSI_TRIGGER: Signed 32-bit
+ *     value, RSSI below which "Alert" roam is enabled.
+ *     "Alert" mode roaming - firmware is "urgently" hunting for another BSSID
+ *     because the RSSI is low, or because many successive beacons have been
+ *     lost or other bad link conditions.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_LAZY_ROAM_ENABLE: Unsigned 32-bit
+ *     value. 1-Enable, 0-Disable. Represents "Lazy" mode, where
+ *     firmware is hunting for a better BSSID or white listed SSID even though
+ *     the RSSI of the link is good. The parameters enabling the roaming are
+ *     configured through the PARAM_A_BAND_XX attrbutes.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PREFS: Nested attribute,
+ *     represents the BSSIDs preferred over others while evaluating them
+ *     for the roaming.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_LAZY_ROAM_NUM_BSSID: Unsigned
+ *     32-bit value. Represents the number of preferred BSSIDs set.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_LAZY_ROAM_BSSID: 6-byte MAC
+ *     address representing the BSSID to be preferred.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_LAZY_ROAM_RSSI_MODIFIER: Signed
+ *     32-bit value, representing the modifier to be applied to the RSSI of
+ *     the BSSID for the purpose of comparing it with other roam candidate.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS: Nested attribute,
+ *     represents the BSSIDs to get blacklisted for roaming.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_NUM_BSSID: Unsigned
+ *     32-bit value, represents the number of blacklisted BSSIDs.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_BSSID: 6-byte MAC
+ *     address representing the Blacklisted BSSID.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_HINT: Flag attribute,
+ *     indicates this BSSID blacklist as a hint to the driver. The driver can
+ *     select this BSSID in the worst case (when no other BSSIDs are better).
+ */
 enum qca_wlan_vendor_attr_roaming_config_params {
        QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_INVALID = 0,
 
@@ -3127,6 +3483,8 @@ enum qca_wlan_vendor_attr_roaming_config_params {
        QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS = 18,
        QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_NUM_BSSID = 19,
        QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_BSSID = 20,
+       /* Flag attribute indicates this BSSID blacklist as a hint */
+       QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_HINT = 21,
 
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_AFTER_LAST,
@@ -3135,8 +3493,33 @@ enum qca_wlan_vendor_attr_roaming_config_params {
 };
 
 /*
- * enum qca_wlan_vendor_attr_roam_subcmd: Attributes for data used by
- * QCA_NL80211_VENDOR_SUBCMD_ROAM sub command.
+ * enum qca_wlan_vendor_attr_roam_subcmd: Referred by
+ * QCA_WLAN_VENDOR_ATTR_ROAMING_SUBCMD.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SSID_WHITE_LIST: Sub command to
+ *     configure the white list SSIDs. These are configured through
+ *     the following attributes.
+ *     QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID_NUM_NETWORKS,
+ *     QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID_LIST,
+ *     QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_WHITE_LIST_SSID
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_GSCAN_ROAM_PARAMS: Sub command to
+ *     configure the Roam params. These parameters are evaluated on the GScan
+ *     results. Refers the attributes PARAM_A_BAND_XX above to configure the
+ *     params.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_LAZY_ROAM: Sets the Lazy roam. Uses
+ *     the attribute QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_LAZY_ROAM_ENABLE
+ *     to enable/disable Lazy roam.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_BSSID_PREFS: Sets the BSSID
+ *     preference. Contains the attribute
+ *     QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PREFS to set the BSSID
+ *     preference.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_BLACKLIST_BSSID: Sets the Blacklist
+ *     BSSIDs. Refers QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS to
+ *     set the same.
  */
 enum qca_wlan_vendor_attr_roam_subcmd {
        QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_INVALID = 0,
@@ -3516,6 +3899,14 @@ enum qca_wlan_vendor_attr_gscan_results {
 
        QCA_WLAN_VENDOR_ATTR_GSCAN_RESULTS_BUCKETS_SCANNED = 45,
 
+       /* Unsigned 32-bit value; a GSCAN Capabilities attribute.
+        * This is used to limit the maximum number of BSSIDs while sending
+        * the vendor command QCA_NL80211_VENDOR_SUBCMD_ROAM with attributes
+        * QCA_WLAN_VENDOR_ATTR_ROAM_SUBCMD_SET_BLACKLIST_BSSID and
+        * QCA_WLAN_VENDOR_ATTR_ROAMING_PARAM_SET_BSSID_PARAMS_NUM_BSSID.
+        */
+       QCA_WLAN_VENDOR_ATTR_GSCAN_MAX_NUM_BLACKLISTED_BSSID = 46,
+
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_GSCAN_RESULTS_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_GSCAN_RESULTS_MAX =
@@ -4314,6 +4705,44 @@ enum qca_wlan_vendor_attr_spectral_scan {
         * qca_wlan_vendor_attr_spectral_scan_request_type.
         */
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_REQUEST_TYPE = 23,
+       /* This specifies the frequency span over which spectral
+        * scan would be carried out. Its value depends on the
+        * value of QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_MODE and
+        * the relation is as follows.
+        * QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_NORMAL
+        *    Not applicable. Spectral scan would happen in the
+        *    operating span.
+        * QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_AGILE
+        *    Center frequency (in MHz) of the span of interest or
+        *    for convenience, center frequency (in MHz) of any channel
+        *    in the span of interest. If agile spectral scan is initiated
+        *    without setting a valid frequency it returns the error code
+        *    (QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_NOT_INITIALIZED).
+        * u32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CONFIG_FREQUENCY = 24,
+       /* Spectral scan mode. u32 attribute.
+        * It uses values defined in enum qca_wlan_vendor_spectral_scan_mode.
+        * If this attribute is not present, it is assumed to be
+        * normal mode (QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_NORMAL).
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_MODE = 25,
+       /* Spectral scan error code. u32 attribute.
+        * It uses values defined in enum
+        * qca_wlan_vendor_spectral_scan_error_code.
+        * This attribute is included only in failure scenarios.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_ERROR_CODE = 26,
+       /* 8-bit unsigned value to enable/disable debug of the
+        * Spectral DMA ring.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CONFIG_DMA_RING_DEBUG = 27,
+       /* 8-bit unsigned value to enable/disable debug of the
+        * Spectral DMA buffers.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CONFIG_DMA_BUFFER_DEBUG = 28,
 
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CONFIG_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CONFIG_MAX =
@@ -4371,6 +4800,29 @@ enum qca_wlan_vendor_attr_spectral_cap {
         * qca_wlan_vendor_spectral_scan_cap_hw_gen.
         */
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_HW_GEN = 5,
+       /* Spectral bin scaling formula ID. u16 attribute.
+        * It uses values defined in enum
+        * qca_wlan_vendor_spectral_scan_cap_formula_id.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_FORMULA_ID = 6,
+       /* Spectral bin scaling param - low level offset.
+        * s16 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_LOW_LEVEL_OFFSET = 7,
+       /* Spectral bin scaling param - high level offset.
+        * s16 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_HIGH_LEVEL_OFFSET = 8,
+       /* Spectral bin scaling param - RSSI threshold.
+        * s16 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_RSSI_THR = 9,
+       /* Spectral bin scaling param - default AGC max gain.
+        * u8 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_DEFAULT_AGC_MAX_GAIN = 10,
+       /* Flag attribute to indicate agile spectral scan capability */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_AGILE_SPECTRAL = 11,
 
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_MAX =
@@ -4387,6 +4839,13 @@ enum qca_wlan_vendor_attr_spectral_scan_status {
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_IS_ENABLED = 1,
        /* Flag attribute to indicate whether spectral scan is in progress*/
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_IS_ACTIVE = 2,
+       /* Spectral scan mode. u32 attribute.
+        * It uses values defined in enum qca_wlan_vendor_spectral_scan_mode.
+        * If this attribute is not present, normal mode
+        * (QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_NORMAL is assumed to be
+        * requested.
+        */
+       QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_MODE = 3,
 
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_MAX =
@@ -4411,6 +4870,43 @@ enum qca_wlan_vendor_attr_spectral_scan_request_type {
        QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_REQUEST_TYPE_CONFIG,
 };
 
+/**
+ * qca_wlan_vendor_spectral_scan_mode: Attribute values for
+ * QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_MODE in the vendor subcmd
+ * QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_START and
+ * QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_STATUS_MODE in the vendor subcmd
+ * QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_GET_STATUS. This represents the
+ * spectral scan modes.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_NORMAL: Normal spectral scan:
+ * spectral scan in the current operating span.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_AGILE: Agile spectral scan:
+ * spectral scan in the configured agile span.
+ */
+enum qca_wlan_vendor_spectral_scan_mode {
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_NORMAL = 0,
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_MODE_AGILE = 1,
+};
+
+/**
+ * qca_wlan_vendor_spectral_scan_error_code: Attribute values for
+ * QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_ERROR_CODE in the vendor subcmd
+ * QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_START.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_UNSUPPORTED: Changing the value
+ * of a parameter is not supported.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_MODE_UNSUPPORTED: Requested spectral scan
+ * mode is not supported.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_INVALID_VALUE: A parameter
+ * has invalid value.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_NOT_INITIALIZED: A parameter
+ * is not initialized.
+ */
+enum qca_wlan_vendor_spectral_scan_error_code {
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_UNSUPPORTED = 0,
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_MODE_UNSUPPORTED = 1,
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_INVALID_VALUE = 2,
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_ERR_PARAM_NOT_INITIALIZED = 3,
+};
+
 /**
  * qca_wlan_vendor_spectral_scan_cap_hw_gen: Attribute values for
  * QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_HW_GEN to the vendor subcmd
@@ -4515,6 +5011,20 @@ enum qca_wlan_vendor_attr_flush_pending {
        QCA_WLAN_VENDOR_ATTR_FLUSH_PENDING_AFTER_LAST - 1,
 };
 
+/**
+ * qca_wlan_vendor_spectral_scan_cap_formula_id: Attribute values for
+ * QCA_WLAN_VENDOR_ATTR_SPECTRAL_SCAN_CAP_FORMULA_ID in the vendor subcmd
+ * QCA_NL80211_VENDOR_SUBCMD_SPECTRAL_SCAN_GET_CAP_INFO. This represents the
+ * Spectral bin scaling formula ID.
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_CAP_NO_SCALING: No scaling
+ * @QCA_WLAN_VENDOR_SPECTRAL_SCAN_CAP_AGC_GAIN_RSSI_CORR_BASED: AGC gain
+ * and RSSI threshold based formula.
+ */
+enum qca_wlan_vendor_spectral_scan_cap_formula_id {
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_CAP_NO_SCALING = 0,
+       QCA_WLAN_VENDOR_SPECTRAL_SCAN_CAP_AGC_GAIN_RSSI_CORR_BASED = 1,
+};
+
 /**
  * enum qca_wlan_vendor_attr_rropavail_info - Specifies whether Representative
  * RF Operating Parameter (RROP) information is available, and if so, at which
@@ -4774,6 +5284,10 @@ enum qca_wlan_vendor_attr_offloaded_packets {
        QCA_WLAN_VENDOR_ATTR_OFFLOADED_PACKETS_DST_MAC_ADDR,
        /* Unsigned 32-bit value, in milli seconds */
        QCA_WLAN_VENDOR_ATTR_OFFLOADED_PACKETS_PERIOD,
+       /* This optional unsigned 16-bit attribute is used for specifying
+        * ethernet protocol type. If not specified ethertype defaults to IPv4.
+        */
+       QCA_WLAN_VENDOR_ATTR_OFFLOADED_PACKETS_ETHER_PROTO_TYPE,
 
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_OFFLOADED_PACKETS_AFTER_LAST,
@@ -4916,6 +5430,10 @@ enum qca_wlan_vendor_attr_ndp_params {
         * and ndp confirm.
         */
        QCA_WLAN_VENDOR_ATTR_NDP_TRANSPORT_PROTOCOL = 29,
+       /* Unsigned 8-bit value indicating if NDP remote peer supports NAN NDPE.
+        * 1:support 0:not support
+        */
+       QCA_WLAN_VENDOR_ATTR_PEER_NDPE_SUPPORT = 30,
 
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_NDP_PARAMS_AFTER_LAST,
@@ -5356,6 +5874,89 @@ enum qca_wlan_he_ltf_cfg {
        QCA_WLAN_HE_LTF_4X = 3,
 };
 
+/**
+ * enum qca_wlan_he_mac_padding_dur - HE trigger frame MAC padding duration
+ *
+ * Indicates the HE trigger frame MAC padding duration value.
+ *
+ * @QCA_WLAN_HE_NO_ADDITIONAL_PROCESS_TIME: no additional time required to
+ * process the trigger frame.
+ * @QCA_WLAN_HE_8US_OF_PROCESS_TIME: indicates the 8us of processing time for
+ * trigger frame.
+ * @QCA_WLAN_HE_16US_OF_PROCESS_TIME: indicates the 16us of processing time for
+ * trigger frame.
+ */
+enum qca_wlan_he_mac_padding_dur {
+       QCA_WLAN_HE_NO_ADDITIONAL_PROCESS_TIME = 0,
+       QCA_WLAN_HE_8US_OF_PROCESS_TIME = 1,
+       QCA_WLAN_HE_16US_OF_PROCESS_TIME = 2,
+};
+
+/**
+ * enum qca_wlan_he_om_ctrl_ch_bw - HE OM control field BW configuration
+ *
+ * Indicates the HE Operating mode control channel width setting value.
+ *
+ * @QCA_WLAN_HE_OM_CTRL_BW_20M: Primary 20 MHz
+ * @QCA_WLAN_HE_OM_CTRL_BW_40M: Primary 40 MHz
+ * @QCA_WLAN_HE_OM_CTRL_BW_80M: Primary 80 MHz
+ * @QCA_WLAN_HE_OM_CTRL_BW_160M: 160 MHz and 80+80 MHz
+ */
+enum qca_wlan_he_om_ctrl_ch_bw {
+       QCA_WLAN_HE_OM_CTRL_BW_20M = 0,
+       QCA_WLAN_HE_OM_CTRL_BW_40M = 1,
+       QCA_WLAN_HE_OM_CTRL_BW_80M = 2,
+       QCA_WLAN_HE_OM_CTRL_BW_160M = 3,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_he_omi_tx: Represents attributes for
+ * HE operating mode control transmit request. These attributes are
+ * sent as part of QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OMI_TX and
+ * QCA_NL80211_VENDOR_SUBCMD_WIFI_TEST_CONFIGURATION.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_HE_OMI_RX_NSS: Mandatory 8-bit unsigned value
+ * indicates the maximum number of spatial streams, NSS, that the STA
+ * supports in reception for PPDU bandwidths less than or equal to 80 MHz
+ * and is set to NSS - 1.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_HE_OMI_CH_BW: Mandatory 8-bit unsigned value
+ * indicates the operating channel width supported by the STA for both
+ * reception and transmission. Uses enum qca_wlan_he_om_ctrl_ch_bw values.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_HE_OMI_ULMU_DISABLE: Mandatory 8-bit unsigned value
+ * indicates the all trigger based UL MU operations by the STA.
+ * 0 - UL MU operations are enabled by the STA.
+ * 1 - All triggered UL MU transmissions are suspended by the STA.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_HE_OMI_TX_NSTS: Mandatory 8-bit unsigned value
+ * indicates the maximum number of space-time streams, NSTS, that
+ * the STA supports in transmission and is set to NSTS - 1.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_HE_OMI_ULMU_DATA_DISABLE: 8-bit unsigned value
+ * combined with the UL MU Disable subfield and the recipient's setting
+ * of the OM Control UL MU Data Disable RX Support subfield in the HE MAC
+ * capabilities to determine which HE TB PPDUs are possible by the
+ * STA to transmit.
+ * 0 - UL MU data operations are enabled by the STA.
+ * 1 - Determine which HE TB PPDU types are allowed by the STA if UL MU disable
+ * bit is not set, else UL MU Tx is suspended.
+ *
+ */
+enum qca_wlan_vendor_attr_he_omi_tx {
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_INVALID = 0,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_RX_NSS = 1,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_CH_BW = 2,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_ULMU_DISABLE = 3,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_TX_NSTS = 4,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_ULMU_DATA_DISABLE = 5,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_MAX =
+       QCA_WLAN_VENDOR_ATTR_HE_OMI_AFTER_LAST - 1,
+};
+
 /* Attributes for data used by
  * QCA_NL80211_VENDOR_SUBCMD_WIFI_TEST_CONFIGURATION
  */
@@ -5416,10 +6017,10 @@ enum qca_wlan_vendor_attr_wifi_test_config {
         */
        QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_ADD_DEL_BA_SESSION = 7,
 
-       /* 8-bit unsigned value to configure the buffer size in addba
+       /* 16-bit unsigned value to configure the buffer size in addba
         * request and response frames.
         * This attribute is used to configure the testbed device.
-        * The range of the value is 0 to 255.
+        * The range of the value is 0 to 256.
         */
        QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_ADDBA_BUFF_SIZE = 8,
 
@@ -5462,6 +6063,183 @@ enum qca_wlan_vendor_attr_wifi_test_config {
         */
        QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_TX_BEAMFORMEE_NSTS = 14,
 
+       /* 8-bit unsigned value to configure the MU EDCA params for given AC
+        * This attribute is used to configure the testbed device.
+        * Uses the enum qca_wlan_ac_type values.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MU_EDCA_AC = 15,
+
+       /* 8-bit unsigned value to configure the MU EDCA AIFSN for given AC
+        * To configure MU EDCA AIFSN value, MU EDCA access category value
+        * is required to process the command.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MU_EDCA_AIFSN = 16,
+
+       /* 8-bit unsigned value to configure the MU EDCA ECW min value for
+        * given AC.
+        * To configure MU EDCA ECW min value, MU EDCA access category value
+        * is required to process the command.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MU_EDCA_ECWMIN = 17,
+
+       /* 8-bit unsigned value to configure the MU EDCA ECW max value for
+        * given AC.
+        * To configure MU EDCA ECW max value, MU EDCA access category value
+        * is required to process the command.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MU_EDCA_ECWMAX = 18,
+
+       /* 8-bit unsigned value to configure the MU EDCA timer for given AC
+        * To configure MU EDCA timer value, MU EDCA access category value
+        * is required to process the command.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MU_EDCA_TIMER = 19,
+
+       /* 8-bit unsigned value to configure the HE trigger frame MAC padding
+        * duration.
+        * This attribute is used to configure the testbed device.
+        * Uses the enum qca_wlan_he_mac_padding_dur values.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_MAC_PADDING_DUR = 20,
+
+       /* 8-bit unsigned value to override the MU EDCA params to defaults
+        * regardless of the AP beacon MU EDCA params. If it is enabled use
+        * the default values else use the MU EDCA params from AP beacon.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_OVERRIDE_MU_EDCA = 21,
+
+       /* 8-bit unsigned value to configure the support for receiving
+        * an MPDU that contains an operating mode control subfield.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OM_CTRL_SUPP = 22,
+
+       /* Nested attribute values required to setup the TWT session.
+        * enum qca_wlan_vendor_attr_twt_setup provides the necessary
+        * information to set up the session. It contains broadcast flags,
+        * set_up flags, trigger value, flow type, flow ID, wake interval
+        * exponent, protection, target wake time, wake duration, wake interval
+        * mantissa. These nested attributes are used to setup a host triggered
+        * TWT session.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_SETUP = 23,
+
+       /* This nested attribute is used to terminate the current TWT session.
+        * It does not currently carry any attributes.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_TERMINATE = 24,
+
+       /* This nested attribute is used to suspend the current TWT session.
+        * It does not currently carry any attributes.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_SUSPEND = 25,
+
+       /* Nested attribute values to indicate the request for resume.
+        * This attribute is used to resume the TWT session.
+        * enum qca_wlan_vendor_attr_twt_resume provides the necessary
+        * parameters required to resume the TWT session.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_RESUME = 26,
+
+       /* 8-bit unsigned value to set the HE operating mode control
+        * (OM CTRL) Channel Width subfield.
+        * The Channel Width subfield indicates the operating channel width
+        * supported by the STA for both reception and transmission.
+        * Uses the enum qca_wlan_he_om_ctrl_ch_bw values.
+        * This setting is cleared with the
+        * QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_CLEAR_HE_OM_CTRL_CONFIG
+        * flag attribute to reset defaults.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OM_CTRL_BW = 27,
+
+       /* 8-bit unsigned value to configure the number of spatial
+        * streams in HE operating mode control field.
+        * This setting is cleared with the
+        * QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_CLEAR_HE_OM_CTRL_CONFIG
+        * flag attribute to reset defaults.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OM_CTRL_NSS = 28,
+
+       /* Flag attribute to configure the UL MU disable bit in
+        * HE operating mode control field.
+        * This setting is cleared with the
+        * QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_CLEAR_HE_OM_CTRL_CONFIG
+        * flag attribute to reset defaults.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OM_CTRL_UL_MU_DISABLE = 29,
+
+       /* Flag attribute to clear the previously set HE operating mode
+        * control field configuration.
+        * This attribute is used to configure the testbed device to reset
+        * defaults to clear any previously set HE operating mode control
+        * field configuration.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_CLEAR_HE_OM_CTRL_CONFIG = 30,
+
+       /* 8-bit unsigned value to configure HE single user PPDU
+        * transmission. By default this setting is disabled and it
+        * is disabled in the reset defaults of the device configuration.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_TX_SUPPDU = 31,
+
+       /* 8-bit unsigned value to configure action frame transmission
+        * in HE trigger based PPDU transmission.
+        * By default this setting is disabled and it is disabled in
+        * the reset defaults of the device configuration.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_ACTION_TX_TB_PPDU = 32,
+
+       /* Nested attribute to indicate HE operating mode control field
+        * transmission. It contains operating mode control field Nss,
+        * channel bandwidth, Tx Nsts and UL MU disable attributes.
+        * These nested attributes are used to send HE operating mode control
+        * with configured values.
+        * Uses the enum qca_wlan_vendor_attr_he_omi_tx attributes.
+        * This attribute is used to configure the testbed device.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_OMI_TX = 33,
+
+       /* 8-bit unsigned value to configure +HTC_HE support to indicate the
+        * support for the reception of a frame that carries an HE variant
+        * HT Control field.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_HTC_HE_SUPP = 34,
+
+       /* 8-bit unsigned value to configure VHT support in 2.4G band.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_ENABLE_2G_VHT = 35,
+
+       /* 8-bit unsigned value to configure HE testbed defaults.
+        * This attribute is used to configure the testbed device.
+        * 1-set the device HE capabilities to testbed defaults.
+        * 0-reset the device HE capabilities to supported config.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_SET_HE_TESTBED_DEFAULTS = 36,
+
+       /* 8-bit unsigned value to configure TWT request support.
+        * This attribute is used to configure the testbed device.
+        * 1-enable, 0-disable.
+        */
+       QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_HE_TWT_REQ_SUPPORT = 37,
+
        /* keep last */
        QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_AFTER_LAST,
        QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_MAX =
@@ -5567,4 +6345,923 @@ enum qca_wlan_vendor_bss_filter_sta_stats {
        QCA_WLAN_VENDOR_BSS_FILTER_STA_STATS_AFTER_LAST - 1
 };
 
+/* enum qca_wlan_nan_subcmd_type - Type of NAN command used by attribute
+ * QCA_WLAN_VENDOR_ATTR_NAN_SUBCMD_TYPE as a part of vendor command
+ * QCA_NL80211_VENDOR_SUBCMD_NAN_EXT.
+ */
+enum qca_wlan_nan_ext_subcmd_type {
+       /* Subcmd of type NAN Enable Request */
+       QCA_WLAN_NAN_EXT_SUBCMD_TYPE_ENABLE_REQ = 1,
+       /* Subcmd of type NAN Disable Request */
+       QCA_WLAN_NAN_EXT_SUBCMD_TYPE_DISABLE_REQ = 2,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_nan_params - Used by the vendor command
+ * QCA_NL80211_VENDOR_SUBCMD_NAN_EXT.
+ */
+enum qca_wlan_vendor_attr_nan_params {
+       QCA_WLAN_VENDOR_ATTR_NAN_INVALID = 0,
+       /* Carries NAN command for firmware component. Every vendor command
+        * QCA_NL80211_VENDOR_SUBCMD_NAN_EXT must contain this attribute with a
+        * payload containing the NAN command. NLA_BINARY attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_NAN_CMD_DATA = 1,
+       /* Indicates the type of NAN command sent with
+        * QCA_NL80211_VENDOR_SUBCMD_NAN_EXT. enum qca_wlan_nan_ext_subcmd_type
+        * describes the possible range of values. This attribute is mandatory
+        * if the command being issued is either
+        * QCA_WLAN_NAN_EXT_SUBCMD_TYPE_ENABLE_REQ or
+        * QCA_WLAN_NAN_EXT_SUBCMD_TYPE_DISABLE_REQ. NLA_U32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_NAN_SUBCMD_TYPE = 2,
+       /* Frequency (in MHz) of primary NAN discovery social channel in 2.4 GHz
+        * band. This attribute is mandatory when command type is
+        * QCA_WLAN_NAN_EXT_SUBCMD_TYPE_ENABLE_REQ. NLA_U32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_NAN_DISC_24GHZ_BAND_FREQ = 3,
+       /* Frequency (in MHz) of secondary NAN discovery social channel in 5 GHz
+        * band. This attribute is optional and should be included when command
+        * type is QCA_WLAN_NAN_EXT_SUBCMD_TYPE_ENABLE_REQ and NAN discovery
+        * has to be started on 5GHz along with 2.4GHz. NLA_U32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_NAN_DISC_5GHZ_BAND_FREQ = 4,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_NAN_PARAMS_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_NAN_PARAMS_MAX =
+               QCA_WLAN_VENDOR_ATTR_NAN_PARAMS_AFTER_LAST - 1
+};
+
+/**
+ * enum qca_wlan_vendor_attr_twt_setup: Represents attributes for
+ * TWT (Target Wake Time) setup request. These attributes are sent as part of
+ * %QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_SETUP and
+ * %QCA_NL80211_VENDOR_SUBCMD_WIFI_TEST_CONFIGURATION.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_BCAST: Flag attribute.
+ * Disable (flag attribute not present) - Individual TWT
+ * Enable (flag attribute present) - Broadcast TWT.
+ * Individual means the session is between the STA and the AP.
+ * This session is established using a separate negotiation between
+ * STA and AP.
+ * Broadcast means the session is across multiple STAs and an AP. The
+ * configuration parameters are announced in Beacon frames by the AP.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_REQ_TYPE: Required (u8).
+ * Unsigned 8-bit qca_wlan_vendor_twt_setup_req_type to
+ * specify the TWT request type
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_TRIGGER: Flag attribute
+ * Enable (flag attribute present) - TWT with trigger support.
+ * Disable (flag attribute not present) - TWT without trigger support.
+ * Trigger means the AP will send the trigger frame to allow STA to send data.
+ * Without trigger, the STA will wait for the MU EDCA timer before
+ * transmitting the data.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_FLOW_TYPE: Required (u8)
+ * 0 - Announced TWT - In this mode, STA may skip few service periods to
+ * save more power. If STA wants to wake up, it will send a PS-POLL/QoS
+ * NULL frame to AP.
+ * 1 - Unannounced TWT - The STA will wakeup during every SP.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_FLOW_ID: Optional (u8)
+ * Flow ID is the unique identifier for each TWT session.
+ * Currently this is not required and dialog ID will be set to zero.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_INTVL_EXP: Required (u8)
+ * This attribute (exp) is used along with the mantissa to derive the
+ * wake interval using the following formula:
+ * pow(2,exp) = wake_intvl_us/wake_intvl_mantis
+ * Wake interval is the interval between 2 successive SP.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_PROTECTION: Flag attribute
+ * Enable (flag attribute present) - Protection required.
+ * Disable (flag attribute not present) - Protection not required.
+ * If protection is enabled, then the AP will use protection
+ * mechanism using RTS/CTS to self to reserve the airtime.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_TIME: Optional (u32)
+ * This attribute is used as the SP offset which is the offset from
+ * TSF after which the wake happens. The units are in microseconds. If
+ * this attribute is not provided, then the value will be set to zero.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_DURATION: Required (u32)
+ * This is the duration of the service period. The units are in TU.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_INTVL_MANTISSA: Required (u32)
+ * This attribute is used to configure wake interval mantissa.
+ * The units are in TU.
+ */
+enum qca_wlan_vendor_attr_twt_setup {
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_INVALID = 0,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_BCAST = 1,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_REQ_TYPE = 2,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_TRIGGER = 3,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_FLOW_TYPE = 4,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_FLOW_ID = 5,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_INTVL_EXP = 6,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_PROTECTION = 7,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_TIME = 8,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_DURATION = 9,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_WAKE_INTVL_MANTISSA = 10,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_MAX =
+       QCA_WLAN_VENDOR_ATTR_TWT_SETUP_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_twt_resume: Represents attributes for
+ * TWT (Target Wake Time) resume request. These attributes are sent as part of
+ * %QCA_WLAN_VENDOR_ATTR_WIFI_TEST_CONFIG_TWT_RESUME and
+ * %QCA_NL80211_VENDOR_SUBCMD_WIFI_TEST_CONFIGURATION.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_RESUME_NEXT_TWT: Optional (u8)
+ * This attribute is used as the SP offset which is the offset from
+ * TSF after which the wake happens. The units are in microseconds.
+ * If this attribute is not provided, then the value will be set to
+ * zero.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_TWT_RESUME_NEXT_TWT_SIZE: Required (u32)
+ * This attribute represents the next TWT subfield size.
+ */
+enum qca_wlan_vendor_attr_twt_resume {
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_INVALID = 0,
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_NEXT_TWT = 1,
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_NEXT_TWT_SIZE = 2,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_MAX =
+       QCA_WLAN_VENDOR_ATTR_TWT_RESUME_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_wlan_vendor_twt_setup_req_type - Required (u8)
+ * Represents the setup type being requested for TWT.
+ * @QCA_WLAN_VENDOR_TWT_SETUP_REQUEST: STA is not specifying all the TWT
+ * parameters but relying on AP to fill the parameters during the negotiation.
+ * @QCA_WLAN_VENDOR_TWT_SETUP_SUGGEST: STA will provide all the suggested
+ * values which the AP may accept or AP may provide alternative parameters
+ * which the STA may accept.
+ * @QCA_WLAN_VENDOR_TWT_SETUP_DEMAND: STA is not willing to accept any
+ * alternate parameters than the requested ones.
+ */
+enum qca_wlan_vendor_twt_setup_req_type {
+       QCA_WLAN_VENDOR_TWT_SETUP_REQUEST = 1,
+       QCA_WLAN_VENDOR_TWT_SETUP_SUGGEST = 2,
+       QCA_WLAN_VENDOR_TWT_SETUP_DEMAND = 3,
+};
+
+/**
+ * enum qca_wlan_roam_scan_event_type - Type of roam scan event
+ *
+ * Indicates the type of roam scan event sent by firmware/driver.
+ *
+ * @QCA_WLAN_ROAM_SCAN_TRIGGER_EVENT: Roam scan trigger event type.
+ * @QCA_WLAN_ROAM_SCAN_STOP_EVENT: Roam scan stopped event type.
+ */
+enum qca_wlan_roam_scan_event_type {
+       QCA_WLAN_ROAM_SCAN_TRIGGER_EVENT = 0,
+       QCA_WLAN_ROAM_SCAN_STOP_EVENT = 1,
+};
+
+/**
+ * enum qca_wlan_roam_scan_trigger_reason - Roam scan trigger reason
+ *
+ * Indicates the reason for triggering roam scan by firmware/driver.
+ *
+ * @QCA_WLAN_ROAM_SCAN_TRIGGER_REASON_LOW_RSSI: Due to low RSSI of current AP.
+ * @QCA_WLAN_ROAM_SCAN_TRIGGER_REASON_HIGH_PER: Due to high packet error rate.
+ */
+enum qca_wlan_roam_scan_trigger_reason {
+       QCA_WLAN_ROAM_SCAN_TRIGGER_REASON_LOW_RSSI = 0,
+       QCA_WLAN_ROAM_SCAN_TRIGGER_REASON_HIGH_PER = 1,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_roam_scan - Vendor subcmd attributes to report
+ * roam scan related details from driver/firmware to user space. enum values
+ * are used for NL attributes sent with
+ * %QCA_NL80211_VENDOR_SUBCMD_ROAM_SCAN_EVENT sub command.
+ */
+enum qca_wlan_vendor_attr_roam_scan {
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_INVALID = 0,
+       /* Encapsulates type of roam scan event being reported. enum
+        * qca_wlan_roam_scan_event_type describes the possible range of
+        * values. u32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_EVENT_TYPE = 1,
+       /* Encapsulates reason for triggering roam scan. enum
+        * qca_wlan_roam_scan_trigger_reason describes the possible range of
+        * values. u32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_TRIGGER_REASON = 2,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_MAX =
+       QCA_WLAN_VENDOR_ATTR_ROAM_SCAN_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_wlan_vendor_cfr_method - QCA vendor CFR methods used by
+ * attribute QCA_WLAN_VENDOR_ATTR_PEER_CFR_METHOD as part of vendor
+ * command QCA_NL80211_VENDOR_SUBCMD_PEER_CFR_CAPTURE_CFG.
+ */
+enum qca_wlan_vendor_cfr_method {
+       /* CFR method using QOS Null frame */
+       QCA_WLAN_VENDOR_CFR_METHOD_QOS_NULL = 0,
+};
+
+/**
+ * enum qca_wlan_vendor_peer_cfr_capture_attr - Used by the vendor command
+ * QCA_NL80211_VENDOR_SUBCMD_PEER_CFR_CAPTURE_CFG to configure peer
+ * Channel Frequency Response capture parameters and enable periodic CFR
+ * capture.
+ */
+enum qca_wlan_vendor_peer_cfr_capture_attr {
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_CAPTURE_INVALID = 0,
+       /* 6-byte MAC address of the peer.
+        * This attribute is mandatory.
+        */
+       QCA_WLAN_VENDOR_ATTR_CFR_PEER_MAC_ADDR = 1,
+       /* Enable peer CFR Capture, flag attribute.
+        * This attribute is mandatory to enable peer CFR capture.
+        * If this attribute is not present, peer CFR capture is disabled.
+        */
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_ENABLE = 2,
+       /* BW of measurement, attribute uses the values in enum nl80211_chan_width
+        * Supported values: 20, 40, 80, 80+80, 160.
+        * Note that all targets may not support all bandwidths.
+        * u8 attribute. This attribute is mandatory if attribute
+        * QCA_WLAN_VENDOR_ATTR_PEER_CFR_ENABLE is used.
+        */
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_BANDWIDTH = 3,
+       /* Periodicity of CFR measurement in msec.
+        * Periodicity should be a multiple of Base timer.
+        * Current Base timer value supported is 10 msecs (default).
+        * 0 for one shot capture. u32 attribute.
+        * This attribute is mandatory if attribute
+        * QCA_WLAN_VENDOR_ATTR_PEER_CFR_ENABLE is used.
+        */
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_PERIODICITY = 4,
+       /* Method used to capture Channel Frequency Response.
+        * Attribute uses the values defined in enum qca_wlan_vendor_cfr_method.
+        * u8 attribute. This attribute is mandatory if attribute
+        * QCA_WLAN_VENDOR_ATTR_PEER_CFR_ENABLE is used.
+        */
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_METHOD = 5,
+       /* Enable periodic CFR capture, flag attribute.
+        * This attribute is mandatory to enable Periodic CFR capture.
+        * If this attribute is not present, periodic CFR capture is disabled.
+        */
+       QCA_WLAN_VENDOR_ATTR_PERIODIC_CFR_CAPTURE_ENABLE = 6,
+
+       /* Keep last */
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_MAX =
+       QCA_WLAN_VENDOR_ATTR_PEER_CFR_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_wlan_throughput_level - Current throughput level
+ *
+ * Indicates the current level of throughput calculated by the driver. The
+ * driver may choose different thresholds to decide whether the throughput level
+ * is low or medium or high based on variety of parameters like physical link
+ * capacity of the current connection, the number of packets being dispatched
+ * per second, etc. The throughput level events might not be consistent with the
+ * actual current throughput value being observed.
+ *
+ * @QCA_WLAN_THROUGHPUT_LEVEL_LOW: Low level of throughput
+ * @QCA_WLAN_THROUGHPUT_LEVEL_MEDIUM: Medium level of throughput
+ * @QCA_WLAN_THROUGHPUT_LEVEL_HIGH: High level of throughput
+ */
+enum qca_wlan_throughput_level {
+       QCA_WLAN_THROUGHPUT_LEVEL_LOW = 0,
+       QCA_WLAN_THROUGHPUT_LEVEL_MEDIUM = 1,
+       QCA_WLAN_THROUGHPUT_LEVEL_HIGH = 2,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_throughput_change - Vendor subcmd attributes to
+ * report throughput changes from the driver to user space. enum values are used
+ * for netlink attributes sent with
+ * %QCA_NL80211_VENDOR_SUBCMD_THROUGHPUT_CHANGE_EVENT sub command.
+ */
+enum qca_wlan_vendor_attr_throughput_change {
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_INVALID = 0,
+       /* Indicates the direction of throughput in which the change is being
+        * reported. u8 attribute. Value is 0 for TX and 1 for RX.
+        */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_DIRECTION = 1,
+       /* Indicates the newly observed throughput level. enum
+        * qca_wlan_throughput_level describes the possible range of values.
+        * u8 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_THROUGHPUT_LEVEL = 2,
+       /* Indicates the driver's guidance on the new value to be set to
+        * kernel's TCP parameter tcp_limit_output_bytes. u32 attribute. The
+        * driver may optionally include this attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_TCP_LIMIT_OUTPUT_BYTES = 3,
+       /* Indicates the driver's guidance on the new value to be set to
+        * kernel's TCP parameter tcp_adv_win_scale. s8 attribute. Possible
+        * values are from -31 to 31. The driver may optionally include this
+        * attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_TCP_ADV_WIN_SCALE = 4,
+       /* Indicates the driver's guidance on the new value to be set to
+        * kernel's TCP parameter tcp_delack_seg. u32 attribute. The driver may
+        * optionally include this attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_TCP_DELACK_SEG = 5,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_MAX =
+       QCA_WLAN_VENDOR_ATTR_THROUGHPUT_CHANGE_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_coex_config_profiles - This enum defines different types of
+ * traffic streams that can be prioritized one over the other during coex
+ * scenarios.
+ * The types defined in this enum are categorized in the below manner.
+ * 0 - 31 values corresponds to WLAN
+ * 32 - 63 values corresponds to BT
+ * 64 - 95 values corresponds to Zigbee
+ * @QCA_WIFI_STA_DISCOVERY: Prioritize discovery frames for WLAN STA
+ * @QCA_WIFI_STA_CONNECTION: Prioritize connection frames for WLAN STA
+ * @QCA_WIFI_STA_CLASS_3_MGMT: Prioritize class 3 mgmt frames for WLAN STA
+ * @QCA_WIFI_STA_DATA : Prioritize data frames for WLAN STA
+ * @QCA_WIFI_STA_ALL: Priritize all frames for WLAN STA
+ * @QCA_WIFI_SAP_DISCOVERY: Prioritize discovery frames for WLAN SAP
+ * @QCA_WIFI_SAP_CONNECTION: Prioritize connection frames for WLAN SAP
+ * @QCA_WIFI_SAP_CLASS_3_MGMT: Prioritize class 3 mgmt frames for WLAN SAP
+ * @QCA_WIFI_SAP_DATA: Prioritize data frames for WLAN SAP
+ * @QCA_WIFI_SAP_ALL: Prioritize all frames for WLAN SAP
+ * @QCA_BT_A2DP: Prioritize BT A2DP
+ * @QCA_BT_BLE: Prioritize BT BLE
+ * @QCA_BT_SCO: Prioritize BT SCO
+ * @QCA_ZB_LOW: Prioritize Zigbee Low
+ * @QCA_ZB_HIGH: Prioritize Zigbee High
+ */
+enum qca_coex_config_profiles {
+       /* 0 - 31 corresponds to WLAN */
+       QCA_WIFI_STA_DISCOVERY = 0,
+       QCA_WIFI_STA_CONNECTION = 1,
+       QCA_WIFI_STA_CLASS_3_MGMT = 2,
+       QCA_WIFI_STA_DATA = 3,
+       QCA_WIFI_STA_ALL = 4,
+       QCA_WIFI_SAP_DISCOVERY = 5,
+       QCA_WIFI_SAP_CONNECTION = 6,
+       QCA_WIFI_SAP_CLASS_3_MGMT = 7,
+       QCA_WIFI_SAP_DATA = 8,
+       QCA_WIFI_SAP_ALL = 9,
+       QCA_WIFI_CASE_MAX = 31,
+       /* 32 - 63 corresponds to BT */
+       QCA_BT_A2DP = 32,
+       QCA_BT_BLE = 33,
+       QCA_BT_SCO = 34,
+       QCA_BT_CASE_MAX = 63,
+       /* 64 - 95 corresponds to Zigbee */
+       QCA_ZB_LOW = 64,
+       QCA_ZB_HIGH = 65,
+       QCA_ZB_CASE_MAX = 95,
+       /* 0xff is default value if the u8 profile value is not set. */
+       QCA_COEX_CONFIG_PROFILE_DEFAULT_VALUE = 255
+};
+
+/**
+ * enum qca_vendor_attr_coex_config_types - Coex configurations types.
+ * This enum defines the valid set of values of coex configuration types. These
+ * values may used by attribute
+ * %QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_CONFIG_TYPE.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_COEX_RESET: Reset all the
+ *     weights to default values.
+ * @QCA_WLAN_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_COEX_START: Start to config
+ *     weights with configurability value.
+ */
+enum qca_vendor_attr_coex_config_types {
+       QCA_WLAN_VENDOR_ATTR_COEX_CONFIG_INVALID = 0,
+       QCA_WLAN_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_COEX_RESET = 1,
+       QCA_WLAN_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_COEX_START = 2,
+};
+
+/**
+ * enum qca_vendor_attr_coex_config - Specifies vendor coex config attributes
+ *
+ * @QCA_VENDOR_ATTR_COEX_CONFIG_PROFILES: This attribute contains variable
+ * length array of 8-bit values from enum qca_coex_config_profiles.
+ * FW will prioritize the profiles in the order given in the array encapsulated
+ * in this attribute.
+ * For example:
+ * -----------------------------------------------------------------------
+ * |     1       |       34       |        32         |         65       |
+ * -----------------------------------------------------------------------
+ * If the attribute contains the values defined in above array then it means
+ * 1) Wifi STA connection has priority over BT_SCO, BT_A2DP and ZIGBEE HIGH.
+ * 2) BT_SCO has priority over BT_A2DP.
+ * 3) BT_A2DP has priority over ZIGBEE HIGH.
+ * Profiles which are not listed in this array shall not be preferred over the
+ * profiles which are listed in the array as a part of this attribute.
+ */
+enum qca_vendor_attr_coex_config {
+       QCA_VENDOR_ATTR_COEX_CONFIG_INVALID = 0,
+       QCA_VENDOR_ATTR_COEX_CONFIG_PROFILES = 1,
+
+       /* Keep last */
+       QCA_VENDOR_ATTR_COEX_CONFIG_AFTER_LAST,
+       QCA_VENDOR_ATTR_COEX_CONFIG_MAX =
+       QCA_VENDOR_ATTR_COEX_CONFIG_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_vendor_attr_coex_config_three_way - Specifies vendor coex config
+ * attributes
+ * Attributes for data used by QCA_NL80211_VENDOR_SUBCMD_COEX_CONFIG
+ *
+ * QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_CONFIG_TYPE: u32 attribute.
+ * Indicate config type.
+ * The config types are 32-bit values from qca_vendor_attr_coex_config_types
+ *
+ * @QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_1: u32 attribute.
+ *     Indicate the Priority 1 profiles.
+ *     The profiles are 8-bit values from enum qca_coex_config_profiles.
+ *     In same priority level, maximum to 4 profiles can be set here.
+ * @QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_2: u32 attribute.
+ *     Indicate the Priority 2 profiles.
+ *     The profiles are 8-bit values from enum qca_coex_config_profiles.
+ *     In same priority level, maximum to 4 profiles can be set here.
+ * @QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_3: u32 attribute.
+ *     Indicate the Priority 3 profiles.
+ *     The profiles are 8-bit values from enum qca_coex_config_profiles.
+ *     In same priority level, maximum to 4 profiles can be set here.
+ * @QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_4: u32 attribute.
+ *     Indicate the Priority 4 profiles.
+ *     The profiles are 8-bit values from enum qca_coex_config_profiles.
+ *     In same priority level, maximum to 4 profiles can be set here.
+ * NOTE:
+ * Limitations for QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_x priority
+ * arrangement:
+ *     1: In the same u32 attribute (priority x), the profiles enum values own
+ *     same priority level.
+ *     2: 0xff is default value if the u8 profile value is not set.
+ *     3: max to 4 rules/profiles in same priority level.
+ *     4: max to 4 priority level (priority 1 - priority 4)
+ *     5: one priority level only supports one scenario from WLAN/BT/ZB,
+ *     hybrid rules not support.
+ *     6: if WMI_COEX_CONFIG_THREE_WAY_COEX_RESET called, priority x will
+ *     remain blank to reset all parameters.
+ * For example:
+ *
+ *     If the attributes as follow:
+ *     priority 1:
+ *     ------------------------------------
+ *     |  0xff  |    0   |   1   |    2   |
+ *     ------------------------------------
+ *     priority 2:
+ *     -------------------------------------
+ *     |  0xff  |  0xff  |  0xff  |   32   |
+ *     -------------------------------------
+ *     priority 3:
+ *     -------------------------------------
+ *     |  0xff  |  0xff  |  0xff  |   65   |
+ *     -------------------------------------
+ *     then it means:
+ *     1: WIFI_STA_DISCOVERY, WIFI_STA_CLASS_3_MGMT and WIFI_STA_CONNECTION
+ *             owns same priority level.
+ *     2: WIFI_STA_DISCOVERY, WIFI_STA_CLASS_3_MGMT and WIFI_STA_CONNECTION
+ *             has priority over BT_A2DP and ZB_HIGH.
+ *     3: BT_A2DP has priority over ZB_HIGH.
+ */
+
+enum qca_vendor_attr_coex_config_three_way {
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_INVALID = 0,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_CONFIG_TYPE = 1,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_1 = 2,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_2 = 3,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_3 = 4,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_PRIORITY_4 = 5,
+
+       /* Keep last */
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_AFTER_LAST,
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_MAX =
+       QCA_VENDOR_ATTR_COEX_CONFIG_THREE_WAY_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_link_properties - Represent the link properties.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_MAC_ADDR: MAC address of the peer
+ * (STA/AP) for the connected link.
+ * @QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_STA_FLAGS: Attribute containing a
+ * &struct nl80211_sta_flag_update for the respective connected link. MAC
+ * address of the peer represented by
+ * QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_MAC_ADDR.
+ */
+enum qca_wlan_vendor_attr_link_properties {
+       QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_INVALID = 0,
+       /* 1 - 3 are reserved */
+       QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_MAC_ADDR = 4,
+       QCA_WLAN_VENDOR_ATTR_LINK_PROPERTIES_STA_FLAGS = 5,
+
+       /* Keep last */
+       QCA_VENDOR_ATTR_LINK_PROPERTIES_AFTER_LAST,
+       QCA_VENDOR_ATTR_LINK_PROPERTIES_MAX =
+       QCA_VENDOR_ATTR_LINK_PROPERTIES_AFTER_LAST - 1,
+};
+
+/**
+ * enum qca_vendor_attr_peer_stats_cache_type - Represents peer stats cache type
+ * This enum defines the valid set of values of peer stats cache types. These
+ * values are used by attribute
+ * %QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_TYPE.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_PEER_TX_RATE_STATS: Represents peer TX rate statistics
+ * @QCA_WLAN_VENDOR_ATTR_PEER_RX_RATE_STATS: Represents peer RX rate statistics
+ * @QCA_WLAN_VENDOR_ATTR_PEER_TX_SOJOURN_STATS: Represents peer TX sojourn
+ * statistics
+ */
+enum qca_vendor_attr_peer_stats_cache_type {
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_TYPE_INVALID = 0,
+
+       QCA_WLAN_VENDOR_ATTR_PEER_TX_RATE_STATS,
+       QCA_WLAN_VENDOR_ATTR_PEER_RX_RATE_STATS,
+       QCA_WLAN_VENDOR_ATTR_PEER_TX_SOJOURN_STATS,
+};
+
+/**
+ * enum qca_wlan_vendor_attr_peer_stats_cache_params - This enum defines
+ * attributes required for QCA_NL80211_VENDOR_SUBCMD_PEER_STATS_CACHE_FLUSH
+ * Information in these attributes is used to flush peer rate statistics from
+ * the driver to user application.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_TYPE: Unsigned 32-bit attribute
+ * Indicate peer statistics cache type.
+ * The statistics types are 32-bit values from
+ * enum qca_vendor_attr_peer_stats_cache_type.
+ * @QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_PEER_MAC: Unsigned 8-bit array
+ * of size 6 octets, representing the peer MAC address.
+ * @QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_DATA: Opaque data attribute
+ * containing buffer of statistics to send to application layer entity.
+ * @QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_PEER_COOKIE: Unsigned 64-bit attribute
+ * representing a cookie for peer unique session.
+ */
+enum qca_wlan_vendor_attr_peer_stats_cache_params {
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_INVALID = 0,
+
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_TYPE = 1,
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_PEER_MAC = 2,
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_DATA = 3,
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_PEER_COOKIE = 4,
+
+       /* Keep last */
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_LAST,
+       QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_MAX =
+               QCA_WLAN_VENDOR_ATTR_PEER_STATS_CACHE_LAST - 1
+};
+
+/**
+ * enum qca_mpta_helper_attr_zigbee_state - Current Zigbee state
+ * This enum defines all the possible states of Zigbee, which can be
+ * delivered in the QCA_MPTA_HELPER_VENDOR_ATTR_ZIGBEE_STATE attribute.
+ *
+ * @ZIGBEE_IDLE: Zigbee in idle state
+ * @ZIGBEE_FORM_NETWORK: Zigbee forming network
+ * @ZIGBEE_WAIT_JOIN: Zigbee waiting for joining network
+ * @ZIGBEE_JOIN: Zigbee joining network
+ * @ZIGBEE_NETWORK_UP: Zigbee network is up
+ * @ZIGBEE_HMI: Zigbee in HMI mode
+ */
+enum qca_mpta_helper_attr_zigbee_state {
+       ZIGBEE_IDLE = 0,
+       ZIGBEE_FORM_NETWORK = 1,
+       ZIGBEE_WAIT_JOIN = 2,
+       ZIGBEE_JOIN = 3,
+       ZIGBEE_NETWORK_UP = 4,
+       ZIGBEE_HMI = 5,
+};
+
+/*
+ * enum qca_mpta_helper_vendor_attr - Attributes used in vendor sub-command
+ * QCA_NL80211_VENDOR_SUBCMD_MPTA_HELPER_CONFIG.
+ */
+enum qca_mpta_helper_vendor_attr {
+       QCA_MPTA_HELPER_VENDOR_ATTR_INVALID = 0,
+       /* Optional attribute used to update Zigbee state.
+        * enum qca_mpta_helper_attr_zigbee_state.
+        * NLA_U32 attribute.
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_ZIGBEE_STATE = 1,
+       /* Optional attribute used to configure WLAN duration for Shape-OCS
+        * during interrupt.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_INT_NON_WLAN_DURATION.
+        * Value range 0 ~ 300 (ms).
+        * NLA_U32 attribute.
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_INT_WLAN_DURATION = 2,
+       /* Optional attribute used to configure non-WLAN duration for Shape-OCS
+        * during interrupt.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_INT_WLAN_DURATION.
+        * Value range 0 ~ 300 (ms).
+        * NLA_U32 attribute.
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_INT_NON_WLAN_DURATION  = 3,
+       /* Optional attribute used to configure WLAN duration for Shape-OCS
+        * monitor period.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_MON_NON_WLAN_DURATION.
+        * Value range 0 ~ 300 (ms)
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_MON_WLAN_DURATION = 4,
+       /* Optional attribute used to configure non-WLAN duration for Shape-OCS
+        * monitor period.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_MON_WLAN_DURATION.
+        * Value range 0 ~ 300 (ms)
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_MON_NON_WLAN_DURATION  = 5,
+       /* Optional attribute used to configure OCS interrupt duration.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_MON_OCS_DURATION.
+        * Value range 1000 ~ 20000 (ms)
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_INT_OCS_DURATION  = 6,
+       /* Optional attribute used to configure OCS monitor duration.
+        * Set in pair with QCA_MPTA_HELPER_VENDOR_ATTR_INT_OCS_DURATION.
+        * Value range 1000 ~ 20000 (ms)
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_MON_OCS_DURATION  = 7,
+       /* Optional attribute used to notify WLAN firmware the current Zigbee
+        * channel.
+        * Value range 11 ~ 26
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_ZIGBEE_CHAN = 8,
+       /* Optional attribute used to configure WLAN mute duration.
+        * Value range 0 ~ 400 (ms)
+        * NLA_U32 attribute
+        */
+       QCA_MPTA_HELPER_VENDOR_ATTR_WLAN_MUTE_DURATION  = 9,
+
+       /* keep last */
+       QCA_MPTA_HELPER_VENDOR_ATTR_AFTER_LAST,
+       QCA_MPTA_HELPER_VENDOR_ATTR_MAX =
+               QCA_MPTA_HELPER_VENDOR_ATTR_AFTER_LAST - 1
+};
+
+/**
+ * enum qca_wlan_vendor_beacon_reporting_op_types - Defines different types of
+ * operations for which %QCA_NL80211_VENDOR_SUBCMD_BEACON_REPORTING can be used.
+ * Will be used by %QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE.
+ *
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START: Sent by userspace to the driver
+ * to request the driver to start reporting Beacon frames.
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_OP_STOP: Sent by userspace to the driver to
+ * request the driver to stop reporting Beacon frames.
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO: Sent by the driver to
+ * userspace to report received Beacon frames.
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_OP_PAUSE: Sent by the driver to userspace
+ * to indicate that the driver is going to pause reporting Beacon frames.
+ */
+enum qca_wlan_vendor_beacon_reporting_op_types {
+       QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START = 0,
+       QCA_WLAN_VENDOR_BEACON_REPORTING_OP_STOP = 1,
+       QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO = 2,
+       QCA_WLAN_VENDOR_BEACON_REPORTING_OP_PAUSE = 3,
+};
+
+/**
+ * enum qca_wlan_vendor_beacon_reporting_pause_reasons - Defines different types
+ * of reasons for which the driver is pausing reporting Beacon frames. Will be
+ * used by %QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_PAUSE_REASON.
+ *
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_UNSPECIFIED: For unspecified
+ * reasons.
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_SCAN_STARTED: When the
+ * driver/firmware is starting a scan.
+ * @QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_DISCONNECTED: When the
+ * driver/firmware disconnects from the ESS and indicates the disconnection to
+ * userspace (non-seamless roaming case). This reason code will be used by the
+ * driver/firmware to indicate stopping of beacon report events. Userspace will
+ * need to start beacon reporting again (if desired) by sending vendor command
+ * QCA_NL80211_VENDOR_SUBCMD_BEACON_REPORTING with
+ * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE set to
+ * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START after the next connection is
+ * completed.
+ */
+enum qca_wlan_vendor_beacon_reporting_pause_reasons {
+       QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_UNSPECIFIED = 0,
+       QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_SCAN_STARTED = 1,
+       QCA_WLAN_VENDOR_BEACON_REPORTING_PAUSE_REASON_DISCONNECTED = 2,
+};
+
+/*
+ * enum qca_wlan_vendor_attr_beacon_reporting_params - List of attributes used
+ * in vendor sub-command QCA_NL80211_VENDOR_SUBCMD_BEACON_REPORTING.
+ */
+enum qca_wlan_vendor_attr_beacon_reporting_params {
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_INVALID = 0,
+       /* Specifies the type of operation that the vendor command/event is
+        * intended for. Possible values for this attribute are defined in
+        * enum qca_wlan_vendor_beacon_reporting_op_types. u32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE = 1,
+       /* Optionally set by userspace to request the driver to report Beacon
+        * frames using asynchronous vendor events when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START. NLA_FLAG attribute.
+        * If this flag is not set, the driver will only update Beacon frames in
+        * cfg80211 scan cache but not send any vendor events.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_ACTIVE_REPORTING = 2,
+       /* Optionally used by userspace to request the driver/firmware to report
+        * Beacon frames periodically when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START.
+        * u32 attribute, indicates the period of Beacon frames to be reported
+        * and in the units of beacon interval.
+        * If this attribute is missing in the command, then the default value
+        * of 1 will be assumed by driver, i.e., to report every Beacon frame.
+        * Zero is an invalid value.
+        * If a valid value is received for this attribute, the driver will
+        * update the cfg80211 scan cache periodically as per the value received
+        * in this attribute in addition to updating the cfg80211 scan cache
+        * when there is significant change in Beacon frame IEs.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_PERIOD = 3,
+       /* Used by the driver to encapsulate the SSID when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO.
+        * u8 array with a maximum size of 32.
+        *
+        * When generating beacon report from non-MBSSID Beacon frame, the SSID
+        * will be taken from the SSID element of the received Beacon frame.
+        *
+        * When generating beacon report from Multiple BSSID Beacon frame and if
+        * the BSSID of the current connected BSS matches the BSSID of the
+        * transmitting BSS, the SSID will be taken from the SSID element of the
+        * received Beacon frame.
+        *
+        * When generating beacon report from Multiple BSSID Beacon frame and if
+        * the BSSID of the current connected BSS matches the BSSID of one of
+        * the* nontransmitting BSSs, the SSID will be taken from the SSID field
+        * included in the nontransmitted BSS profile whose derived BSSID is
+        * same as the BSSID of the current connected BSS. When there is no
+        * nontransmitted BSS profile whose derived BSSID is same as the BSSID
+        * of current connected* BSS, this attribute will not be present.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_SSID = 4,
+       /* Used by the driver to encapsulate the BSSID of the AP to which STA is
+        * currently connected to when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO. u8 array with a
+        * fixed size of 6 bytes.
+        *
+        * When generating beacon report from a Multiple BSSID beacon and the
+        * current connected BSSID matches one of the nontransmitted BSSIDs in a
+        * Multiple BSSID set, this BSSID will be that particular nontransmitted
+        * BSSID and not the transmitted BSSID (i.e., the transmitting address
+        * of the Beacon frame).
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_BSSID = 5,
+       /* Used by the driver to encapsulate the frequency in MHz on which
+        * the Beacon frame was received when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is
+        * set to QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO.
+        * u32 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_FREQ = 6,
+       /* Used by the driver to encapsulate the Beacon interval
+        * when the QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO.
+        * u16 attribute. The value will be copied from the Beacon frame and the
+        * units are TUs.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_BI = 7,
+       /* Used by the driver to encapsulate the Timestamp field from the Beacon
+        * frame when the QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set
+        * to QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO.
+        * u64 attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_TSF = 8,
+       /* Used by the driver to encapsulate the CLOCK_BOOTTIME when this
+        * Beacon frame is received in the driver when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO. u64 attribute, in
+        * the units of nanoseconds. This value is expected to have accuracy of
+        * about 10 ms.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_BOOTTIME_WHEN_RECEIVED = 9,
+       /* Used by the driver to encapsulate the IEs of the Beacon frame from
+        * which this event is generated when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_BEACON_INFO. u8 array.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_IES = 10,
+       /* Used by the driver to specify the reason for the driver/firmware to
+        * pause sending beacons to userspace when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_PAUSE. Possible values are
+        * defined in enum qca_wlan_vendor_beacon_reporting_pause_reasons, u32
+        * attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_PAUSE_REASON = 11,
+       /* Used by the driver to specify whether the driver will automatically
+        * resume reporting beacon events to userspace later (for example after
+        * the ongoing off-channel activity is completed etc.) when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_PAUSE. NLA_FLAG attribute.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_AUTO_RESUMES = 12,
+       /* Optionally set by userspace to request the driver not to resume
+        * beacon reporting after a pause is completed, when the
+        * QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_OP_TYPE is set to
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START. NLA_FLAG attribute.
+        * If this flag is set, the driver will not resume beacon reporting
+        * after any pause in beacon reporting is completed. Userspace has to
+        * send QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START command again in order
+        * to initiate beacon reporting again. If this flag is set in the recent
+        * QCA_WLAN_VENDOR_BEACON_REPORTING_OP_START command, then in the
+        * subsequent QCA_WLAN_VENDOR_BEACON_REPORTING_OP_PAUSE event (if any)
+        * the QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_AUTO_RESUMES shall not be
+        * set by the driver. Setting this flag until and unless there is a
+        * specific need is not recommended as there is a chance of some beacons
+        * received after pause command and next start command being not
+        * reported.
+        */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_DO_NOT_RESUME = 13,
+
+       /* Keep last */
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_LAST,
+       QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_MAX =
+               QCA_WLAN_VENDOR_ATTR_BEACON_REPORTING_LAST - 1
+};
+
+/**
+ * enum qca_vendor_interop_issues_ap_type - Interop issue types
+ * This enum defines the valid set of values of interop issue types. These
+ * values are used by attribute %QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_TYPE.
+ *
+ * @QCA_VENDOR_INTEROP_ISSUES_AP_ON_STA_PS: The AP has power save interop issue
+ * when the STA's Qpower feature is enabled.
+ */
+enum qca_vendor_interop_issues_ap_type {
+       QCA_VENDOR_INTEROP_ISSUES_AP_INVALID = 0,
+       QCA_VENDOR_INTEROP_ISSUES_AP_ON_STA_PS = 1,
+};
+
+/**
+ * enum qca_vendor_attr_interop_issues_ap - attribute for AP with interop issues
+ * Values are used by %QCA_NL80211_VENDOR_SUBCMD_INTEROP_ISSUES_AP.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_INVALID: Invalid value
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_TYPE: Interop issue type
+ * 32-bit unsigned value. The values defined in enum
+ * qca_vendor_interop_issues_ap_type are used.
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_LIST: APs' BSSID container
+ * array of nested QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_BSSID attributes.
+ * It is present and mandatory for the command but is not used for the event
+ * since only a single BSSID is reported in an event.
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_BSSID: AP's BSSID 6-byte MAC address.
+ * It is used within the nested QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_LIST
+ * attribute in command case and without such encapsulation in the event case.
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_AFTER_LAST: last value
+ * @QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_MAX: max value
+ */
+enum qca_vendor_attr_interop_issues_ap {
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_INVALID,
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_TYPE,
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_LIST,
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_BSSID,
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_MAX =
+               QCA_WLAN_VENDOR_ATTR_INTEROP_ISSUES_AP_AFTER_LAST - 1
+};
+
+/*
+ * enum qca_wlan_vendor_attr_oem_data_params - Used by the vendor command
+ * QCA_NL80211_VENDOR_SUBCMD_OEM_DATA.
+ *
+ * @QCA_WLAN_VENDOR_ATTR_OEM_DATA_CMD_DATA: The binary blob for the vendor
+ * command QCA_NL80211_VENDOR_SUBCMD_OEM_DATA are carried through this attribute.
+ * NLA_BINARY attribute, the max size is 1024 bytes.
+ */
+enum qca_wlan_vendor_attr_oem_data_params {
+       QCA_WLAN_VENDOR_ATTR_OEM_DATA_INVALID = 0,
+       QCA_WLAN_VENDOR_ATTR_OEM_DATA_CMD_DATA = 1,
+
+       /* keep last */
+       QCA_WLAN_VENDOR_ATTR_OEM_DATA_PARAMS_AFTER_LAST,
+       QCA_WLAN_VENDOR_ATTR_OEM_DATA_PARAMS_MAX =
+               QCA_WLAN_VENDOR_ATTR_OEM_DATA_PARAMS_AFTER_LAST - 1
+};
 #endif /* QCA_VENDOR_H */