wmi.h 29 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384
  1. /*
  2. * Copyright (c) 2012-2015 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_RX_GROUP = 1,
  237. WMI_KEY_USE_TX_GROUP = 2,
  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. enum wmi_hidden_ssid {
  449. WMI_HIDDEN_SSID_DISABLED = 0,
  450. WMI_HIDDEN_SSID_SEND_EMPTY = 1,
  451. WMI_HIDDEN_SSID_CLEAR = 2,
  452. };
  453. struct wmi_pcp_start_cmd {
  454. __le16 bcon_interval;
  455. u8 pcp_max_assoc_sta;
  456. u8 hidden_ssid;
  457. u8 reserved0[8];
  458. u8 network_type;
  459. u8 channel;
  460. u8 disable_sec_offload;
  461. u8 disable_sec;
  462. } __packed;
  463. /*
  464. * WMI_SW_TX_REQ_CMDID
  465. */
  466. struct wmi_sw_tx_req_cmd {
  467. u8 dst_mac[WMI_MAC_LEN];
  468. __le16 len;
  469. u8 payload[0];
  470. } __packed;
  471. /*
  472. * WMI_VRING_CFG_CMDID
  473. */
  474. struct wmi_sw_ring_cfg {
  475. __le64 ring_mem_base;
  476. __le16 ring_size;
  477. __le16 max_mpdu_size;
  478. } __packed;
  479. struct wmi_vring_cfg_schd {
  480. __le16 priority;
  481. __le16 timeslot_us;
  482. } __packed;
  483. enum wmi_vring_cfg_encap_trans_type {
  484. WMI_VRING_ENC_TYPE_802_3 = 0,
  485. WMI_VRING_ENC_TYPE_NATIVE_WIFI = 1,
  486. };
  487. enum wmi_vring_cfg_ds_cfg {
  488. WMI_VRING_DS_PBSS = 0,
  489. WMI_VRING_DS_STATION = 1,
  490. WMI_VRING_DS_AP = 2,
  491. WMI_VRING_DS_ADDR4 = 3,
  492. };
  493. enum wmi_vring_cfg_nwifi_ds_trans_type {
  494. WMI_NWIFI_TX_TRANS_MODE_NO = 0,
  495. WMI_NWIFI_TX_TRANS_MODE_AP2PBSS = 1,
  496. WMI_NWIFI_TX_TRANS_MODE_STA2PBSS = 2,
  497. };
  498. enum wmi_vring_cfg_schd_params_priority {
  499. WMI_SCH_PRIO_REGULAR = 0,
  500. WMI_SCH_PRIO_HIGH = 1,
  501. };
  502. #define CIDXTID_CID_POS (0)
  503. #define CIDXTID_CID_LEN (4)
  504. #define CIDXTID_CID_MSK (0xF)
  505. #define CIDXTID_TID_POS (4)
  506. #define CIDXTID_TID_LEN (4)
  507. #define CIDXTID_TID_MSK (0xF0)
  508. struct wmi_vring_cfg {
  509. struct wmi_sw_ring_cfg tx_sw_ring;
  510. u8 ringid; /* 0-23 vrings */
  511. u8 cidxtid;
  512. u8 encap_trans_type;
  513. u8 ds_cfg; /* 802.3 DS cfg */
  514. u8 nwifi_ds_trans_type;
  515. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_POS (0)
  516. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_LEN (1)
  517. #define VRING_CFG_MAC_CTRL_LIFETIME_EN_MSK (0x1)
  518. #define VRING_CFG_MAC_CTRL_AGGR_EN_POS (1)
  519. #define VRING_CFG_MAC_CTRL_AGGR_EN_LEN (1)
  520. #define VRING_CFG_MAC_CTRL_AGGR_EN_MSK (0x2)
  521. u8 mac_ctrl;
  522. #define VRING_CFG_TO_RESOLUTION_VALUE_POS (0)
  523. #define VRING_CFG_TO_RESOLUTION_VALUE_LEN (6)
  524. #define VRING_CFG_TO_RESOLUTION_VALUE_MSK (0x3F)
  525. u8 to_resolution;
  526. u8 agg_max_wsize;
  527. struct wmi_vring_cfg_schd schd_params;
  528. } __packed;
  529. enum wmi_vring_cfg_cmd_action {
  530. WMI_VRING_CMD_ADD = 0,
  531. WMI_VRING_CMD_MODIFY = 1,
  532. WMI_VRING_CMD_DELETE = 2,
  533. };
  534. struct wmi_vring_cfg_cmd {
  535. __le32 action;
  536. struct wmi_vring_cfg vring_cfg;
  537. } __packed;
  538. /*
  539. * WMI_BCAST_VRING_CFG_CMDID
  540. */
  541. struct wmi_bcast_vring_cfg {
  542. struct wmi_sw_ring_cfg tx_sw_ring;
  543. u8 ringid; /* 0-23 vrings */
  544. u8 encap_trans_type;
  545. u8 ds_cfg; /* 802.3 DS cfg */
  546. u8 nwifi_ds_trans_type;
  547. } __packed;
  548. struct wmi_bcast_vring_cfg_cmd {
  549. __le32 action;
  550. struct wmi_bcast_vring_cfg vring_cfg;
  551. } __packed;
  552. /*
  553. * WMI_VRING_BA_EN_CMDID
  554. */
  555. struct wmi_vring_ba_en_cmd {
  556. u8 ringid;
  557. u8 agg_max_wsize;
  558. __le16 ba_timeout;
  559. u8 amsdu;
  560. } __packed;
  561. /*
  562. * WMI_VRING_BA_DIS_CMDID
  563. */
  564. struct wmi_vring_ba_dis_cmd {
  565. u8 ringid;
  566. u8 reserved;
  567. __le16 reason;
  568. } __packed;
  569. /*
  570. * WMI_NOTIFY_REQ_CMDID
  571. */
  572. struct wmi_notify_req_cmd {
  573. u8 cid;
  574. u8 year;
  575. u8 month;
  576. u8 day;
  577. __le32 interval_usec;
  578. u8 hour;
  579. u8 minute;
  580. u8 second;
  581. u8 miliseconds;
  582. } __packed;
  583. /*
  584. * WMI_CFG_RX_CHAIN_CMDID
  585. */
  586. enum wmi_sniffer_cfg_mode {
  587. WMI_SNIFFER_OFF = 0,
  588. WMI_SNIFFER_ON = 1,
  589. };
  590. enum wmi_sniffer_cfg_phy_info_mode {
  591. WMI_SNIFFER_PHY_INFO_DISABLED = 0,
  592. WMI_SNIFFER_PHY_INFO_ENABLED = 1,
  593. };
  594. enum wmi_sniffer_cfg_phy_support {
  595. WMI_SNIFFER_CP = 0,
  596. WMI_SNIFFER_DP = 1,
  597. WMI_SNIFFER_BOTH_PHYS = 2,
  598. };
  599. struct wmi_sniffer_cfg {
  600. __le32 mode; /* enum wmi_sniffer_cfg_mode */
  601. __le32 phy_info_mode; /* enum wmi_sniffer_cfg_phy_info_mode */
  602. __le32 phy_support; /* enum wmi_sniffer_cfg_phy_support */
  603. u8 channel;
  604. u8 reserved[3];
  605. } __packed;
  606. enum wmi_cfg_rx_chain_cmd_action {
  607. WMI_RX_CHAIN_ADD = 0,
  608. WMI_RX_CHAIN_DEL = 1,
  609. };
  610. enum wmi_cfg_rx_chain_cmd_decap_trans_type {
  611. WMI_DECAP_TYPE_802_3 = 0,
  612. WMI_DECAP_TYPE_NATIVE_WIFI = 1,
  613. WMI_DECAP_TYPE_NONE = 2,
  614. };
  615. enum wmi_cfg_rx_chain_cmd_nwifi_ds_trans_type {
  616. WMI_NWIFI_RX_TRANS_MODE_NO = 0,
  617. WMI_NWIFI_RX_TRANS_MODE_PBSS2AP = 1,
  618. WMI_NWIFI_RX_TRANS_MODE_PBSS2STA = 2,
  619. };
  620. enum wmi_cfg_rx_chain_cmd_reorder_type {
  621. WMI_RX_HW_REORDER = 0,
  622. WMI_RX_SW_REORDER = 1,
  623. };
  624. struct wmi_cfg_rx_chain_cmd {
  625. __le32 action;
  626. struct wmi_sw_ring_cfg rx_sw_ring;
  627. u8 mid;
  628. u8 decap_trans_type;
  629. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_POS (0)
  630. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_LEN (1)
  631. #define L2_802_3_OFFLOAD_CTRL_VLAN_TAG_INSERTION_MSK (0x1)
  632. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_POS (1)
  633. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_LEN (1)
  634. #define L2_802_3_OFFLOAD_CTRL_SNAP_KEEP_MSK (0x2)
  635. u8 l2_802_3_offload_ctrl;
  636. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_POS (0)
  637. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_LEN (1)
  638. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_QOS_MSK (0x1)
  639. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_POS (1)
  640. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_LEN (1)
  641. #define L2_NWIFI_OFFLOAD_CTRL_REMOVE_PN_MSK (0x2)
  642. u8 l2_nwifi_offload_ctrl;
  643. u8 vlan_id;
  644. u8 nwifi_ds_trans_type;
  645. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_POS (0)
  646. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_LEN (1)
  647. #define L3_L4_CTRL_IPV4_CHECKSUM_EN_MSK (0x1)
  648. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_POS (1)
  649. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_LEN (1)
  650. #define L3_L4_CTRL_TCPIP_CHECKSUM_EN_MSK (0x2)
  651. u8 l3_l4_ctrl;
  652. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_POS (0)
  653. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_LEN (1)
  654. #define RING_CTRL_OVERRIDE_PREFETCH_THRSH_MSK (0x1)
  655. #define RING_CTRL_OVERRIDE_WB_THRSH_POS (1)
  656. #define RING_CTRL_OVERRIDE_WB_THRSH_LEN (1)
  657. #define RING_CTRL_OVERRIDE_WB_THRSH_MSK (0x2)
  658. #define RING_CTRL_OVERRIDE_ITR_THRSH_POS (2)
  659. #define RING_CTRL_OVERRIDE_ITR_THRSH_LEN (1)
  660. #define RING_CTRL_OVERRIDE_ITR_THRSH_MSK (0x4)
  661. #define RING_CTRL_OVERRIDE_HOST_THRSH_POS (3)
  662. #define RING_CTRL_OVERRIDE_HOST_THRSH_LEN (1)
  663. #define RING_CTRL_OVERRIDE_HOST_THRSH_MSK (0x8)
  664. u8 ring_ctrl;
  665. __le16 prefetch_thrsh;
  666. __le16 wb_thrsh;
  667. __le32 itr_value;
  668. __le16 host_thrsh;
  669. u8 reorder_type;
  670. u8 reserved;
  671. struct wmi_sniffer_cfg sniffer_cfg;
  672. } __packed;
  673. /*
  674. * WMI_RCP_ADDBA_RESP_CMDID
  675. */
  676. struct wmi_rcp_addba_resp_cmd {
  677. u8 cidxtid;
  678. u8 dialog_token;
  679. __le16 status_code;
  680. __le16 ba_param_set; /* ieee80211_ba_parameterset field to send */
  681. __le16 ba_timeout;
  682. } __packed;
  683. /*
  684. * WMI_RCP_DELBA_CMDID
  685. */
  686. struct wmi_rcp_delba_cmd {
  687. u8 cidxtid;
  688. u8 reserved;
  689. __le16 reason;
  690. } __packed;
  691. /*
  692. * WMI_RCP_ADDBA_REQ_CMDID
  693. */
  694. struct wmi_rcp_addba_req_cmd {
  695. u8 cidxtid;
  696. u8 dialog_token;
  697. /* ieee80211_ba_parameterset field as it received */
  698. __le16 ba_param_set;
  699. __le16 ba_timeout;
  700. /* ieee80211_ba_seqstrl field as it received */
  701. __le16 ba_seq_ctrl;
  702. } __packed;
  703. /*
  704. * WMI_SET_MAC_ADDRESS_CMDID
  705. */
  706. struct wmi_set_mac_address_cmd {
  707. u8 mac[WMI_MAC_LEN];
  708. u8 reserved[2];
  709. } __packed;
  710. /*
  711. * WMI_EAPOL_TX_CMDID
  712. */
  713. struct wmi_eapol_tx_cmd {
  714. u8 dst_mac[WMI_MAC_LEN];
  715. __le16 eapol_len;
  716. u8 eapol[0];
  717. } __packed;
  718. /*
  719. * WMI_ECHO_CMDID
  720. *
  721. * Check FW is alive
  722. *
  723. * WMI_DEEP_ECHO_CMDID
  724. *
  725. * Check FW and ucode are alive
  726. *
  727. * Returned event: WMI_ECHO_RSP_EVENTID
  728. * same event for both commands
  729. */
  730. struct wmi_echo_cmd {
  731. __le32 value;
  732. } __packed;
  733. /*
  734. * WMI_TEMP_SENSE_CMDID
  735. *
  736. * Measure MAC and radio temperatures
  737. */
  738. /* Possible modes for temperature measurement */
  739. enum wmi_temperature_measure_mode {
  740. TEMPERATURE_USE_OLD_VALUE = 0x1,
  741. TEMPERATURE_MEASURE_NOW = 0x2,
  742. };
  743. struct wmi_temp_sense_cmd {
  744. __le32 measure_baseband_en;
  745. __le32 measure_rf_en;
  746. __le32 measure_mode;
  747. } __packed;
  748. /*
  749. * WMI_PMC_CMDID
  750. */
  751. enum wmi_pmc_op_e {
  752. WMI_PMC_ALLOCATE = 0,
  753. WMI_PMC_RELEASE = 1,
  754. };
  755. struct wmi_pmc_cmd {
  756. u8 op; /* enum wmi_pmc_cmd_op_type */
  757. u8 reserved;
  758. __le16 ring_size;
  759. __le64 mem_base;
  760. } __packed;
  761. /*
  762. * WMI Events
  763. */
  764. /*
  765. * List of Events (target to host)
  766. */
  767. enum wmi_event_id {
  768. WMI_READY_EVENTID = 0x1001,
  769. WMI_CONNECT_EVENTID = 0x1002,
  770. WMI_DISCONNECT_EVENTID = 0x1003,
  771. WMI_SCAN_COMPLETE_EVENTID = 0x100a,
  772. WMI_REPORT_STATISTICS_EVENTID = 0x100b,
  773. WMI_RD_MEM_RSP_EVENTID = 0x1800,
  774. WMI_FW_READY_EVENTID = 0x1801,
  775. WMI_EXIT_FAST_MEM_ACC_MODE_EVENTID = 0x0200,
  776. WMI_ECHO_RSP_EVENTID = 0x1803,
  777. WMI_FS_TUNE_DONE_EVENTID = 0x180a,
  778. WMI_CORR_MEASURE_EVENTID = 0x180b,
  779. WMI_READ_RSSI_EVENTID = 0x180c,
  780. WMI_TEMP_SENSE_DONE_EVENTID = 0x180e,
  781. WMI_DC_CALIB_DONE_EVENTID = 0x180f,
  782. WMI_IQ_TX_CALIB_DONE_EVENTID = 0x1811,
  783. WMI_IQ_RX_CALIB_DONE_EVENTID = 0x1812,
  784. WMI_SET_WORK_MODE_DONE_EVENTID = 0x1815,
  785. WMI_LO_LEAKAGE_CALIB_DONE_EVENTID = 0x1816,
  786. WMI_MARLON_R_READ_DONE_EVENTID = 0x1818,
  787. WMI_MARLON_R_WRITE_DONE_EVENTID = 0x1819,
  788. WMI_MARLON_R_TXRX_SEL_DONE_EVENTID = 0x181a,
  789. WMI_SILENT_RSSI_CALIB_DONE_EVENTID = 0x181d,
  790. WMI_RF_RX_TEST_DONE_EVENTID = 0x181e,
  791. WMI_CFG_RX_CHAIN_DONE_EVENTID = 0x1820,
  792. WMI_VRING_CFG_DONE_EVENTID = 0x1821,
  793. WMI_BA_STATUS_EVENTID = 0x1823,
  794. WMI_RCP_ADDBA_REQ_EVENTID = 0x1824,
  795. WMI_RCP_ADDBA_RESP_SENT_EVENTID = 0x1825,
  796. WMI_DELBA_EVENTID = 0x1826,
  797. WMI_GET_SSID_EVENTID = 0x1828,
  798. WMI_GET_PCP_CHANNEL_EVENTID = 0x182a,
  799. WMI_SW_TX_COMPLETE_EVENTID = 0x182b,
  800. WMI_READ_MAC_RXQ_EVENTID = 0x1830,
  801. WMI_READ_MAC_TXQ_EVENTID = 0x1831,
  802. WMI_WRITE_MAC_RXQ_EVENTID = 0x1832,
  803. WMI_WRITE_MAC_TXQ_EVENTID = 0x1833,
  804. WMI_WRITE_MAC_XQ_FIELD_EVENTID = 0x1834,
  805. WMI_BEAMFORMING_MGMT_DONE_EVENTID = 0x1836,
  806. WMI_BF_TXSS_MGMT_DONE_EVENTID = 0x1837,
  807. WMI_BF_RXSS_MGMT_DONE_EVENTID = 0x1839,
  808. WMI_RS_MGMT_DONE_EVENTID = 0x1852,
  809. WMI_RF_MGMT_STATUS_EVENTID = 0x1853,
  810. WMI_THERMAL_THROTTLING_STATUS_EVENTID = 0x1855,
  811. WMI_BF_SM_MGMT_DONE_EVENTID = 0x1838,
  812. WMI_RX_MGMT_PACKET_EVENTID = 0x1840,
  813. WMI_TX_MGMT_PACKET_EVENTID = 0x1841,
  814. /* Performance monitoring events */
  815. WMI_DATA_PORT_OPEN_EVENTID = 0x1860,
  816. WMI_WBE_LINK_DOWN_EVENTID = 0x1861,
  817. WMI_BF_CTRL_DONE_EVENTID = 0x1862,
  818. WMI_NOTIFY_REQ_DONE_EVENTID = 0x1863,
  819. WMI_GET_STATUS_DONE_EVENTID = 0x1864,
  820. WMI_VRING_EN_EVENTID = 0x1865,
  821. WMI_UNIT_TEST_EVENTID = 0x1900,
  822. WMI_FLASH_READ_DONE_EVENTID = 0x1902,
  823. WMI_FLASH_WRITE_DONE_EVENTID = 0x1903,
  824. /*P2P*/
  825. WMI_P2P_CFG_DONE_EVENTID = 0x1910,
  826. WMI_PORT_ALLOCATED_EVENTID = 0x1911,
  827. WMI_PORT_DELETED_EVENTID = 0x1912,
  828. WMI_LISTEN_STARTED_EVENTID = 0x1914,
  829. WMI_SEARCH_STARTED_EVENTID = 0x1915,
  830. WMI_DISCOVERY_STARTED_EVENTID = 0x1916,
  831. WMI_DISCOVERY_STOPPED_EVENTID = 0x1917,
  832. WMI_PCP_STARTED_EVENTID = 0x1918,
  833. WMI_PCP_STOPPED_EVENTID = 0x1919,
  834. WMI_PCP_FACTOR_EVENTID = 0x191a,
  835. WMI_SET_CHANNEL_EVENTID = 0x9000,
  836. WMI_ASSOC_REQ_EVENTID = 0x9001,
  837. WMI_EAPOL_RX_EVENTID = 0x9002,
  838. WMI_MAC_ADDR_RESP_EVENTID = 0x9003,
  839. WMI_FW_VER_EVENTID = 0x9004,
  840. };
  841. /*
  842. * Events data structures
  843. */
  844. enum wmi_fw_status {
  845. WMI_FW_STATUS_SUCCESS,
  846. WMI_FW_STATUS_FAILURE,
  847. };
  848. /*
  849. * WMI_RF_MGMT_STATUS_EVENTID
  850. */
  851. enum wmi_rf_status {
  852. WMI_RF_ENABLED = 0,
  853. WMI_RF_DISABLED_HW = 1,
  854. WMI_RF_DISABLED_SW = 2,
  855. WMI_RF_DISABLED_HW_SW = 3,
  856. };
  857. struct wmi_rf_mgmt_status_event {
  858. __le32 rf_status;
  859. } __packed;
  860. /*
  861. * WMI_THERMAL_THROTTLING_STATUS_EVENTID
  862. */
  863. struct wmi_thermal_throttling_status_event {
  864. __le32 time_on_usec;
  865. __le32 time_off_usec;
  866. __le32 max_txop_length_usec;
  867. } __packed;
  868. /*
  869. * WMI_GET_STATUS_DONE_EVENTID
  870. */
  871. struct wmi_get_status_done_event {
  872. __le32 is_associated;
  873. u8 cid;
  874. u8 reserved0[3];
  875. u8 bssid[WMI_MAC_LEN];
  876. u8 channel;
  877. u8 reserved1;
  878. u8 network_type;
  879. u8 reserved2[3];
  880. __le32 ssid_len;
  881. u8 ssid[WMI_MAX_SSID_LEN];
  882. __le32 rf_status;
  883. __le32 is_secured;
  884. } __packed;
  885. /*
  886. * WMI_FW_VER_EVENTID
  887. */
  888. struct wmi_fw_ver_event {
  889. u8 major;
  890. u8 minor;
  891. __le16 subminor;
  892. __le16 build;
  893. } __packed;
  894. /*
  895. * WMI_MAC_ADDR_RESP_EVENTID
  896. */
  897. struct wmi_mac_addr_resp_event {
  898. u8 mac[WMI_MAC_LEN];
  899. u8 auth_mode;
  900. u8 crypt_mode;
  901. __le32 offload_mode;
  902. } __packed;
  903. /*
  904. * WMI_EAPOL_RX_EVENTID
  905. */
  906. struct wmi_eapol_rx_event {
  907. u8 src_mac[WMI_MAC_LEN];
  908. __le16 eapol_len;
  909. u8 eapol[0];
  910. } __packed;
  911. /*
  912. * WMI_READY_EVENTID
  913. */
  914. enum wmi_phy_capability {
  915. WMI_11A_CAPABILITY = 1,
  916. WMI_11G_CAPABILITY = 2,
  917. WMI_11AG_CAPABILITY = 3,
  918. WMI_11NA_CAPABILITY = 4,
  919. WMI_11NG_CAPABILITY = 5,
  920. WMI_11NAG_CAPABILITY = 6,
  921. WMI_11AD_CAPABILITY = 7,
  922. WMI_11N_CAPABILITY_OFFSET = WMI_11NA_CAPABILITY - WMI_11A_CAPABILITY,
  923. };
  924. struct wmi_ready_event {
  925. __le32 sw_version;
  926. __le32 abi_version;
  927. u8 mac[WMI_MAC_LEN];
  928. u8 phy_capability; /* enum wmi_phy_capability */
  929. u8 numof_additional_mids;
  930. } __packed;
  931. /*
  932. * WMI_NOTIFY_REQ_DONE_EVENTID
  933. */
  934. struct wmi_notify_req_done_event {
  935. __le32 status; /* beamforming status, 0: fail; 1: OK; 2: retrying */
  936. __le64 tsf;
  937. __le32 snr_val;
  938. __le32 tx_tpt;
  939. __le32 tx_goodput;
  940. __le32 rx_goodput;
  941. __le16 bf_mcs;
  942. __le16 my_rx_sector;
  943. __le16 my_tx_sector;
  944. __le16 other_rx_sector;
  945. __le16 other_tx_sector;
  946. __le16 range;
  947. u8 sqi;
  948. u8 reserved[3];
  949. } __packed;
  950. /*
  951. * WMI_CONNECT_EVENTID
  952. */
  953. struct wmi_connect_event {
  954. u8 channel;
  955. u8 reserved0;
  956. u8 bssid[WMI_MAC_LEN];
  957. __le16 listen_interval;
  958. __le16 beacon_interval;
  959. u8 network_type;
  960. u8 reserved1[3];
  961. u8 beacon_ie_len;
  962. u8 assoc_req_len;
  963. u8 assoc_resp_len;
  964. u8 cid;
  965. u8 reserved2[3];
  966. u8 assoc_info[0];
  967. } __packed;
  968. /*
  969. * WMI_DISCONNECT_EVENTID
  970. */
  971. enum wmi_disconnect_reason {
  972. WMI_DIS_REASON_NO_NETWORK_AVAIL = 1,
  973. WMI_DIS_REASON_LOST_LINK = 2, /* bmiss */
  974. WMI_DIS_REASON_DISCONNECT_CMD = 3,
  975. WMI_DIS_REASON_BSS_DISCONNECTED = 4,
  976. WMI_DIS_REASON_AUTH_FAILED = 5,
  977. WMI_DIS_REASON_ASSOC_FAILED = 6,
  978. WMI_DIS_REASON_NO_RESOURCES_AVAIL = 7,
  979. WMI_DIS_REASON_CSERV_DISCONNECT = 8,
  980. WMI_DIS_REASON_INVALID_PROFILE = 10,
  981. WMI_DIS_REASON_DOT11H_CHANNEL_SWITCH = 11,
  982. WMI_DIS_REASON_PROFILE_MISMATCH = 12,
  983. WMI_DIS_REASON_CONNECTION_EVICTED = 13,
  984. WMI_DIS_REASON_IBSS_MERGE = 14,
  985. };
  986. struct wmi_disconnect_event {
  987. __le16 protocol_reason_status; /* reason code, see 802.11 spec. */
  988. u8 bssid[WMI_MAC_LEN]; /* set if known */
  989. u8 disconnect_reason; /* see wmi_disconnect_reason */
  990. u8 assoc_resp_len; /* not used */
  991. u8 assoc_info[0]; /* not used */
  992. } __packed;
  993. /*
  994. * WMI_SCAN_COMPLETE_EVENTID
  995. */
  996. enum scan_status {
  997. WMI_SCAN_SUCCESS = 0,
  998. WMI_SCAN_FAILED = 1,
  999. WMI_SCAN_ABORTED = 2,
  1000. WMI_SCAN_REJECTED = 3,
  1001. };
  1002. struct wmi_scan_complete_event {
  1003. __le32 status; /* scan_status */
  1004. } __packed;
  1005. /*
  1006. * WMI_BA_STATUS_EVENTID
  1007. */
  1008. enum wmi_vring_ba_status {
  1009. WMI_BA_AGREED = 0,
  1010. WMI_BA_NON_AGREED = 1,
  1011. /* BA_EN in middle of teardown flow */
  1012. WMI_BA_TD_WIP = 2,
  1013. /* BA_DIS or BA_EN in middle of BA SETUP flow */
  1014. WMI_BA_SETUP_WIP = 3,
  1015. /* BA_EN when the BA session is already active */
  1016. WMI_BA_SESSION_ACTIVE = 4,
  1017. /* BA_DIS when the BA session is not active */
  1018. WMI_BA_SESSION_NOT_ACTIVE = 5,
  1019. };
  1020. struct wmi_vring_ba_status_event {
  1021. __le16 status; /* enum wmi_vring_ba_status */
  1022. u8 reserved[2];
  1023. u8 ringid;
  1024. u8 agg_wsize;
  1025. __le16 ba_timeout;
  1026. u8 amsdu;
  1027. } __packed;
  1028. /*
  1029. * WMI_DELBA_EVENTID
  1030. */
  1031. struct wmi_delba_event {
  1032. u8 cidxtid;
  1033. u8 from_initiator;
  1034. __le16 reason;
  1035. } __packed;
  1036. /*
  1037. * WMI_VRING_CFG_DONE_EVENTID
  1038. */
  1039. struct wmi_vring_cfg_done_event {
  1040. u8 ringid;
  1041. u8 status;
  1042. u8 reserved[2];
  1043. __le32 tx_vring_tail_ptr;
  1044. } __packed;
  1045. /*
  1046. * WMI_RCP_ADDBA_RESP_SENT_EVENTID
  1047. */
  1048. struct wmi_rcp_addba_resp_sent_event {
  1049. u8 cidxtid;
  1050. u8 reserved;
  1051. __le16 status;
  1052. } __packed;
  1053. /*
  1054. * WMI_RCP_ADDBA_REQ_EVENTID
  1055. */
  1056. struct wmi_rcp_addba_req_event {
  1057. u8 cidxtid;
  1058. u8 dialog_token;
  1059. __le16 ba_param_set; /* ieee80211_ba_parameterset as it received */
  1060. __le16 ba_timeout;
  1061. __le16 ba_seq_ctrl; /* ieee80211_ba_seqstrl field as it received */
  1062. } __packed;
  1063. /*
  1064. * WMI_CFG_RX_CHAIN_DONE_EVENTID
  1065. */
  1066. enum wmi_cfg_rx_chain_done_event_status {
  1067. WMI_CFG_RX_CHAIN_SUCCESS = 1,
  1068. };
  1069. struct wmi_cfg_rx_chain_done_event {
  1070. __le32 rx_ring_tail_ptr; /* Rx V-Ring Tail pointer */
  1071. __le32 status;
  1072. } __packed;
  1073. /*
  1074. * WMI_WBE_LINK_DOWN_EVENTID
  1075. */
  1076. enum wmi_wbe_link_down_event_reason {
  1077. WMI_WBE_REASON_USER_REQUEST = 0,
  1078. WMI_WBE_REASON_RX_DISASSOC = 1,
  1079. WMI_WBE_REASON_BAD_PHY_LINK = 2,
  1080. };
  1081. struct wmi_wbe_link_down_event {
  1082. u8 cid;
  1083. u8 reserved[3];
  1084. __le32 reason;
  1085. } __packed;
  1086. /*
  1087. * WMI_DATA_PORT_OPEN_EVENTID
  1088. */
  1089. struct wmi_data_port_open_event {
  1090. u8 cid;
  1091. u8 reserved[3];
  1092. } __packed;
  1093. /*
  1094. * WMI_VRING_EN_EVENTID
  1095. */
  1096. struct wmi_vring_en_event {
  1097. u8 vring_index;
  1098. u8 reserved[3];
  1099. } __packed;
  1100. /*
  1101. * WMI_GET_PCP_CHANNEL_EVENTID
  1102. */
  1103. struct wmi_get_pcp_channel_event {
  1104. u8 channel;
  1105. u8 reserved[3];
  1106. } __packed;
  1107. /*
  1108. * WMI_P2P_CFG_DONE_EVENTID
  1109. */
  1110. struct wmi_p2p_cfg_done_event {
  1111. u8 status; /* wmi_fw_status */
  1112. u8 reserved[3];
  1113. } __packed;
  1114. /*
  1115. * WMI_PORT_ALLOCATED_EVENTID
  1116. */
  1117. struct wmi_port_allocated_event {
  1118. u8 status; /* wmi_fw_status */
  1119. u8 reserved[3];
  1120. } __packed;
  1121. /*
  1122. * WMI_PORT_DELETED_EVENTID
  1123. */
  1124. struct wmi_port_deleted_event {
  1125. u8 status; /* wmi_fw_status */
  1126. u8 reserved[3];
  1127. } __packed;
  1128. /*
  1129. * WMI_LISTEN_STARTED_EVENTID
  1130. */
  1131. struct wmi_listen_started_event {
  1132. u8 status; /* wmi_fw_status */
  1133. u8 reserved[3];
  1134. } __packed;
  1135. /*
  1136. * WMI_SEARCH_STARTED_EVENTID
  1137. */
  1138. struct wmi_search_started_event {
  1139. u8 status; /* wmi_fw_status */
  1140. u8 reserved[3];
  1141. } __packed;
  1142. /*
  1143. * WMI_PCP_STARTED_EVENTID
  1144. */
  1145. struct wmi_pcp_started_event {
  1146. u8 status; /* wmi_fw_status */
  1147. u8 reserved[3];
  1148. } __packed;
  1149. /*
  1150. * WMI_PCP_FACTOR_EVENTID
  1151. */
  1152. struct wmi_pcp_factor_event {
  1153. __le32 pcp_factor;
  1154. } __packed;
  1155. /*
  1156. * WMI_SW_TX_COMPLETE_EVENTID
  1157. */
  1158. enum wmi_sw_tx_status {
  1159. WMI_TX_SW_STATUS_SUCCESS = 0,
  1160. WMI_TX_SW_STATUS_FAILED_NO_RESOURCES = 1,
  1161. WMI_TX_SW_STATUS_FAILED_TX = 2,
  1162. };
  1163. struct wmi_sw_tx_complete_event {
  1164. u8 status; /* enum wmi_sw_tx_status */
  1165. u8 reserved[3];
  1166. } __packed;
  1167. /*
  1168. * WMI_CORR_MEASURE_EVENTID
  1169. */
  1170. struct wmi_corr_measure_event {
  1171. s32 i;
  1172. s32 q;
  1173. s32 image_i;
  1174. s32 image_q;
  1175. } __packed;
  1176. /*
  1177. * WMI_READ_RSSI_EVENTID
  1178. */
  1179. struct wmi_read_rssi_event {
  1180. __le32 ina_rssi_adc_dbm;
  1181. } __packed;
  1182. /*
  1183. * WMI_GET_SSID_EVENTID
  1184. */
  1185. struct wmi_get_ssid_event {
  1186. __le32 ssid_len;
  1187. u8 ssid[WMI_MAX_SSID_LEN];
  1188. } __packed;
  1189. /*
  1190. * WMI_RX_MGMT_PACKET_EVENTID
  1191. */
  1192. struct wmi_rx_mgmt_info {
  1193. u8 mcs;
  1194. s8 snr;
  1195. u8 range;
  1196. u8 sqi;
  1197. __le16 stype;
  1198. __le16 status;
  1199. __le32 len;
  1200. u8 qid;
  1201. u8 mid;
  1202. u8 cid;
  1203. u8 channel; /* From Radio MNGR */
  1204. } __packed;
  1205. /*
  1206. * WMI_TX_MGMT_PACKET_EVENTID
  1207. */
  1208. struct wmi_tx_mgmt_packet_event {
  1209. u8 payload[0];
  1210. } __packed;
  1211. struct wmi_rx_mgmt_packet_event {
  1212. struct wmi_rx_mgmt_info info;
  1213. u8 payload[0];
  1214. } __packed;
  1215. /*
  1216. * WMI_ECHO_RSP_EVENTID
  1217. */
  1218. struct wmi_echo_event {
  1219. __le32 echoed_value;
  1220. } __packed;
  1221. /*
  1222. * WMI_TEMP_SENSE_DONE_EVENTID
  1223. *
  1224. * Measure MAC and radio temperatures
  1225. */
  1226. struct wmi_temp_sense_done_event {
  1227. __le32 baseband_t1000;
  1228. __le32 rf_t1000;
  1229. } __packed;
  1230. #endif /* __WILOCITY_WMI_H__ */