wmi.h 29 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352
  1. /*
  2. * Copyright (c) 2012-2014 Qualcomm Atheros, Inc.
  3. * Copyright (c) 2006-2012 Wilocity .
  4. *
  5. * Permission to use, copy, modify, and/or distribute this software for any
  6. * purpose with or without fee is hereby granted, provided that the above
  7. * copyright notice and this permission notice appear in all copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  10. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  11. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  12. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  13. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  14. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  15. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  16. */
  17. /*
  18. * This file contains the definitions of the WMI protocol specified in the
  19. * Wireless Module Interface (WMI) for the Wilocity
  20. * MARLON 60 Gigabit wireless solution.
  21. * It includes definitions of all the commands and events.
  22. * Commands are messages from the host to the WM.
  23. * Events are messages from the WM to the host.
  24. */
  25. #ifndef __WILOCITY_WMI_H__
  26. #define __WILOCITY_WMI_H__
  27. /* General */
  28. #define WILOCITY_MAX_ASSOC_STA (8)
  29. #define WILOCITY_DEFAULT_ASSOC_STA (1)
  30. #define WMI_MAC_LEN (6)
  31. #define WMI_PROX_RANGE_NUM (3)
  32. #define WMI_MAX_LOSS_DMG_BEACONS (32)
  33. /* List of Commands */
  34. enum wmi_command_id {
  35. WMI_CONNECT_CMDID = 0x0001,
  36. WMI_DISCONNECT_CMDID = 0x0003,
  37. WMI_DISCONNECT_STA_CMDID = 0x0004,
  38. WMI_START_SCAN_CMDID = 0x0007,
  39. WMI_SET_BSS_FILTER_CMDID = 0x0009,
  40. WMI_SET_PROBED_SSID_CMDID = 0x000a,
  41. WMI_SET_LISTEN_INT_CMDID = 0x000b,
  42. WMI_BCON_CTRL_CMDID = 0x000f,
  43. WMI_ADD_CIPHER_KEY_CMDID = 0x0016,
  44. WMI_DELETE_CIPHER_KEY_CMDID = 0x0017,
  45. WMI_SET_APPIE_CMDID = 0x003f,
  46. WMI_SET_WSC_STATUS_CMDID = 0x0041,
  47. WMI_PXMT_RANGE_CFG_CMDID = 0x0042,
  48. WMI_PXMT_SNR2_RANGE_CFG_CMDID = 0x0043,
  49. /* WMI_FAST_MEM_ACC_MODE_CMDID = 0x0300, */
  50. WMI_MEM_READ_CMDID = 0x0800,
  51. WMI_MEM_WR_CMDID = 0x0801,
  52. WMI_ECHO_CMDID = 0x0803,
  53. WMI_DEEP_ECHO_CMDID = 0x0804,
  54. WMI_CONFIG_MAC_CMDID = 0x0805,
  55. WMI_CONFIG_PHY_DEBUG_CMDID = 0x0806,
  56. WMI_ADD_DEBUG_TX_PCKT_CMDID = 0x0808,
  57. WMI_PHY_GET_STATISTICS_CMDID = 0x0809,
  58. WMI_FS_TUNE_CMDID = 0x080a,
  59. WMI_CORR_MEASURE_CMDID = 0x080b,
  60. WMI_READ_RSSI_CMDID = 0x080c,
  61. WMI_TEMP_SENSE_CMDID = 0x080e,
  62. WMI_DC_CALIB_CMDID = 0x080f,
  63. WMI_SEND_TONE_CMDID = 0x0810,
  64. WMI_IQ_TX_CALIB_CMDID = 0x0811,
  65. WMI_IQ_RX_CALIB_CMDID = 0x0812,
  66. WMI_SET_UCODE_IDLE_CMDID = 0x0813,
  67. WMI_SET_WORK_MODE_CMDID = 0x0815,
  68. WMI_LO_LEAKAGE_CALIB_CMDID = 0x0816,
  69. WMI_MARLON_R_READ_CMDID = 0x0818,
  70. WMI_MARLON_R_WRITE_CMDID = 0x0819,
  71. WMI_MARLON_R_TXRX_SEL_CMDID = 0x081a,
  72. MAC_IO_STATIC_PARAMS_CMDID = 0x081b,
  73. MAC_IO_DYNAMIC_PARAMS_CMDID = 0x081c,
  74. WMI_SILENT_RSSI_CALIB_CMDID = 0x081d,
  75. WMI_RF_RX_TEST_CMDID = 0x081e,
  76. WMI_CFG_RX_CHAIN_CMDID = 0x0820,
  77. WMI_VRING_CFG_CMDID = 0x0821,
  78. WMI_BCAST_VRING_CFG_CMDID = 0x0822,
  79. WMI_VRING_BA_EN_CMDID = 0x0823,
  80. WMI_VRING_BA_DIS_CMDID = 0x0824,
  81. WMI_RCP_ADDBA_RESP_CMDID = 0x0825,
  82. WMI_RCP_DELBA_CMDID = 0x0826,
  83. WMI_SET_SSID_CMDID = 0x0827,
  84. WMI_GET_SSID_CMDID = 0x0828,
  85. WMI_SET_PCP_CHANNEL_CMDID = 0x0829,
  86. WMI_GET_PCP_CHANNEL_CMDID = 0x082a,
  87. WMI_SW_TX_REQ_CMDID = 0x082b,
  88. WMI_READ_MAC_RXQ_CMDID = 0x0830,
  89. WMI_READ_MAC_TXQ_CMDID = 0x0831,
  90. WMI_WRITE_MAC_RXQ_CMDID = 0x0832,
  91. WMI_WRITE_MAC_TXQ_CMDID = 0x0833,
  92. WMI_WRITE_MAC_XQ_FIELD_CMDID = 0x0834,
  93. WMI_MLME_PUSH_CMDID = 0x0835,
  94. WMI_BEAMFORMING_MGMT_CMDID = 0x0836,
  95. WMI_BF_TXSS_MGMT_CMDID = 0x0837,
  96. WMI_BF_SM_MGMT_CMDID = 0x0838,
  97. WMI_BF_RXSS_MGMT_CMDID = 0x0839,
  98. WMI_BF_TRIG_CMDID = 0x083A,
  99. WMI_SET_SECTORS_CMDID = 0x0849,
  100. WMI_MAINTAIN_PAUSE_CMDID = 0x0850,
  101. WMI_MAINTAIN_RESUME_CMDID = 0x0851,
  102. WMI_RS_MGMT_CMDID = 0x0852,
  103. WMI_RF_MGMT_CMDID = 0x0853,
  104. WMI_THERMAL_THROTTLING_CTRL_CMDID = 0x0854,
  105. WMI_THERMAL_THROTTLING_GET_STATUS_CMDID = 0x0855,
  106. /* Performance monitoring commands */
  107. WMI_BF_CTRL_CMDID = 0x0862,
  108. WMI_NOTIFY_REQ_CMDID = 0x0863,
  109. WMI_GET_STATUS_CMDID = 0x0864,
  110. WMI_UNIT_TEST_CMDID = 0x0900,
  111. WMI_HICCUP_CMDID = 0x0901,
  112. WMI_FLASH_READ_CMDID = 0x0902,
  113. WMI_FLASH_WRITE_CMDID = 0x0903,
  114. WMI_SECURITY_UNIT_TEST_CMDID = 0x0904,
  115. /*P2P*/
  116. WMI_P2P_CFG_CMDID = 0x0910,
  117. WMI_PORT_ALLOCATE_CMDID = 0x0911,
  118. WMI_PORT_DELETE_CMDID = 0x0912,
  119. WMI_POWER_MGMT_CFG_CMDID = 0x0913,
  120. WMI_START_LISTEN_CMDID = 0x0914,
  121. WMI_START_SEARCH_CMDID = 0x0915,
  122. WMI_DISCOVERY_START_CMDID = 0x0916,
  123. WMI_DISCOVERY_STOP_CMDID = 0x0917,
  124. WMI_PCP_START_CMDID = 0x0918,
  125. WMI_PCP_STOP_CMDID = 0x0919,
  126. WMI_GET_PCP_FACTOR_CMDID = 0x091b,
  127. WMI_SET_MAC_ADDRESS_CMDID = 0xf003,
  128. WMI_ABORT_SCAN_CMDID = 0xf007,
  129. WMI_SET_PMK_CMDID = 0xf028,
  130. WMI_SET_PROMISCUOUS_MODE_CMDID = 0xf041,
  131. WMI_GET_PMK_CMDID = 0xf048,
  132. WMI_SET_PASSPHRASE_CMDID = 0xf049,
  133. WMI_SEND_ASSOC_RES_CMDID = 0xf04a,
  134. WMI_SET_ASSOC_REQ_RELAY_CMDID = 0xf04b,
  135. WMI_EAPOL_TX_CMDID = 0xf04c,
  136. WMI_MAC_ADDR_REQ_CMDID = 0xf04d,
  137. WMI_FW_VER_CMDID = 0xf04e,
  138. WMI_PMC_CMDID = 0xf04f,
  139. };
  140. /*
  141. * Commands data structures
  142. */
  143. /*
  144. * WMI_CONNECT_CMDID
  145. */
  146. enum wmi_network_type {
  147. WMI_NETTYPE_INFRA = 0x01,
  148. WMI_NETTYPE_ADHOC = 0x02,
  149. WMI_NETTYPE_ADHOC_CREATOR = 0x04,
  150. WMI_NETTYPE_AP = 0x10,
  151. WMI_NETTYPE_P2P = 0x20,
  152. WMI_NETTYPE_WBE = 0x40, /* PCIE over 60g */
  153. };
  154. enum wmi_dot11_auth_mode {
  155. WMI_AUTH11_OPEN = 0x01,
  156. WMI_AUTH11_SHARED = 0x02,
  157. WMI_AUTH11_LEAP = 0x04,
  158. WMI_AUTH11_WSC = 0x08,
  159. };
  160. enum wmi_auth_mode {
  161. WMI_AUTH_NONE = 0x01,
  162. WMI_AUTH_WPA = 0x02,
  163. WMI_AUTH_WPA2 = 0x04,
  164. WMI_AUTH_WPA_PSK = 0x08,
  165. WMI_AUTH_WPA2_PSK = 0x10,
  166. WMI_AUTH_WPA_CCKM = 0x20,
  167. WMI_AUTH_WPA2_CCKM = 0x40,
  168. };
  169. enum wmi_crypto_type {
  170. WMI_CRYPT_NONE = 0x01,
  171. WMI_CRYPT_WEP = 0x02,
  172. WMI_CRYPT_TKIP = 0x04,
  173. WMI_CRYPT_AES = 0x08,
  174. WMI_CRYPT_AES_GCMP = 0x20,
  175. };
  176. enum wmi_connect_ctrl_flag_bits {
  177. WMI_CONNECT_ASSOC_POLICY_USER = 0x0001,
  178. WMI_CONNECT_SEND_REASSOC = 0x0002,
  179. WMI_CONNECT_IGNORE_WPA_GROUP_CIPHER = 0x0004,
  180. WMI_CONNECT_PROFILE_MATCH_DONE = 0x0008,
  181. WMI_CONNECT_IGNORE_AAC_BEACON = 0x0010,
  182. WMI_CONNECT_CSA_FOLLOW_BSS = 0x0020,
  183. WMI_CONNECT_DO_WPA_OFFLOAD = 0x0040,
  184. WMI_CONNECT_DO_NOT_DEAUTH = 0x0080,
  185. };
  186. #define WMI_MAX_SSID_LEN (32)
  187. struct wmi_connect_cmd {
  188. u8 network_type;
  189. u8 dot11_auth_mode;
  190. u8 auth_mode;
  191. u8 pairwise_crypto_type;
  192. u8 pairwise_crypto_len;
  193. u8 group_crypto_type;
  194. u8 group_crypto_len;
  195. u8 ssid_len;
  196. u8 ssid[WMI_MAX_SSID_LEN];
  197. u8 channel;
  198. u8 reserved0;
  199. u8 bssid[WMI_MAC_LEN];
  200. __le32 ctrl_flags;
  201. u8 dst_mac[WMI_MAC_LEN];
  202. u8 reserved1[2];
  203. } __packed;
  204. /*
  205. * WMI_DISCONNECT_STA_CMDID
  206. */
  207. struct wmi_disconnect_sta_cmd {
  208. u8 dst_mac[WMI_MAC_LEN];
  209. __le16 disconnect_reason;
  210. } __packed;
  211. /*
  212. * WMI_SET_PMK_CMDID
  213. */
  214. #define WMI_MIN_KEY_INDEX (0)
  215. #define WMI_MAX_KEY_INDEX (3)
  216. #define WMI_MAX_KEY_LEN (32)
  217. #define WMI_PASSPHRASE_LEN (64)
  218. #define WMI_PMK_LEN (32)
  219. struct wmi_set_pmk_cmd {
  220. u8 pmk[WMI_PMK_LEN];
  221. } __packed;
  222. /*
  223. * WMI_SET_PASSPHRASE_CMDID
  224. */
  225. struct wmi_set_passphrase_cmd {
  226. u8 ssid[WMI_MAX_SSID_LEN];
  227. u8 passphrase[WMI_PASSPHRASE_LEN];
  228. u8 ssid_len;
  229. u8 passphrase_len;
  230. } __packed;
  231. /*
  232. * WMI_ADD_CIPHER_KEY_CMDID
  233. */
  234. enum wmi_key_usage {
  235. WMI_KEY_USE_PAIRWISE = 0,
  236. WMI_KEY_USE_GROUP = 1,
  237. WMI_KEY_USE_TX = 2, /* default Tx Key - Static WEP only */
  238. };
  239. struct wmi_add_cipher_key_cmd {
  240. u8 key_index;
  241. u8 key_type;
  242. u8 key_usage; /* enum wmi_key_usage */
  243. u8 key_len;
  244. u8 key_rsc[8]; /* key replay sequence counter */
  245. u8 key[WMI_MAX_KEY_LEN];
  246. u8 key_op_ctrl; /* Additional Key Control information */
  247. u8 mac[WMI_MAC_LEN];
  248. } __packed;
  249. /*
  250. * WMI_DELETE_CIPHER_KEY_CMDID
  251. */
  252. struct wmi_delete_cipher_key_cmd {
  253. u8 key_index;
  254. u8 mac[WMI_MAC_LEN];
  255. } __packed;
  256. /*
  257. * WMI_START_SCAN_CMDID
  258. *
  259. * Start L1 scan operation
  260. *
  261. * Returned events:
  262. * - WMI_RX_MGMT_PACKET_EVENTID - for every probe resp.
  263. * - WMI_SCAN_COMPLETE_EVENTID
  264. */
  265. enum wmi_scan_type {
  266. WMI_LONG_SCAN = 0,
  267. WMI_SHORT_SCAN = 1,
  268. WMI_PBC_SCAN = 2,
  269. WMI_DIRECT_SCAN = 3,
  270. WMI_ACTIVE_SCAN = 4,
  271. };
  272. struct wmi_start_scan_cmd {
  273. u8 direct_scan_mac_addr[6];
  274. u8 reserved[2];
  275. __le32 home_dwell_time; /* Max duration in the home channel(ms) */
  276. __le32 force_scan_interval; /* Time interval between scans (ms)*/
  277. u8 scan_type; /* wmi_scan_type */
  278. u8 num_channels; /* how many channels follow */
  279. struct {
  280. u8 channel;
  281. u8 reserved;
  282. } channel_list[0]; /* channels ID's */
  283. /* 0 - 58320 MHz */
  284. /* 1 - 60480 MHz */
  285. /* 2 - 62640 MHz */
  286. } __packed;
  287. /*
  288. * WMI_SET_PROBED_SSID_CMDID
  289. */
  290. #define MAX_PROBED_SSID_INDEX (3)
  291. enum wmi_ssid_flag {
  292. WMI_SSID_FLAG_DISABLE = 0, /* disables entry */
  293. WMI_SSID_FLAG_SPECIFIC = 1, /* probes specified ssid */
  294. WMI_SSID_FLAG_ANY = 2, /* probes for any ssid */
  295. };
  296. struct wmi_probed_ssid_cmd {
  297. u8 entry_index; /* 0 to MAX_PROBED_SSID_INDEX */
  298. u8 flag; /* enum wmi_ssid_flag */
  299. u8 ssid_len;
  300. u8 ssid[WMI_MAX_SSID_LEN];
  301. } __packed;
  302. /*
  303. * WMI_SET_APPIE_CMDID
  304. * Add Application specified IE to a management frame
  305. */
  306. #define WMI_MAX_IE_LEN (1024)
  307. /*
  308. * Frame Types
  309. */
  310. enum wmi_mgmt_frame_type {
  311. WMI_FRAME_BEACON = 0,
  312. WMI_FRAME_PROBE_REQ = 1,
  313. WMI_FRAME_PROBE_RESP = 2,
  314. WMI_FRAME_ASSOC_REQ = 3,
  315. WMI_FRAME_ASSOC_RESP = 4,
  316. WMI_NUM_MGMT_FRAME,
  317. };
  318. struct wmi_set_appie_cmd {
  319. u8 mgmt_frm_type; /* enum wmi_mgmt_frame_type */
  320. u8 reserved;
  321. __le16 ie_len; /* Length of the IE to be added to MGMT frame */
  322. u8 ie_info[0];
  323. } __packed;
  324. /*
  325. * WMI_PXMT_RANGE_CFG_CMDID
  326. */
  327. struct wmi_pxmt_range_cfg_cmd {
  328. u8 dst_mac[WMI_MAC_LEN];
  329. __le16 range;
  330. } __packed;
  331. /*
  332. * WMI_PXMT_SNR2_RANGE_CFG_CMDID
  333. */
  334. struct wmi_pxmt_snr2_range_cfg_cmd {
  335. s8 snr2range_arr[WMI_PROX_RANGE_NUM-1];
  336. } __packed;
  337. /*
  338. * WMI_RF_MGMT_CMDID
  339. */
  340. enum wmi_rf_mgmt_type {
  341. WMI_RF_MGMT_W_DISABLE = 0,
  342. WMI_RF_MGMT_W_ENABLE = 1,
  343. WMI_RF_MGMT_GET_STATUS = 2,
  344. };
  345. struct wmi_rf_mgmt_cmd {
  346. __le32 rf_mgmt_type;
  347. } __packed;
  348. /*
  349. * WMI_THERMAL_THROTTLING_CTRL_CMDID
  350. */
  351. #define THERMAL_THROTTLING_USE_DEFAULT_MAX_TXOP_LENGTH (0xFFFFFFFF)
  352. struct wmi_thermal_throttling_ctrl_cmd {
  353. __le32 time_on_usec;
  354. __le32 time_off_usec;
  355. __le32 max_txop_length_usec;
  356. } __packed;
  357. /*
  358. * WMI_RF_RX_TEST_CMDID
  359. */
  360. struct wmi_rf_rx_test_cmd {
  361. __le32 sector;
  362. } __packed;
  363. /*
  364. * WMI_CORR_MEASURE_CMDID
  365. */
  366. struct wmi_corr_measure_cmd {
  367. s32 freq_mhz;
  368. __le32 length_samples;
  369. __le32 iterations;
  370. } __packed;
  371. /*
  372. * WMI_SET_SSID_CMDID
  373. */
  374. struct wmi_set_ssid_cmd {
  375. __le32 ssid_len;
  376. u8 ssid[WMI_MAX_SSID_LEN];
  377. } __packed;
  378. /*
  379. * WMI_SET_PCP_CHANNEL_CMDID
  380. */
  381. struct wmi_set_pcp_channel_cmd {
  382. u8 channel;
  383. u8 reserved[3];
  384. } __packed;
  385. /*
  386. * WMI_BCON_CTRL_CMDID
  387. */
  388. struct wmi_bcon_ctrl_cmd {
  389. __le16 bcon_interval;
  390. __le16 frag_num;
  391. __le64 ss_mask;
  392. u8 network_type;
  393. u8 pcp_max_assoc_sta;
  394. u8 disable_sec_offload;
  395. u8 disable_sec;
  396. } __packed;
  397. /******* P2P ***********/
  398. /*
  399. * WMI_PORT_ALLOCATE_CMDID
  400. */
  401. enum wmi_port_role {
  402. WMI_PORT_STA = 0,
  403. WMI_PORT_PCP = 1,
  404. WMI_PORT_AP = 2,
  405. WMI_PORT_P2P_DEV = 3,
  406. WMI_PORT_P2P_CLIENT = 4,
  407. WMI_PORT_P2P_GO = 5,
  408. };
  409. struct wmi_port_allocate_cmd {
  410. u8 mac[WMI_MAC_LEN];
  411. u8 port_role;
  412. u8 mid;
  413. } __packed;
  414. /*
  415. * WMI_PORT_DELETE_CMDID
  416. */
  417. struct wmi_delete_port_cmd {
  418. u8 mid;
  419. u8 reserved[3];
  420. } __packed;
  421. /*
  422. * WMI_P2P_CFG_CMDID
  423. */
  424. enum wmi_discovery_mode {
  425. WMI_DISCOVERY_MODE_NON_OFFLOAD = 0,
  426. WMI_DISCOVERY_MODE_OFFLOAD = 1,
  427. WMI_DISCOVERY_MODE_PEER2PEER = 2,
  428. };
  429. struct wmi_p2p_cfg_cmd {
  430. u8 discovery_mode; /* wmi_discovery_mode */
  431. u8 channel;
  432. __le16 bcon_interval; /* base to listen/search duration calculation */
  433. } __packed;
  434. /*
  435. * WMI_POWER_MGMT_CFG_CMDID
  436. */
  437. enum wmi_power_source_type {
  438. WMI_POWER_SOURCE_BATTERY = 0,
  439. WMI_POWER_SOURCE_OTHER = 1,
  440. };
  441. struct wmi_power_mgmt_cfg_cmd {
  442. u8 power_source; /* wmi_power_source_type */
  443. u8 reserved[3];
  444. } __packed;
  445. /*
  446. * WMI_PCP_START_CMDID
  447. */
  448. struct wmi_pcp_start_cmd {
  449. __le16 bcon_interval;
  450. u8 pcp_max_assoc_sta;
  451. u8 reserved0[9];
  452. u8 network_type;
  453. u8 channel;
  454. u8 disable_sec_offload;
  455. u8 disable_sec;
  456. } __packed;
  457. /*
  458. * WMI_SW_TX_REQ_CMDID
  459. */
  460. struct wmi_sw_tx_req_cmd {
  461. u8 dst_mac[WMI_MAC_LEN];
  462. __le16 len;
  463. u8 payload[0];
  464. } __packed;
  465. /*
  466. * WMI_VRING_CFG_CMDID
  467. */
  468. struct wmi_sw_ring_cfg {
  469. __le64 ring_mem_base;
  470. __le16 ring_size;
  471. __le16 max_mpdu_size;
  472. } __packed;
  473. struct wmi_vring_cfg_schd {
  474. __le16 priority;
  475. __le16 timeslot_us;
  476. } __packed;
  477. enum wmi_vring_cfg_encap_trans_type {
  478. WMI_VRING_ENC_TYPE_802_3 = 0,
  479. WMI_VRING_ENC_TYPE_NATIVE_WIFI = 1,
  480. };
  481. enum wmi_vring_cfg_ds_cfg {
  482. WMI_VRING_DS_PBSS = 0,
  483. WMI_VRING_DS_STATION = 1,
  484. WMI_VRING_DS_AP = 2,
  485. WMI_VRING_DS_ADDR4 = 3,
  486. };
  487. enum wmi_vring_cfg_nwifi_ds_trans_type {
  488. WMI_NWIFI_TX_TRANS_MODE_NO = 0,
  489. WMI_NWIFI_TX_TRANS_MODE_AP2PBSS = 1,
  490. WMI_NWIFI_TX_TRANS_MODE_STA2PBSS = 2,
  491. };
  492. enum wmi_vring_cfg_schd_params_priority {
  493. WMI_SCH_PRIO_REGULAR = 0,
  494. WMI_SCH_PRIO_HIGH = 1,
  495. };
  496. #define CIDXTID_CID_POS (0)
  497. #define CIDXTID_CID_LEN (4)
  498. #define CIDXTID_CID_MSK (0xF)
  499. #define CIDXTID_TID_POS (4)
  500. #define CIDXTID_TID_LEN (4)
  501. #define CIDXTID_TID_MSK (0xF0)
  502. struct wmi_vring_cfg {
  503. struct wmi_sw_ring_cfg tx_sw_ring;
  504. u8 ringid; /* 0-23 vrings */
  505. u8 cidxtid;
  506. u8 encap_trans_type;
  507. u8 ds_cfg; /* 802.3 DS cfg */
  508. u8 nwifi_ds_trans_type;
  509. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_POS (0)
  510. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_LEN (1)
  511. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_MSK (0x1)
  512. #define VRING_CFG_MAC_CTRL_AGGR_EN_POS (1)
  513. #define VRING_CFG_MAC_CTRL_AGGR_EN_LEN (1)
  514. #define VRING_CFG_MAC_CTRL_AGGR_EN_MSK (0x2)
  515. u8 mac_ctrl;
  516. #define VRING_CFG_TO_RESOLUTION_VALUE_POS (0)
  517. #define VRING_CFG_TO_RESOLUTION_VALUE_LEN (6)
  518. #define VRING_CFG_TO_RESOLUTION_VALUE_MSK (0x3F)
  519. u8 to_resolution;
  520. u8 agg_max_wsize;
  521. struct wmi_vring_cfg_schd schd_params;
  522. } __packed;
  523. enum wmi_vring_cfg_cmd_action {
  524. WMI_VRING_CMD_ADD = 0,
  525. WMI_VRING_CMD_MODIFY = 1,
  526. WMI_VRING_CMD_DELETE = 2,
  527. };
  528. struct wmi_vring_cfg_cmd {
  529. __le32 action;
  530. struct wmi_vring_cfg vring_cfg;
  531. } __packed;
  532. /*
  533. * WMI_BCAST_VRING_CFG_CMDID
  534. */
  535. struct wmi_bcast_vring_cfg {
  536. struct wmi_sw_ring_cfg tx_sw_ring;
  537. u8 ringid; /* 0-23 vrings */
  538. u8 encap_trans_type;
  539. u8 ds_cfg; /* 802.3 DS cfg */
  540. u8 nwifi_ds_trans_type;
  541. } __packed;
  542. struct wmi_bcast_vring_cfg_cmd {
  543. __le32 action;
  544. struct wmi_bcast_vring_cfg vring_cfg;
  545. } __packed;
  546. /*
  547. * WMI_VRING_BA_EN_CMDID
  548. */
  549. struct wmi_vring_ba_en_cmd {
  550. u8 ringid;
  551. u8 agg_max_wsize;
  552. __le16 ba_timeout;
  553. u8 amsdu;
  554. } __packed;
  555. /*
  556. * WMI_VRING_BA_DIS_CMDID
  557. */
  558. struct wmi_vring_ba_dis_cmd {
  559. u8 ringid;
  560. u8 reserved;
  561. __le16 reason;
  562. } __packed;
  563. /*
  564. * WMI_NOTIFY_REQ_CMDID
  565. */
  566. struct wmi_notify_req_cmd {
  567. u8 cid;
  568. u8 year;
  569. u8 month;
  570. u8 day;
  571. __le32 interval_usec;
  572. u8 hour;
  573. u8 minute;
  574. u8 second;
  575. u8 miliseconds;
  576. } __packed;
  577. /*
  578. * WMI_CFG_RX_CHAIN_CMDID
  579. */
  580. enum wmi_sniffer_cfg_mode {
  581. WMI_SNIFFER_OFF = 0,
  582. WMI_SNIFFER_ON = 1,
  583. };
  584. enum wmi_sniffer_cfg_phy_info_mode {
  585. WMI_SNIFFER_PHY_INFO_DISABLED = 0,
  586. WMI_SNIFFER_PHY_INFO_ENABLED = 1,
  587. };
  588. enum wmi_sniffer_cfg_phy_support {
  589. WMI_SNIFFER_CP = 0,
  590. WMI_SNIFFER_DP = 1,
  591. WMI_SNIFFER_BOTH_PHYS = 2,
  592. };
  593. struct wmi_sniffer_cfg {
  594. __le32 mode; /* enum wmi_sniffer_cfg_mode */
  595. __le32 phy_info_mode; /* enum wmi_sniffer_cfg_phy_info_mode */
  596. __le32 phy_support; /* enum wmi_sniffer_cfg_phy_support */
  597. u8 channel;
  598. u8 reserved[3];
  599. } __packed;
  600. enum wmi_cfg_rx_chain_cmd_action {
  601. WMI_RX_CHAIN_ADD = 0,
  602. WMI_RX_CHAIN_DEL = 1,
  603. };
  604. enum wmi_cfg_rx_chain_cmd_decap_trans_type {
  605. WMI_DECAP_TYPE_802_3 = 0,
  606. WMI_DECAP_TYPE_NATIVE_WIFI = 1,
  607. WMI_DECAP_TYPE_NONE = 2,
  608. };
  609. enum wmi_cfg_rx_chain_cmd_nwifi_ds_trans_type {
  610. WMI_NWIFI_RX_TRANS_MODE_NO = 0,
  611. WMI_NWIFI_RX_TRANS_MODE_PBSS2AP = 1,
  612. WMI_NWIFI_RX_TRANS_MODE_PBSS2STA = 2,
  613. };
  614. enum wmi_cfg_rx_chain_cmd_reorder_type {
  615. WMI_RX_HW_REORDER = 0,
  616. WMI_RX_SW_REORDER = 1,
  617. };
  618. struct wmi_cfg_rx_chain_cmd {
  619. __le32 action;
  620. struct wmi_sw_ring_cfg rx_sw_ring;
  621. u8 mid;
  622. u8 decap_trans_type;
  623. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_POS (0)
  624. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_LEN (1)
  625. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_MSK (0x1)
  626. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_POS (1)
  627. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_LEN (1)
  628. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_MSK (0x2)
  629. u8 l2_802_3_offload_ctrl;
  630. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_POS (0)
  631. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_LEN (1)
  632. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_MSK (0x1)
  633. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_POS (1)
  634. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_LEN (1)
  635. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_MSK (0x2)
  636. u8 l2_nwifi_offload_ctrl;
  637. u8 vlan_id;
  638. u8 nwifi_ds_trans_type;
  639. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_POS (0)
  640. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_LEN (1)
  641. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_MSK (0x1)
  642. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_POS (1)
  643. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_LEN (1)
  644. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_MSK (0x2)
  645. u8 l3_l4_ctrl;
  646. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_POS (0)
  647. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_LEN (1)
  648. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_MSK (0x1)
  649. #define RING_CTRL_OVERRIDE_WB_THRSH_POS (1)
  650. #define RING_CTRL_OVERRIDE_WB_THRSH_LEN (1)
  651. #define RING_CTRL_OVERRIDE_WB_THRSH_MSK (0x2)
  652. #define RING_CTRL_OVERRIDE_ITR_THRSH_POS (2)
  653. #define RING_CTRL_OVERRIDE_ITR_THRSH_LEN (1)
  654. #define RING_CTRL_OVERRIDE_ITR_THRSH_MSK (0x4)
  655. #define RING_CTRL_OVERRIDE_HOST_THRSH_POS (3)
  656. #define RING_CTRL_OVERRIDE_HOST_THRSH_LEN (1)
  657. #define RING_CTRL_OVERRIDE_HOST_THRSH_MSK (0x8)
  658. u8 ring_ctrl;
  659. __le16 prefetch_thrsh;
  660. __le16 wb_thrsh;
  661. __le32 itr_value;
  662. __le16 host_thrsh;
  663. u8 reorder_type;
  664. u8 reserved;
  665. struct wmi_sniffer_cfg sniffer_cfg;
  666. } __packed;
  667. /*
  668. * WMI_RCP_ADDBA_RESP_CMDID
  669. */
  670. struct wmi_rcp_addba_resp_cmd {
  671. u8 cidxtid;
  672. u8 dialog_token;
  673. __le16 status_code;
  674. __le16 ba_param_set; /* ieee80211_ba_parameterset field to send */
  675. __le16 ba_timeout;
  676. } __packed;
  677. /*
  678. * WMI_RCP_DELBA_CMDID
  679. */
  680. struct wmi_rcp_delba_cmd {
  681. u8 cidxtid;
  682. u8 reserved;
  683. __le16 reason;
  684. } __packed;
  685. /*
  686. * WMI_RCP_ADDBA_REQ_CMDID
  687. */
  688. struct wmi_rcp_addba_req_cmd {
  689. u8 cidxtid;
  690. u8 dialog_token;
  691. /* ieee80211_ba_parameterset field as it received */
  692. __le16 ba_param_set;
  693. __le16 ba_timeout;
  694. /* ieee80211_ba_seqstrl field as it received */
  695. __le16 ba_seq_ctrl;
  696. } __packed;
  697. /*
  698. * WMI_SET_MAC_ADDRESS_CMDID
  699. */
  700. struct wmi_set_mac_address_cmd {
  701. u8 mac[WMI_MAC_LEN];
  702. u8 reserved[2];
  703. } __packed;
  704. /*
  705. * WMI_EAPOL_TX_CMDID
  706. */
  707. struct wmi_eapol_tx_cmd {
  708. u8 dst_mac[WMI_MAC_LEN];
  709. __le16 eapol_len;
  710. u8 eapol[0];
  711. } __packed;
  712. /*
  713. * WMI_ECHO_CMDID
  714. *
  715. * Check FW is alive
  716. *
  717. * WMI_DEEP_ECHO_CMDID
  718. *
  719. * Check FW and ucode are alive
  720. *
  721. * Returned event: WMI_ECHO_RSP_EVENTID
  722. * same event for both commands
  723. */
  724. struct wmi_echo_cmd {
  725. __le32 value;
  726. } __packed;
  727. /*
  728. * WMI_TEMP_SENSE_CMDID
  729. *
  730. * Measure MAC and radio temperatures
  731. */
  732. /* Possible modes for temperature measurement */
  733. enum wmi_temperature_measure_mode {
  734. TEMPERATURE_USE_OLD_VALUE = 0x1,
  735. TEMPERATURE_MEASURE_NOW = 0x2,
  736. };
  737. struct wmi_temp_sense_cmd {
  738. __le32 measure_baseband_en;
  739. __le32 measure_rf_en;
  740. __le32 measure_mode;
  741. } __packed;
  742. /*
  743. * WMI Events
  744. */
  745. /*
  746. * List of Events (target to host)
  747. */
  748. enum wmi_event_id {
  749. WMI_READY_EVENTID = 0x1001,
  750. WMI_CONNECT_EVENTID = 0x1002,
  751. WMI_DISCONNECT_EVENTID = 0x1003,
  752. WMI_SCAN_COMPLETE_EVENTID = 0x100a,
  753. WMI_REPORT_STATISTICS_EVENTID = 0x100b,
  754. WMI_RD_MEM_RSP_EVENTID = 0x1800,
  755. WMI_FW_READY_EVENTID = 0x1801,
  756. WMI_EXIT_FAST_MEM_ACC_MODE_EVENTID = 0x0200,
  757. WMI_ECHO_RSP_EVENTID = 0x1803,
  758. WMI_FS_TUNE_DONE_EVENTID = 0x180a,
  759. WMI_CORR_MEASURE_EVENTID = 0x180b,
  760. WMI_READ_RSSI_EVENTID = 0x180c,
  761. WMI_TEMP_SENSE_DONE_EVENTID = 0x180e,
  762. WMI_DC_CALIB_DONE_EVENTID = 0x180f,
  763. WMI_IQ_TX_CALIB_DONE_EVENTID = 0x1811,
  764. WMI_IQ_RX_CALIB_DONE_EVENTID = 0x1812,
  765. WMI_SET_WORK_MODE_DONE_EVENTID = 0x1815,
  766. WMI_LO_LEAKAGE_CALIB_DONE_EVENTID = 0x1816,
  767. WMI_MARLON_R_READ_DONE_EVENTID = 0x1818,
  768. WMI_MARLON_R_WRITE_DONE_EVENTID = 0x1819,
  769. WMI_MARLON_R_TXRX_SEL_DONE_EVENTID = 0x181a,
  770. WMI_SILENT_RSSI_CALIB_DONE_EVENTID = 0x181d,
  771. WMI_RF_RX_TEST_DONE_EVENTID = 0x181e,
  772. WMI_CFG_RX_CHAIN_DONE_EVENTID = 0x1820,
  773. WMI_VRING_CFG_DONE_EVENTID = 0x1821,
  774. WMI_BA_STATUS_EVENTID = 0x1823,
  775. WMI_RCP_ADDBA_REQ_EVENTID = 0x1824,
  776. WMI_ADDBA_RESP_SENT_EVENTID = 0x1825,
  777. WMI_DELBA_EVENTID = 0x1826,
  778. WMI_GET_SSID_EVENTID = 0x1828,
  779. WMI_GET_PCP_CHANNEL_EVENTID = 0x182a,
  780. WMI_SW_TX_COMPLETE_EVENTID = 0x182b,
  781. WMI_READ_MAC_RXQ_EVENTID = 0x1830,
  782. WMI_READ_MAC_TXQ_EVENTID = 0x1831,
  783. WMI_WRITE_MAC_RXQ_EVENTID = 0x1832,
  784. WMI_WRITE_MAC_TXQ_EVENTID = 0x1833,
  785. WMI_WRITE_MAC_XQ_FIELD_EVENTID = 0x1834,
  786. WMI_BEAFORMING_MGMT_DONE_EVENTID = 0x1836,
  787. WMI_BF_TXSS_MGMT_DONE_EVENTID = 0x1837,
  788. WMI_BF_RXSS_MGMT_DONE_EVENTID = 0x1839,
  789. WMI_RS_MGMT_DONE_EVENTID = 0x1852,
  790. WMI_RF_MGMT_STATUS_EVENTID = 0x1853,
  791. WMI_THERMAL_THROTTLING_STATUS_EVENTID = 0x1855,
  792. WMI_BF_SM_MGMT_DONE_EVENTID = 0x1838,
  793. WMI_RX_MGMT_PACKET_EVENTID = 0x1840,
  794. WMI_TX_MGMT_PACKET_EVENTID = 0x1841,
  795. /* Performance monitoring events */
  796. WMI_DATA_PORT_OPEN_EVENTID = 0x1860,
  797. WMI_WBE_LINKDOWN_EVENTID = 0x1861,
  798. WMI_BF_CTRL_DONE_EVENTID = 0x1862,
  799. WMI_NOTIFY_REQ_DONE_EVENTID = 0x1863,
  800. WMI_GET_STATUS_DONE_EVENTID = 0x1864,
  801. WMI_UNIT_TEST_EVENTID = 0x1900,
  802. WMI_FLASH_READ_DONE_EVENTID = 0x1902,
  803. WMI_FLASH_WRITE_DONE_EVENTID = 0x1903,
  804. /*P2P*/
  805. WMI_P2P_CFG_DONE_EVENTID = 0x1910,
  806. WMI_PORT_ALLOCATED_EVENTID = 0x1911,
  807. WMI_PORT_DELETED_EVENTID = 0x1912,
  808. WMI_LISTEN_STARTED_EVENTID = 0x1914,
  809. WMI_SEARCH_STARTED_EVENTID = 0x1915,
  810. WMI_DISCOVERY_STARTED_EVENTID = 0x1916,
  811. WMI_DISCOVERY_STOPPED_EVENTID = 0x1917,
  812. WMI_PCP_STARTED_EVENTID = 0x1918,
  813. WMI_PCP_STOPPED_EVENTID = 0x1919,
  814. WMI_PCP_FACTOR_EVENTID = 0x191a,
  815. WMI_SET_CHANNEL_EVENTID = 0x9000,
  816. WMI_ASSOC_REQ_EVENTID = 0x9001,
  817. WMI_EAPOL_RX_EVENTID = 0x9002,
  818. WMI_MAC_ADDR_RESP_EVENTID = 0x9003,
  819. WMI_FW_VER_EVENTID = 0x9004,
  820. };
  821. /*
  822. * Events data structures
  823. */
  824. enum wmi_fw_status {
  825. WMI_FW_STATUS_SUCCESS,
  826. WMI_FW_STATUS_FAILURE,
  827. };
  828. /*
  829. * WMI_RF_MGMT_STATUS_EVENTID
  830. */
  831. enum wmi_rf_status {
  832. WMI_RF_ENABLED = 0,
  833. WMI_RF_DISABLED_HW = 1,
  834. WMI_RF_DISABLED_SW = 2,
  835. WMI_RF_DISABLED_HW_SW = 3,
  836. };
  837. struct wmi_rf_mgmt_status_event {
  838. __le32 rf_status;
  839. } __packed;
  840. /*
  841. * WMI_THERMAL_THROTTLING_STATUS_EVENTID
  842. */
  843. struct wmi_thermal_throttling_status_event {
  844. __le32 time_on_usec;
  845. __le32 time_off_usec;
  846. __le32 max_txop_length_usec;
  847. } __packed;
  848. /*
  849. * WMI_GET_STATUS_DONE_EVENTID
  850. */
  851. struct wmi_get_status_done_event {
  852. __le32 is_associated;
  853. u8 cid;
  854. u8 reserved0[3];
  855. u8 bssid[WMI_MAC_LEN];
  856. u8 channel;
  857. u8 reserved1;
  858. u8 network_type;
  859. u8 reserved2[3];
  860. __le32 ssid_len;
  861. u8 ssid[WMI_MAX_SSID_LEN];
  862. __le32 rf_status;
  863. __le32 is_secured;
  864. } __packed;
  865. /*
  866. * WMI_FW_VER_EVENTID
  867. */
  868. struct wmi_fw_ver_event {
  869. u8 major;
  870. u8 minor;
  871. __le16 subminor;
  872. __le16 build;
  873. } __packed;
  874. /*
  875. * WMI_MAC_ADDR_RESP_EVENTID
  876. */
  877. struct wmi_mac_addr_resp_event {
  878. u8 mac[WMI_MAC_LEN];
  879. u8 auth_mode;
  880. u8 crypt_mode;
  881. __le32 offload_mode;
  882. } __packed;
  883. /*
  884. * WMI_EAPOL_RX_EVENTID
  885. */
  886. struct wmi_eapol_rx_event {
  887. u8 src_mac[WMI_MAC_LEN];
  888. __le16 eapol_len;
  889. u8 eapol[0];
  890. } __packed;
  891. /*
  892. * WMI_READY_EVENTID
  893. */
  894. enum wmi_phy_capability {
  895. WMI_11A_CAPABILITY = 1,
  896. WMI_11G_CAPABILITY = 2,
  897. WMI_11AG_CAPABILITY = 3,
  898. WMI_11NA_CAPABILITY = 4,
  899. WMI_11NG_CAPABILITY = 5,
  900. WMI_11NAG_CAPABILITY = 6,
  901. WMI_11AD_CAPABILITY = 7,
  902. WMI_11N_CAPABILITY_OFFSET = WMI_11NA_CAPABILITY - WMI_11A_CAPABILITY,
  903. };
  904. struct wmi_ready_event {
  905. __le32 sw_version;
  906. __le32 abi_version;
  907. u8 mac[WMI_MAC_LEN];
  908. u8 phy_capability; /* enum wmi_phy_capability */
  909. u8 numof_additional_mids;
  910. } __packed;
  911. /*
  912. * WMI_NOTIFY_REQ_DONE_EVENTID
  913. */
  914. struct wmi_notify_req_done_event {
  915. __le32 status; /* beamforming status, 0: fail; 1: OK; 2: retrying */
  916. __le64 tsf;
  917. __le32 snr_val;
  918. __le32 tx_tpt;
  919. __le32 tx_goodput;
  920. __le32 rx_goodput;
  921. __le16 bf_mcs;
  922. __le16 my_rx_sector;
  923. __le16 my_tx_sector;
  924. __le16 other_rx_sector;
  925. __le16 other_tx_sector;
  926. __le16 range;
  927. u8 sqi;
  928. u8 reserved[3];
  929. } __packed;
  930. /*
  931. * WMI_CONNECT_EVENTID
  932. */
  933. struct wmi_connect_event {
  934. u8 channel;
  935. u8 reserved0;
  936. u8 bssid[WMI_MAC_LEN];
  937. __le16 listen_interval;
  938. __le16 beacon_interval;
  939. u8 network_type;
  940. u8 reserved1[3];
  941. u8 beacon_ie_len;
  942. u8 assoc_req_len;
  943. u8 assoc_resp_len;
  944. u8 cid;
  945. u8 reserved2[3];
  946. u8 assoc_info[0];
  947. } __packed;
  948. /*
  949. * WMI_DISCONNECT_EVENTID
  950. */
  951. enum wmi_disconnect_reason {
  952. WMI_DIS_REASON_NO_NETWORK_AVAIL = 1,
  953. WMI_DIS_REASON_LOST_LINK = 2, /* bmiss */
  954. WMI_DIS_REASON_DISCONNECT_CMD = 3,
  955. WMI_DIS_REASON_BSS_DISCONNECTED = 4,
  956. WMI_DIS_REASON_AUTH_FAILED = 5,
  957. WMI_DIS_REASON_ASSOC_FAILED = 6,
  958. WMI_DIS_REASON_NO_RESOURCES_AVAIL = 7,
  959. WMI_DIS_REASON_CSERV_DISCONNECT = 8,
  960. WMI_DIS_REASON_INVALID_PROFILE = 10,
  961. WMI_DIS_REASON_DOT11H_CHANNEL_SWITCH = 11,
  962. WMI_DIS_REASON_PROFILE_MISMATCH = 12,
  963. WMI_DIS_REASON_CONNECTION_EVICTED = 13,
  964. WMI_DIS_REASON_IBSS_MERGE = 14,
  965. };
  966. struct wmi_disconnect_event {
  967. __le16 protocol_reason_status; /* reason code, see 802.11 spec. */
  968. u8 bssid[WMI_MAC_LEN]; /* set if known */
  969. u8 disconnect_reason; /* see wmi_disconnect_reason */
  970. u8 assoc_resp_len; /* not used */
  971. u8 assoc_info[0]; /* not used */
  972. } __packed;
  973. /*
  974. * WMI_SCAN_COMPLETE_EVENTID
  975. */
  976. enum scan_status {
  977. WMI_SCAN_SUCCESS = 0,
  978. WMI_SCAN_FAILED = 1,
  979. WMI_SCAN_ABORTED = 2,
  980. WMI_SCAN_REJECTED = 3,
  981. };
  982. struct wmi_scan_complete_event {
  983. __le32 status; /* scan_status */
  984. } __packed;
  985. /*
  986. * WMI_BA_STATUS_EVENTID
  987. */
  988. enum wmi_vring_ba_status {
  989. WMI_BA_AGREED = 0,
  990. WMI_BA_NON_AGREED = 1,
  991. /* BA_EN in middle of teardown flow */
  992. WMI_BA_TD_WIP = 2,
  993. /* BA_DIS or BA_EN in middle of BA SETUP flow */
  994. WMI_BA_SETUP_WIP = 3,
  995. /* BA_EN when the BA session is already active */
  996. WMI_BA_SESSION_ACTIVE = 4,
  997. /* BA_DIS when the BA session is not active */
  998. WMI_BA_SESSION_NOT_ACTIVE = 5,
  999. };
  1000. struct wmi_vring_ba_status_event {
  1001. __le16 status; /* enum wmi_vring_ba_status */
  1002. u8 reserved[2];
  1003. u8 ringid;
  1004. u8 agg_wsize;
  1005. __le16 ba_timeout;
  1006. u8 amsdu;
  1007. } __packed;
  1008. /*
  1009. * WMI_DELBA_EVENTID
  1010. */
  1011. struct wmi_delba_event {
  1012. u8 cidxtid;
  1013. u8 from_initiator;
  1014. __le16 reason;
  1015. } __packed;
  1016. /*
  1017. * WMI_VRING_CFG_DONE_EVENTID
  1018. */
  1019. struct wmi_vring_cfg_done_event {
  1020. u8 ringid;
  1021. u8 status;
  1022. u8 reserved[2];
  1023. __le32 tx_vring_tail_ptr;
  1024. } __packed;
  1025. /*
  1026. * WMI_ADDBA_RESP_SENT_EVENTID
  1027. */
  1028. struct wmi_rcp_addba_resp_sent_event {
  1029. u8 cidxtid;
  1030. u8 reserved;
  1031. __le16 status;
  1032. } __packed;
  1033. /*
  1034. * WMI_RCP_ADDBA_REQ_EVENTID
  1035. */
  1036. struct wmi_rcp_addba_req_event {
  1037. u8 cidxtid;
  1038. u8 dialog_token;
  1039. __le16 ba_param_set; /* ieee80211_ba_parameterset as it received */
  1040. __le16 ba_timeout;
  1041. __le16 ba_seq_ctrl; /* ieee80211_ba_seqstrl field as it received */
  1042. } __packed;
  1043. /*
  1044. * WMI_CFG_RX_CHAIN_DONE_EVENTID
  1045. */
  1046. enum wmi_cfg_rx_chain_done_event_status {
  1047. WMI_CFG_RX_CHAIN_SUCCESS = 1,
  1048. };
  1049. struct wmi_cfg_rx_chain_done_event {
  1050. __le32 rx_ring_tail_ptr; /* Rx V-Ring Tail pointer */
  1051. __le32 status;
  1052. } __packed;
  1053. /*
  1054. * WMI_WBE_LINKDOWN_EVENTID
  1055. */
  1056. enum wmi_wbe_link_down_event_reason {
  1057. WMI_WBE_REASON_USER_REQUEST = 0,
  1058. WMI_WBE_REASON_RX_DISASSOC = 1,
  1059. WMI_WBE_REASON_BAD_PHY_LINK = 2,
  1060. };
  1061. struct wmi_wbe_link_down_event {
  1062. u8 cid;
  1063. u8 reserved[3];
  1064. __le32 reason;
  1065. } __packed;
  1066. /*
  1067. * WMI_DATA_PORT_OPEN_EVENTID
  1068. */
  1069. struct wmi_data_port_open_event {
  1070. u8 cid;
  1071. u8 reserved[3];
  1072. } __packed;
  1073. /*
  1074. * WMI_GET_PCP_CHANNEL_EVENTID
  1075. */
  1076. struct wmi_get_pcp_channel_event {
  1077. u8 channel;
  1078. u8 reserved[3];
  1079. } __packed;
  1080. /*
  1081. * WMI_P2P_CFG_DONE_EVENTID
  1082. */
  1083. struct wmi_p2p_cfg_done_event {
  1084. u8 status; /* wmi_fw_status */
  1085. u8 reserved[3];
  1086. } __packed;
  1087. /*
  1088. * WMI_PORT_ALLOCATED_EVENTID
  1089. */
  1090. struct wmi_port_allocated_event {
  1091. u8 status; /* wmi_fw_status */
  1092. u8 reserved[3];
  1093. } __packed;
  1094. /*
  1095. * WMI_PORT_DELETED_EVENTID
  1096. */
  1097. struct wmi_port_deleted_event {
  1098. u8 status; /* wmi_fw_status */
  1099. u8 reserved[3];
  1100. } __packed;
  1101. /*
  1102. * WMI_LISTEN_STARTED_EVENTID
  1103. */
  1104. struct wmi_listen_started_event {
  1105. u8 status; /* wmi_fw_status */
  1106. u8 reserved[3];
  1107. } __packed;
  1108. /*
  1109. * WMI_SEARCH_STARTED_EVENTID
  1110. */
  1111. struct wmi_search_started_event {
  1112. u8 status; /* wmi_fw_status */
  1113. u8 reserved[3];
  1114. } __packed;
  1115. /*
  1116. * WMI_PCP_STARTED_EVENTID
  1117. */
  1118. struct wmi_pcp_started_event {
  1119. u8 status; /* wmi_fw_status */
  1120. u8 reserved[3];
  1121. } __packed;
  1122. /*
  1123. * WMI_PCP_FACTOR_EVENTID
  1124. */
  1125. struct wmi_pcp_factor_event {
  1126. __le32 pcp_factor;
  1127. } __packed;
  1128. /*
  1129. * WMI_SW_TX_COMPLETE_EVENTID
  1130. */
  1131. enum wmi_sw_tx_status {
  1132. WMI_TX_SW_STATUS_SUCCESS = 0,
  1133. WMI_TX_SW_STATUS_FAILED_NO_RESOURCES = 1,
  1134. WMI_TX_SW_STATUS_FAILED_TX = 2,
  1135. };
  1136. struct wmi_sw_tx_complete_event {
  1137. u8 status; /* enum wmi_sw_tx_status */
  1138. u8 reserved[3];
  1139. } __packed;
  1140. /*
  1141. * WMI_CORR_MEASURE_EVENTID
  1142. */
  1143. struct wmi_corr_measure_event {
  1144. s32 i;
  1145. s32 q;
  1146. s32 image_i;
  1147. s32 image_q;
  1148. } __packed;
  1149. /*
  1150. * WMI_READ_RSSI_EVENTID
  1151. */
  1152. struct wmi_read_rssi_event {
  1153. __le32 ina_rssi_adc_dbm;
  1154. } __packed;
  1155. /*
  1156. * WMI_GET_SSID_EVENTID
  1157. */
  1158. struct wmi_get_ssid_event {
  1159. __le32 ssid_len;
  1160. u8 ssid[WMI_MAX_SSID_LEN];
  1161. } __packed;
  1162. /*
  1163. * WMI_RX_MGMT_PACKET_EVENTID
  1164. */
  1165. struct wmi_rx_mgmt_info {
  1166. u8 mcs;
  1167. s8 snr;
  1168. u8 range;
  1169. u8 sqi;
  1170. __le16 stype;
  1171. __le16 status;
  1172. __le32 len;
  1173. u8 qid;
  1174. u8 mid;
  1175. u8 cid;
  1176. u8 channel; /* From Radio MNGR */
  1177. } __packed;
  1178. /*
  1179. * WMI_TX_MGMT_PACKET_EVENTID
  1180. */
  1181. struct wmi_tx_mgmt_packet_event {
  1182. u8 payload[0];
  1183. } __packed;
  1184. struct wmi_rx_mgmt_packet_event {
  1185. struct wmi_rx_mgmt_info info;
  1186. u8 payload[0];
  1187. } __packed;
  1188. /*
  1189. * WMI_ECHO_RSP_EVENTID
  1190. */
  1191. struct wmi_echo_event {
  1192. __le32 echoed_value;
  1193. } __packed;
  1194. /*
  1195. * WMI_TEMP_SENSE_DONE_EVENTID
  1196. *
  1197. * Measure MAC and radio temperatures
  1198. */
  1199. struct wmi_temp_sense_done_event {
  1200. __le32 baseband_t1000;
  1201. __le32 rf_t1000;
  1202. } __packed;
  1203. #endif /* __WILOCITY_WMI_H__ */