wmi.h 28 KB

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