wmi_services.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359
  1. /*
  2. * Copyright (c) 2011-2016 The Linux Foundation. All rights reserved.
  3. *
  4. * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  5. *
  6. *
  7. * Permission to use, copy, modify, and/or distribute this software for
  8. * any purpose with or without fee is hereby granted, provided that the
  9. * above copyright notice and this permission notice appear in all
  10. * copies.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  13. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  14. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  15. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  16. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  17. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  18. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  19. * PERFORMANCE OF THIS SOFTWARE.
  20. */
  21. /*
  22. * This file was originally distributed by Qualcomm Atheros, Inc.
  23. * under proprietary terms before Copyright ownership was assigned
  24. * to the Linux Foundation.
  25. */
  26. /**
  27. * This file defines WMI services bitmap and the set of WMI services .
  28. * defines macrso to set/clear/get different service bits from the bitmap.
  29. * the service bitmap is sent up to the host via WMI_READY command.
  30. *
  31. */
  32. #ifndef _WMI_SERVICES_H_
  33. #define _WMI_SERVICES_H_
  34. #ifdef __cplusplus
  35. extern "C" {
  36. #endif
  37. typedef enum {
  38. WMI_SERVICE_BEACON_OFFLOAD = 0, /* beacon offload */
  39. WMI_SERVICE_SCAN_OFFLOAD = 1, /* scan offload */
  40. WMI_SERVICE_ROAM_SCAN_OFFLOAD = 2, /* roam scan offload */
  41. WMI_SERVICE_BCN_MISS_OFFLOAD = 3, /* beacon miss offload */
  42. /* fake sleep + basic power save */
  43. WMI_SERVICE_STA_PWRSAVE = 4,
  44. WMI_SERVICE_STA_ADVANCED_PWRSAVE = 5, /* uapsd, pspoll, force sleep */
  45. WMI_SERVICE_AP_UAPSD = 6, /* uapsd on AP */
  46. WMI_SERVICE_AP_DFS = 7, /* DFS on AP */
  47. WMI_SERVICE_11AC = 8, /* supports 11ac */
  48. /* Supports triggering ADDBA/DELBA from host*/
  49. WMI_SERVICE_BLOCKACK = 9,
  50. WMI_SERVICE_PHYERR = 10, /* PHY error */
  51. WMI_SERVICE_BCN_FILTER = 11, /* Beacon filter support */
  52. /* RTT (round trip time) support */
  53. WMI_SERVICE_RTT = 12,
  54. WMI_SERVICE_WOW = 13, /* WOW Support */
  55. WMI_SERVICE_RATECTRL_CACHE = 14, /* Rate-control caching */
  56. WMI_SERVICE_IRAM_TIDS = 15, /* TIDs in IRAM */
  57. /* ARP NS Offload support for STA vdev */
  58. WMI_SERVICE_ARPNS_OFFLOAD = 16,
  59. /* Network list offload service */
  60. WMI_SERVICE_NLO = 17,
  61. WMI_SERVICE_GTK_OFFLOAD = 18, /* GTK offload */
  62. WMI_SERVICE_SCAN_SCH = 19, /* Scan Scheduler Service */
  63. WMI_SERVICE_CSA_OFFLOAD = 20, /* CSA offload service */
  64. WMI_SERVICE_CHATTER = 21, /* Chatter service */
  65. /* FW report freq range to avoid */
  66. WMI_SERVICE_COEX_FREQAVOID = 22,
  67. WMI_SERVICE_PACKET_POWER_SAVE = 23, /* packet power save service */
  68. /* Service to test the firmware recovery mechanism */
  69. WMI_SERVICE_FORCE_FW_HANG = 24,
  70. WMI_SERVICE_GPIO = 25, /* GPIO service */
  71. /* Modulated DTIM support */
  72. WMI_SERVICE_STA_DTIM_PS_MODULATED_DTIM = 26,
  73. /**
  74. * Basic version of station UAPSD AC Trigger Generation Method with
  75. * variable tigger periods (service, delay, and suspend intervals)
  76. */
  77. WMI_STA_UAPSD_BASIC_AUTO_TRIG = 27,
  78. /**
  79. * Station UAPSD AC Trigger Generation Method with variable
  80. * trigger periods (service, delay, and suspend intervals)
  81. */
  82. WMI_STA_UAPSD_VAR_AUTO_TRIG = 28,
  83. /* Serivce to support the STA KEEP ALIVE mechanism */
  84. WMI_SERVICE_STA_KEEP_ALIVE = 29,
  85. /* Packet type for TX encapsulation */
  86. WMI_SERVICE_TX_ENCAP = 30,
  87. /* detect out-of-sync sleeping stations */
  88. WMI_SERVICE_AP_PS_DETECT_OUT_OF_SYNC = 31,
  89. WMI_SERVICE_EARLY_RX = 32, /* adaptive early-rx feature */
  90. WMI_SERVICE_STA_SMPS = 33, /* STA MIMO-PS */
  91. WMI_SERVICE_FWTEST = 34, /* Firmware test service */
  92. WMI_SERVICE_STA_WMMAC = 35, /* STA WMMAC */
  93. WMI_SERVICE_TDLS = 36, /* TDLS support */
  94. WMI_SERVICE_BURST = 37, /* SIFS spaced burst support */
  95. /* Dynamic beaocn interval change for SAP/P2p GO in MCC scenario */
  96. WMI_SERVICE_MCC_BCN_INTERVAL_CHANGE = 38,
  97. /* Service to support adaptive off-channel scheduler */
  98. WMI_SERVICE_ADAPTIVE_OCS = 39,
  99. /* target will provide Sequence number for the peer/tid combo */
  100. WMI_SERVICE_BA_SSN_SUPPORT = 40,
  101. WMI_SERVICE_FILTER_IPSEC_NATKEEPALIVE = 41,
  102. WMI_SERVICE_WLAN_HB = 42, /* wlan HB service */
  103. /* support LTE/WLAN antenna sharing */
  104. WMI_SERVICE_LTE_ANT_SHARE_SUPPORT = 43,
  105. WMI_SERVICE_BATCH_SCAN = 44, /*Service to support batch scan*/
  106. WMI_SERVICE_QPOWER = 45, /* QPower service */
  107. WMI_SERVICE_PLMREQ = 46,
  108. WMI_SERVICE_THERMAL_MGMT = 47, /* thermal throttling support */
  109. WMI_SERVICE_RMC = 48, /* RMC support */
  110. /* multi-hop forwarding offload */
  111. WMI_SERVICE_MHF_OFFLOAD = 49,
  112. /* target support SAR tx limit from WMI_PDEV_PARAM_TXPOWER_LIMITxG */
  113. WMI_SERVICE_COEX_SAR = 50,
  114. /* Will support the bcn/prb rsp rate override */
  115. WMI_SERVICE_BCN_TXRATE_OVERRIDE = 51,
  116. WMI_SERVICE_NAN = 52, /* Neighbor Awareness Network */
  117. /* L1SS statistics counter report */
  118. WMI_SERVICE_L1SS_STAT = 53,
  119. /* Linkspeed Estimation per peer */
  120. WMI_SERVICE_ESTIMATE_LINKSPEED = 54,
  121. /* Service to support OBSS scan */
  122. WMI_SERVICE_OBSS_SCAN = 55,
  123. WMI_SERVICE_TDLS_OFFCHAN = 56, /* TDLS off channel support */
  124. /* TDLS UAPSD Buffer STA support */
  125. WMI_SERVICE_TDLS_UAPSD_BUFFER_STA = 57,
  126. /* TDLS UAPSD Sleep STA support */
  127. WMI_SERVICE_TDLS_UAPSD_SLEEP_STA = 58,
  128. WMI_SERVICE_IBSS_PWRSAVE = 59, /* IBSS power save support */
  129. WMI_SERVICE_LPASS = 60, /*Service to support LPASS*/
  130. WMI_SERVICE_EXTSCAN = 61, /* Extended Scans */
  131. WMI_SERVICE_D0WOW = 62, /* D0-WOW Support */
  132. /* Hotspot offload feature Support */
  133. WMI_SERVICE_HSOFFLOAD = 63,
  134. WMI_SERVICE_ROAM_HO_OFFLOAD = 64, /* roam handover offload */
  135. /* target-based Rx full reorder */
  136. WMI_SERVICE_RX_FULL_REORDER = 65,
  137. WMI_SERVICE_DHCP_OFFLOAD = 66, /* DHCP offload support */
  138. /* STA RX DATA offload to IPA support */
  139. WMI_SERVICE_STA_RX_IPA_OFFLOAD_SUPPORT = 67,
  140. /* mDNS responder offload support */
  141. WMI_SERVICE_MDNS_OFFLOAD = 68,
  142. WMI_SERVICE_SAP_AUTH_OFFLOAD = 69, /* softap auth offload */
  143. /* Dual Band Simultaneous support */
  144. WMI_SERVICE_DUAL_BAND_SIMULTANEOUS_SUPPORT = 70,
  145. WMI_SERVICE_OCB = 71, /* OCB mode support */
  146. /* arp offload support for ap mode vdev */
  147. WMI_SERVICE_AP_ARPNS_OFFLOAD = 72,
  148. /* Per band chainmask support */
  149. WMI_SERVICE_PER_BAND_CHAINMASK_SUPPORT = 73,
  150. WMI_SERVICE_PACKET_FILTER_OFFLOAD = 74, /* Per vdev packet filters */
  151. WMI_SERVICE_MGMT_TX_HTT = 75, /* Mgmt Tx via HTT interface */
  152. WMI_SERVICE_MGMT_TX_WMI = 76, /* Mgmt Tx via WMI interface */
  153. /* WMI_SERVICE_READY_EXT msg follows */
  154. WMI_SERVICE_EXT_MSG = 77,
  155. /* Motion Aided WiFi Connectivity (MAWC)*/
  156. WMI_SERVICE_MAWC = 78,
  157. /* target will send ASSOC_CONF after ASSOC_CMD is processed */
  158. WMI_SERVICE_PEER_ASSOC_CONF = 79,
  159. WMI_SERVICE_EGAP = 80, /* enhanced green ap support */
  160. /* FW supports 11W PMF Offload for STA */
  161. WMI_SERVICE_STA_PMF_OFFLOAD = 81,
  162. /* FW supports unified D0 and D3 wow */
  163. WMI_SERVICE_UNIFIED_WOW_CAPABILITY = 82,
  164. /* Enhanced ProxySTA mode support */
  165. WMI_SERVICE_ENHANCED_PROXY_STA = 83,
  166. WMI_SERVICE_ATF = 84, /* Air Time Fairness support */
  167. WMI_SERVICE_COEX_GPIO = 85, /* BTCOEX GPIO support */
  168. /**
  169. * Aux Radio enhancement support for ignoring spectral scan intf
  170. * from main radios
  171. */
  172. WMI_SERVICE_AUX_SPECTRAL_INTF = 86,
  173. /**
  174. * Aux Radio enhancement support for ignoring chan load intf
  175. * from main radios
  176. */
  177. WMI_SERVICE_AUX_CHAN_LOAD_INTF = 87,
  178. /**
  179. * BSS channel info (freq, noise floor, 64-bit counters)
  180. * event support
  181. */
  182. WMI_SERVICE_BSS_CHANNEL_INFO_64 = 88,
  183. /* Enterprise MESH Service Support */
  184. WMI_SERVICE_ENTERPRISE_MESH = 89,
  185. WMI_SERVICE_RESTRT_CHNL_SUPPORT = 90, /* Restricted Channel Support */
  186. WMI_SERVICE_BPF_OFFLOAD = 91, /* FW supports bpf offload */
  187. /* FW sends response event for Peer, Vdev delete commands */
  188. WMI_SERVICE_SYNC_DELETE_CMDS = 92,
  189. WMI_SERVICE_SMART_ANTENNA_SW_SUPPORT = 93,
  190. WMI_SERVICE_SMART_ANTENNA_HW_SUPPORT = 94,
  191. /* allow per-peer tx MCS min/max limits by host */
  192. WMI_SERVICE_RATECTRL_LIMIT_MAX_MIN_RATES = 95,
  193. WMI_SERVICE_NAN_DATA = 96, /* FW supports NAN data */
  194. WMI_SERVICE_NAN_RTT = 97, /* FW supports NAN RTT */
  195. WMI_SERVICE_11AX = 98, /* FW supports 802.11ax */
  196. /* WMI_SERVICE_DEPRECATED_REPLACE
  197. * FW supports these new WMI commands, to be used rather than
  198. * deprecated matching commands:
  199. * - WMI_PDEV_SET_PCL_CMDID (vs. WMI_SOC_SET_PCL_CMDID)
  200. * - WMI_PDEV_SET_HW_MODE_CMDID
  201. * (vs. WMI_SOC_SET_HW_MODE_CMDID)
  202. * - WMI_PDEV_SET_MAC_CONFIG_CMDID
  203. * (vs. WMI_SOC_SET_DUAL_MAC_CONFIG_CMDID)
  204. * - WMI_PDEV_SET_ANTENNA_MODE_CMDID
  205. * (vs. WMI_SOC_SET_ANTENNA_MODE_CMDID)
  206. * - WMI_VDEV_SET_DSCP_TID_MAP_CMDID
  207. * (vs. WMI_VDEV_SET_WMM_PARAMS_CMDID)
  208. */
  209. WMI_SERVICE_DEPRECATED_REPLACE = 99,
  210. /**
  211. * FW supports a new mode that allows to run connection tracker
  212. * in host
  213. */
  214. WMI_SERVICE_TDLS_CONN_TRACKER_IN_HOST_MODE = 100,
  215. /**
  216. * FW supports enhanced multicast filtering (of mcast IP inside
  217. * ucast WLAN)
  218. */
  219. WMI_SERVICE_ENHANCED_MCAST_FILTER = 101,
  220. /* periodic channel stats service */
  221. WMI_SERVICE_PERIODIC_CHAN_STAT_SUPPORT = 102,
  222. WMI_SERVICE_MESH_11S = 103,
  223. /**
  224. * FW+HW supports 10 MHz (half rate) and 5 MHz (quarter rate)
  225. * channel bandwidth
  226. */
  227. WMI_SERVICE_HALF_RATE_QUARTER_RATE_SUPPORT = 104,
  228. /* Support per-vdev specs of which rx frames to filter out */
  229. WMI_SERVICE_VDEV_RX_FILTER = 105,
  230. WMI_SERVICE_P2P_LISTEN_OFFLOAD_SUPPORT = 106,
  231. /**
  232. * FW supports marking the first data packet which wakes
  233. * the host from suspend
  234. */
  235. WMI_SERVICE_MARK_FIRST_WAKEUP_PACKET = 107,
  236. /* FW supports command that can add/delete multiple mcast filters */
  237. WMI_SERVICE_MULTIPLE_MCAST_FILTER_SET = 108,
  238. /* WMI_SERVICE_HOST_MANAGED_RX_REORDER -
  239. * FW supports host-managed RX reorder.
  240. * Host managed RX reorder involves RX BA state machine handling
  241. * on peer/TID basis, REO configuration for HW based reordering/PN
  242. * check and processing reorder exceptions generated by HW.
  243. */
  244. WMI_SERVICE_HOST_MANAGED_RX_REORDER = 109,
  245. /* Specify whether the target supports the following WMI messages
  246. * for reading / writing its flash memory:
  247. * WMI_READ_DATA_FROM_FLASH_CMDID,
  248. * WMI_READ_DATA_FROM_FLASH_EVENTID,
  249. * WMI_TRANSFER_DATA_TO_FLASH_CMDID,
  250. * WMI_TRANSFER_DATA_TO_FLASH_COMPLETE_EVENTID,
  251. */
  252. WMI_SERVICE_FLASH_RDWR_SUPPORT = 110,
  253. WMI_SERVICE_WLAN_STATS_REPORT = 111, /* support WLAN stats report */
  254. /* WMI_SERVICE_TX_MSDU_ID_NEW_PARTITION_SUPPORT -
  255. * FW supports bigger MSDU ID partition which is defined as
  256. * HTT_TX_IPA_NEW_MSDU_ID_SPACE_BEGIN. When both host and FW support
  257. * new partition, FW uses HTT_TX_IPA_NEW_MSDU_ID_SPACE_BEGIN. If host
  258. * doesn't support, FW falls back to HTT_TX_IPA_MSDU_ID_SPACE_BEGIN
  259. * Handshaking is done through WMI_INIT and WMI service ready
  260. *
  261. * support bigger MSDU ID partition
  262. */
  263. WMI_SERVICE_TX_MSDU_ID_NEW_PARTITION_SUPPORT = 112,
  264. WMI_SERVICE_DFS_PHYERR_OFFLOAD = 113,
  265. /*** ADD NEW SERVICES HERE UNTIL ALL VALUES UP TO 128 ARE USED ***/
  266. WMI_MAX_SERVICE = 128, /* max service */
  267. /**
  268. * NOTE:
  269. * The above service flags are delivered in the wmi_service_bitmap
  270. * field of the WMI_SERVICE_READY_EVENT message.
  271. * The below service flags are delivered in a
  272. * WMI_SERVICE_AVAILABLE_EVENT message rather than in the
  273. * WMI_SERVICE_READY_EVENT message's wmi_service_bitmap field.
  274. * The WMI_SERVICE_AVAILABLE_EVENT message immediately precedes the
  275. * WMI_SERVICE_READY_EVENT message.
  276. */
  277. /*PUT 1ST EXT SERVICE HERE:*//*WMI_SERVICE_xxxxxxxx=128,*/
  278. /*PUT 2ND EXT SERVICE HERE:*//*WMI_SERVICE_yyyyyyyy=129,*/
  279. WMI_MAX_EXT_SERVICE
  280. } WMI_SERVICE;
  281. #define WMI_SERVICE_BM_SIZE ((WMI_MAX_SERVICE + sizeof(A_UINT32)- 1)/sizeof(A_UINT32))
  282. #define WMI_NUM_EXT_SERVICES (WMI_MAX_EXT_SERVICE - WMI_MAX_SERVICE)
  283. #define WMI_SERVICE_EXT_BM_SIZE32 ((WMI_NUM_EXT_SERVICES + 31) / 32)
  284. /**
  285. * depreciated the name WMI_SERVICE_ROAM_OFFLOAD, but here to help
  286. * compiling with old host driver
  287. */
  288. #define WMI_SERVICE_ROAM_OFFLOAD WMI_SERVICE_ROAM_SCAN_OFFLOAD
  289. /*
  290. * turn on the WMI service bit corresponding to the WMI service.
  291. */
  292. #define WMI_SERVICE_ENABLE(pwmi_svc_bmap,svc_id) \
  293. ( (pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] |= \
  294. (1 << ((svc_id)%(sizeof(A_UINT32)))) )
  295. #define WMI_SERVICE_DISABLE(pwmi_svc_bmap,svc_id) \
  296. ( (pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] &= \
  297. ( ~(1 << ((svc_id)%(sizeof(A_UINT32)))) ) )
  298. #define WMI_SERVICE_IS_ENABLED(pwmi_svc_bmap,svc_id) \
  299. ( ((pwmi_svc_bmap)[(svc_id)/(sizeof(A_UINT32))] & \
  300. (1 << ((svc_id)%(sizeof(A_UINT32)))) ) != 0)
  301. #define WMI_SERVICE_EXT_ENABLE(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
  302. do { \
  303. if (svc_id < WMI_MAX_SERVICE) { \
  304. WMI_SERVICE_ENABLE(pwmi_svc_bmap, svc_id); \
  305. } else { \
  306. int word = ((svc_id) - WMI_MAX_SERVICE) / 32; \
  307. int bit = (svc_id) & 0x1f; /* svc_id mod 32 */ \
  308. (pwmi_svc_ext_bmap)[word] |= (1 << bit); \
  309. } \
  310. } while (0)
  311. #define WMI_SERVICE_EXT_DISABLE(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
  312. do { \
  313. if (svc_id < WMI_MAX_SERVICE) { \
  314. WMI_SERVICE_DISABLE(pwmi_svc_bmap, svc_id); \
  315. } else { \
  316. int word = ((svc_id) - WMI_MAX_SERVICE) / 32; \
  317. int bit = (svc_id) & 0x1f; /* svc_id mod 32 */ \
  318. (pwmi_svc_ext_bmap)[word] &= ~(1 << bit); \
  319. } \
  320. } while (0)
  321. #define WMI_SERVICE_EXT_IS_ENABLED(pwmi_svc_bmap, pwmi_svc_ext_bmap, svc_id) \
  322. /* If the service ID is beyond the known limit, treat it as disabled */ \
  323. ((svc_id) >= WMI_MAX_EXT_SERVICE ? 0 : \
  324. /* If service ID is in the non-extension range, use the old check */ \
  325. (svc_id) < WMI_MAX_SERVICE ? \
  326. WMI_SERVICE_IS_ENABLED(pwmi_svc_bmap, svc_id) : \
  327. /* If service ID is in the extended range, check ext_bmap */ \
  328. (pwmi_svc_ext_bmap)[((svc_id) - WMI_MAX_SERVICE) / 32] >> \
  329. ((svc_id) & 0x1f))
  330. #ifdef __cplusplus
  331. }
  332. #endif
  333. #endif /*_WMI_SERVICES_H_*/