Add IPA TX msdu_id space repartitioning. Change-Id: I2dd4d430c3ba4413c6b0629d2a97d06769ef0afd CRs-Fixed: 865207
359 lines
14 KiB
C
359 lines
14 KiB
C
/*
|
|
* Copyright (c) 2011-2016 The Linux Foundation. All rights reserved.
|
|
*
|
|
* Previously licensed under the ISC license by Qualcomm Atheros, Inc.
|
|
*
|
|
*
|
|
* Permission to use, copy, modify, and/or distribute this software for
|
|
* any purpose with or without fee is hereby granted, provided that the
|
|
* above copyright notice and this permission notice appear in all
|
|
* copies.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
|
|
* WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
|
|
* WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
|
|
* AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
|
|
* DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
|
|
* PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
|
|
* TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
* PERFORMANCE OF THIS SOFTWARE.
|
|
*/
|
|
|
|
/*
|
|
* This file was originally distributed by Qualcomm Atheros, Inc.
|
|
* under proprietary terms before Copyright ownership was assigned
|
|
* to the Linux Foundation.
|
|
*/
|
|
|
|
/**
|
|
* This file defines WMI services bitmap and the set of WMI services .
|
|
* defines macrso to set/clear/get different service bits from the bitmap.
|
|
* the service bitmap is sent up to the host via WMI_READY command.
|
|
*
|
|
*/
|
|
|
|
#ifndef _WMI_SERVICES_H_
|
|
#define _WMI_SERVICES_H_
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
|
|
|
|
typedef enum {
|
|
WMI_SERVICE_BEACON_OFFLOAD = 0, /* beacon offload */
|
|
WMI_SERVICE_SCAN_OFFLOAD = 1, /* scan offload */
|
|
WMI_SERVICE_ROAM_SCAN_OFFLOAD = 2, /* roam scan offload */
|
|
WMI_SERVICE_BCN_MISS_OFFLOAD = 3, /* beacon miss offload */
|
|
/* fake sleep + basic power save */
|
|
WMI_SERVICE_STA_PWRSAVE = 4,
|
|
WMI_SERVICE_STA_ADVANCED_PWRSAVE = 5, /* uapsd, pspoll, force sleep */
|
|
WMI_SERVICE_AP_UAPSD = 6, /* uapsd on AP */
|
|
WMI_SERVICE_AP_DFS = 7, /* DFS on AP */
|
|
WMI_SERVICE_11AC = 8, /* supports 11ac */
|
|
/* Supports triggering ADDBA/DELBA from host*/
|
|
WMI_SERVICE_BLOCKACK = 9,
|
|
WMI_SERVICE_PHYERR = 10, /* PHY error */
|
|
WMI_SERVICE_BCN_FILTER = 11, /* Beacon filter support */
|
|
/* RTT (round trip time) support */
|
|
WMI_SERVICE_RTT = 12,
|
|
WMI_SERVICE_WOW = 13, /* WOW Support */
|
|
WMI_SERVICE_RATECTRL_CACHE = 14, /* Rate-control caching */
|
|
WMI_SERVICE_IRAM_TIDS = 15, /* TIDs in IRAM */
|
|
/* ARP NS Offload support for STA vdev */
|
|
WMI_SERVICE_ARPNS_OFFLOAD = 16,
|
|
/* Network list offload service */
|
|
WMI_SERVICE_NLO = 17,
|
|
WMI_SERVICE_GTK_OFFLOAD = 18, /* GTK offload */
|
|
WMI_SERVICE_SCAN_SCH = 19, /* Scan Scheduler Service */
|
|
WMI_SERVICE_CSA_OFFLOAD = 20, /* CSA offload service */
|
|
WMI_SERVICE_CHATTER = 21, /* Chatter service */
|
|
/* FW report freq range to avoid */
|
|
WMI_SERVICE_COEX_FREQAVOID = 22,
|
|
WMI_SERVICE_PACKET_POWER_SAVE = 23, /* packet power save service */
|
|
/* Service to test the firmware recovery mechanism */
|
|
WMI_SERVICE_FORCE_FW_HANG = 24,
|
|
WMI_SERVICE_GPIO = 25, /* GPIO service */
|
|
/* Modulated DTIM support */
|
|
WMI_SERVICE_STA_DTIM_PS_MODULATED_DTIM = 26,
|
|
/**
|
|
* Basic version of station UAPSD AC Trigger Generation Method with
|
|
* variable tigger periods (service, delay, and suspend intervals)
|
|
*/
|
|
WMI_STA_UAPSD_BASIC_AUTO_TRIG = 27,
|
|
/**
|
|
* Station UAPSD AC Trigger Generation Method with variable
|
|
* trigger periods (service, delay, and suspend intervals)
|
|
*/
|
|
WMI_STA_UAPSD_VAR_AUTO_TRIG = 28,
|
|
/* Serivce to support the STA KEEP ALIVE mechanism */
|
|
WMI_SERVICE_STA_KEEP_ALIVE = 29,
|
|
/* Packet type for TX encapsulation */
|
|
WMI_SERVICE_TX_ENCAP = 30,
|
|
/* detect out-of-sync sleeping stations */
|
|
WMI_SERVICE_AP_PS_DETECT_OUT_OF_SYNC = 31,
|
|
WMI_SERVICE_EARLY_RX = 32, /* adaptive early-rx feature */
|
|
WMI_SERVICE_STA_SMPS = 33, /* STA MIMO-PS */
|
|
WMI_SERVICE_FWTEST = 34, /* Firmware test service */
|
|
WMI_SERVICE_STA_WMMAC = 35, /* STA WMMAC */
|
|
WMI_SERVICE_TDLS = 36, /* TDLS support */
|
|
WMI_SERVICE_BURST = 37, /* SIFS spaced burst support */
|
|
/* Dynamic beaocn interval change for SAP/P2p GO in MCC scenario */
|
|
WMI_SERVICE_MCC_BCN_INTERVAL_CHANGE = 38,
|
|
/* Service to support adaptive off-channel scheduler */
|
|
WMI_SERVICE_ADAPTIVE_OCS = 39,
|
|
/* target will provide Sequence number for the peer/tid combo */
|
|
WMI_SERVICE_BA_SSN_SUPPORT = 40,
|
|
WMI_SERVICE_FILTER_IPSEC_NATKEEPALIVE = 41,
|
|
WMI_SERVICE_WLAN_HB = 42, /* wlan HB service */
|
|
/* support LTE/WLAN antenna sharing */
|
|
WMI_SERVICE_LTE_ANT_SHARE_SUPPORT = 43,
|
|
WMI_SERVICE_BATCH_SCAN = 44, /*Service to support batch scan*/
|
|
WMI_SERVICE_QPOWER = 45, /* QPower service */
|
|
WMI_SERVICE_PLMREQ = 46,
|
|
WMI_SERVICE_THERMAL_MGMT = 47, /* thermal throttling support */
|
|
WMI_SERVICE_RMC = 48, /* RMC support */
|
|
/* multi-hop forwarding offload */
|
|
WMI_SERVICE_MHF_OFFLOAD = 49,
|
|
/* target support SAR tx limit from WMI_PDEV_PARAM_TXPOWER_LIMITxG */
|
|
WMI_SERVICE_COEX_SAR = 50,
|
|
/* Will support the bcn/prb rsp rate override */
|
|
WMI_SERVICE_BCN_TXRATE_OVERRIDE = 51,
|
|
WMI_SERVICE_NAN = 52, /* Neighbor Awareness Network */
|
|
/* L1SS statistics counter report */
|
|
WMI_SERVICE_L1SS_STAT = 53,
|
|
/* Linkspeed Estimation per peer */
|
|
WMI_SERVICE_ESTIMATE_LINKSPEED = 54,
|
|
/* Service to support OBSS scan */
|
|
WMI_SERVICE_OBSS_SCAN = 55,
|
|
WMI_SERVICE_TDLS_OFFCHAN = 56, /* TDLS off channel support */
|
|
/* TDLS UAPSD Buffer STA support */
|
|
WMI_SERVICE_TDLS_UAPSD_BUFFER_STA = 57,
|
|
/* TDLS UAPSD Sleep STA support */
|
|
WMI_SERVICE_TDLS_UAPSD_SLEEP_STA = 58,
|
|
WMI_SERVICE_IBSS_PWRSAVE = 59, /* IBSS power save support */
|
|
WMI_SERVICE_LPASS = 60, /*Service to support LPASS*/
|
|
WMI_SERVICE_EXTSCAN = 61, /* Extended Scans */
|
|
WMI_SERVICE_D0WOW = 62, /* D0-WOW Support */
|
|
/* Hotspot offload feature Support */
|
|
WMI_SERVICE_HSOFFLOAD = 63,
|
|
WMI_SERVICE_ROAM_HO_OFFLOAD = 64, /* roam handover offload */
|
|
/* target-based Rx full reorder */
|
|
WMI_SERVICE_RX_FULL_REORDER = 65,
|
|
WMI_SERVICE_DHCP_OFFLOAD = 66, /* DHCP offload support */
|
|
/* STA RX DATA offload to IPA support */
|
|
WMI_SERVICE_STA_RX_IPA_OFFLOAD_SUPPORT = 67,
|
|
/* mDNS responder offload support */
|
|
WMI_SERVICE_MDNS_OFFLOAD = 68,
|
|
WMI_SERVICE_SAP_AUTH_OFFLOAD = 69, /* softap auth offload */
|
|
/* Dual Band Simultaneous support */
|
|
WMI_SERVICE_DUAL_BAND_SIMULTANEOUS_SUPPORT = 70,
|
|
WMI_SERVICE_OCB = 71, /* OCB mode support */
|
|
/* arp offload support for ap mode vdev */
|
|
WMI_SERVICE_AP_ARPNS_OFFLOAD = 72,
|
|
/* Per band chainmask support */
|
|
WMI_SERVICE_PER_BAND_CHAINMASK_SUPPORT = 73,
|
|
WMI_SERVICE_PACKET_FILTER_OFFLOAD = 74, /* Per vdev packet filters */
|
|
WMI_SERVICE_MGMT_TX_HTT = 75, /* Mgmt Tx via HTT interface */
|
|
WMI_SERVICE_MGMT_TX_WMI = 76, /* Mgmt Tx via WMI interface */
|
|
/* WMI_SERVICE_READY_EXT msg follows */
|
|
WMI_SERVICE_EXT_MSG = 77,
|
|
/* Motion Aided WiFi Connectivity (MAWC)*/
|
|
WMI_SERVICE_MAWC = 78,
|
|
/* target will send ASSOC_CONF after ASSOC_CMD is processed */
|
|
WMI_SERVICE_PEER_ASSOC_CONF = 79,
|
|
WMI_SERVICE_EGAP = 80, /* enhanced green ap support */
|
|
/* FW supports 11W PMF Offload for STA */
|
|
WMI_SERVICE_STA_PMF_OFFLOAD = 81,
|
|
/* FW supports unified D0 and D3 wow */
|
|
WMI_SERVICE_UNIFIED_WOW_CAPABILITY = 82,
|
|
/* Enhanced ProxySTA mode support */
|
|
WMI_SERVICE_ENHANCED_PROXY_STA = 83,
|
|
WMI_SERVICE_ATF = 84, /* Air Time Fairness support */
|
|
WMI_SERVICE_COEX_GPIO = 85, /* BTCOEX GPIO support */
|
|
/**
|
|
* Aux Radio enhancement support for ignoring spectral scan intf
|
|
* from main radios
|
|
*/
|
|
WMI_SERVICE_AUX_SPECTRAL_INTF = 86,
|
|
/**
|
|
* Aux Radio enhancement support for ignoring chan load intf
|
|
* from main radios
|
|
*/
|
|
WMI_SERVICE_AUX_CHAN_LOAD_INTF = 87,
|
|
/**
|
|
* BSS channel info (freq, noise floor, 64-bit counters)
|
|
* event support
|
|
*/
|
|
WMI_SERVICE_BSS_CHANNEL_INFO_64 = 88,
|
|
/* Enterprise MESH Service Support */
|
|
WMI_SERVICE_ENTERPRISE_MESH = 89,
|
|
WMI_SERVICE_RESTRT_CHNL_SUPPORT = 90, /* Restricted Channel Support */
|
|
WMI_SERVICE_BPF_OFFLOAD = 91, /* FW supports bpf offload */
|
|
/* FW sends response event for Peer, Vdev delete commands */
|
|
WMI_SERVICE_SYNC_DELETE_CMDS = 92,
|
|
WMI_SERVICE_SMART_ANTENNA_SW_SUPPORT = 93,
|
|
WMI_SERVICE_SMART_ANTENNA_HW_SUPPORT = 94,
|
|
/* allow per-peer tx MCS min/max limits by host */
|
|
WMI_SERVICE_RATECTRL_LIMIT_MAX_MIN_RATES = 95,
|
|
WMI_SERVICE_NAN_DATA = 96, /* FW supports NAN data */
|
|
WMI_SERVICE_NAN_RTT = 97, /* FW supports NAN RTT */
|
|
WMI_SERVICE_11AX = 98, /* FW supports 802.11ax */
|
|
|
|
/* WMI_SERVICE_DEPRECATED_REPLACE
|
|
* FW supports these new WMI commands, to be used rather than
|
|
* deprecated matching commands:
|
|
* - WMI_PDEV_SET_PCL_CMDID (vs. WMI_SOC_SET_PCL_CMDID)
|
|
* - WMI_PDEV_SET_HW_MODE_CMDID
|
|
* (vs. WMI_SOC_SET_HW_MODE_CMDID)
|
|
* - WMI_PDEV_SET_MAC_CONFIG_CMDID
|
|
* (vs. WMI_SOC_SET_DUAL_MAC_CONFIG_CMDID)
|
|
* - WMI_PDEV_SET_ANTENNA_MODE_CMDID
|
|
* (vs. WMI_SOC_SET_ANTENNA_MODE_CMDID)
|
|
* - WMI_VDEV_SET_DSCP_TID_MAP_CMDID
|
|
* (vs. WMI_VDEV_SET_WMM_PARAMS_CMDID)
|
|
*/
|
|
WMI_SERVICE_DEPRECATED_REPLACE = 99,
|
|
/**
|
|
* FW supports a new mode that allows to run connection tracker
|
|
* in host
|
|
*/
|
|
WMI_SERVICE_TDLS_CONN_TRACKER_IN_HOST_MODE = 100,
|
|
/**
|
|
* FW supports enhanced multicast filtering (of mcast IP inside
|
|
* ucast WLAN)
|
|
*/
|
|
WMI_SERVICE_ENHANCED_MCAST_FILTER = 101,
|
|
/* periodic channel stats service */
|
|
WMI_SERVICE_PERIODIC_CHAN_STAT_SUPPORT = 102,
|
|
WMI_SERVICE_MESH_11S = 103,
|
|
/**
|
|
* FW+HW supports 10 MHz (half rate) and 5 MHz (quarter rate)
|
|
* channel bandwidth
|
|
*/
|
|
WMI_SERVICE_HALF_RATE_QUARTER_RATE_SUPPORT = 104,
|
|
/* Support per-vdev specs of which rx frames to filter out */
|
|
WMI_SERVICE_VDEV_RX_FILTER = 105,
|
|
WMI_SERVICE_P2P_LISTEN_OFFLOAD_SUPPORT = 106,
|
|
/**
|
|
* FW supports marking the first data packet which wakes
|
|
* the host from suspend
|
|
*/
|
|
WMI_SERVICE_MARK_FIRST_WAKEUP_PACKET = 107,
|
|
/* FW supports command that can add/delete multiple mcast filters */
|
|
WMI_SERVICE_MULTIPLE_MCAST_FILTER_SET = 108,
|
|
/* WMI_SERVICE_HOST_MANAGED_RX_REORDER -
|
|
* FW supports host-managed RX reorder.
|
|
* Host managed RX reorder involves RX BA state machine handling
|
|
* on peer/TID basis, REO configuration for HW based reordering/PN
|
|
* check and processing reorder exceptions generated by HW.
|
|
*/
|
|
WMI_SERVICE_HOST_MANAGED_RX_REORDER = 109,
|
|
/* Specify whether the target supports the following WMI messages
|
|
* for reading / writing its flash memory:
|
|
* WMI_READ_DATA_FROM_FLASH_CMDID,
|
|
* WMI_READ_DATA_FROM_FLASH_EVENTID,
|
|
* WMI_TRANSFER_DATA_TO_FLASH_CMDID,
|
|
* WMI_TRANSFER_DATA_TO_FLASH_COMPLETE_EVENTID,
|
|
*/
|
|
WMI_SERVICE_FLASH_RDWR_SUPPORT = 110,
|
|
WMI_SERVICE_WLAN_STATS_REPORT = 111, /* support WLAN stats report */
|
|
|
|
/* WMI_SERVICE_TX_MSDU_ID_NEW_PARTITION_SUPPORT -
|
|
* FW supports bigger MSDU ID partition which is defined as
|
|
* HTT_TX_IPA_NEW_MSDU_ID_SPACE_BEGIN. When both host and FW support
|
|
* new partition, FW uses HTT_TX_IPA_NEW_MSDU_ID_SPACE_BEGIN. If host
|
|
* doesn't support, FW falls back to HTT_TX_IPA_MSDU_ID_SPACE_BEGIN
|
|
* Handshaking is done through WMI_INIT and WMI service ready
|
|
*
|
|
* support bigger MSDU ID partition
|
|
*/
|
|
WMI_SERVICE_TX_MSDU_ID_NEW_PARTITION_SUPPORT = 112,
|
|
|
|
/*** ADD NEW SERVICES HERE UNTIL ALL VALUES UP TO 128 ARE USED ***/
|
|
|
|
WMI_MAX_SERVICE = 128, /* max service */
|
|
|
|
/**
|
|
* NOTE:
|
|
* The above service flags are delivered in the wmi_service_bitmap
|
|
* field of the WMI_SERVICE_READY_EVENT message.
|
|
* The below service flags are delivered in a
|
|
* WMI_SERVICE_AVAILABLE_EVENT message rather than in the
|
|
* WMI_SERVICE_READY_EVENT message's wmi_service_bitmap field.
|
|
* The WMI_SERVICE_AVAILABLE_EVENT message immediately precedes the
|
|
* WMI_SERVICE_READY_EVENT message.
|
|
*/
|
|
|
|
/*PUT 1ST EXT SERVICE HERE:*//*WMI_SERVICE_xxxxxxxx=128,*/
|
|
/*PUT 2ND EXT SERVICE HERE:*//*WMI_SERVICE_yyyyyyyy=129,*/
|
|
|
|
WMI_MAX_EXT_SERVICE
|
|
|
|
} WMI_SERVICE;
|
|
|
|
#define WMI_SERVICE_BM_SIZE ((WMI_MAX_SERVICE + sizeof(A_UINT32)- 1)/sizeof(A_UINT32))
|
|
|
|
#define WMI_NUM_EXT_SERVICES (WMI_MAX_EXT_SERVICE - WMI_MAX_SERVICE)
|
|
#define WMI_SERVICE_EXT_BM_SIZE32 ((WMI_NUM_EXT_SERVICES + 31) / 32)
|
|
|
|
/**
|
|
* depreciated the name WMI_SERVICE_ROAM_OFFLOAD, but here to help
|
|
* compiling with old host driver
|
|
*/
|
|
#define WMI_SERVICE_ROAM_OFFLOAD WMI_SERVICE_ROAM_SCAN_OFFLOAD
|
|
|
|
/*
|
|
* turn on the WMI service bit corresponding to the WMI service.
|
|
*/
|
|
#define WMI_SERVICE_ENABLE(pwmi_svc_bmap,svc_id) \
|
|
( (pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] |= \
|
|
(1 << ((svc_id)%(sizeof(A_UINT32)))) )
|
|
|
|
#define WMI_SERVICE_DISABLE(pwmi_svc_bmap,svc_id) \
|
|
( (pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] &= \
|
|
( ~(1 << ((svc_id)%(sizeof(A_UINT32)))) ) )
|
|
|
|
#define WMI_SERVICE_IS_ENABLED(pwmi_svc_bmap,svc_id) \
|
|
( ((pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] & \
|
|
(1 << ((svc_id)%(sizeof(A_UINT32)))) ) != 0)
|
|
|
|
#define WMI_SERVICE_EXT_ENABLE(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
|
|
do { \
|
|
if (svc_id < WMI_MAX_SERVICE) { \
|
|
WMI_SERVICE_ENABLE(pwmi_svc_bmap, svc_id); \
|
|
} else { \
|
|
int word = ((svc_id) - WMI_MAX_SERVICE) / 32; \
|
|
int bit = (svc_id) & 0x1f; /* svc_id mod 32 */ \
|
|
(pwmi_svc_ext_bmap)[word] |= (1 << bit); \
|
|
} \
|
|
} while (0)
|
|
|
|
#define WMI_SERVICE_EXT_DISABLE(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
|
|
do { \
|
|
if (svc_id < WMI_MAX_SERVICE) { \
|
|
WMI_SERVICE_DISABLE(pwmi_svc_bmap, svc_id); \
|
|
} else { \
|
|
int word = ((svc_id) - WMI_MAX_SERVICE) / 32; \
|
|
int bit = (svc_id) & 0x1f; /* svc_id mod 32 */ \
|
|
(pwmi_svc_ext_bmap)[word] &= ~(1 << bit); \
|
|
} \
|
|
} while (0)
|
|
|
|
#define WMI_SERVICE_EXT_IS_ENABLED(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
|
|
/* If the service ID is beyond the known limit, treat it as disabled */ \
|
|
((svc_id) >= WMI_MAX_EXT_SERVICE ? 0 : \
|
|
/* If service ID is in the non-extension range, use the old check */ \
|
|
(svc_id) < WMI_MAX_SERVICE ? \
|
|
WMI_SERVICE_IS_ENABLED(pwmi_svc_bmap, svc_id) : \
|
|
/* If service ID is in the extended range, check ext_bmap */ \
|
|
(pwmi_svc_ext_bmap)[((svc_id) - WMI_MAX_SERVICE) / 32] >> \
|
|
((svc_id) & 0x1f))
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
#endif /*_WMI_SERVICES_H_*/
|