htt_isoc.h 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244
  1. /*
  2. * Copyright (c) 2012-2016 The Linux Foundation. All rights reserved.
  3. *
  4. * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  5. *
  6. *
  7. * Permission to use, copy, modify, and/or distribute this software for
  8. * any purpose with or without fee is hereby granted, provided that the
  9. * above copyright notice and this permission notice appear in all
  10. * copies.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  13. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  14. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  15. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  16. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  17. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  18. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  19. * PERFORMANCE OF THIS SOFTWARE.
  20. */
  21. /*
  22. * This file was originally distributed by Qualcomm Atheros, Inc.
  23. * under proprietary terms before Copyright ownership was assigned
  24. * to the Linux Foundation.
  25. */
  26. /**
  27. * @file htt_isoc.h
  28. *
  29. * @details
  30. * This file defines the target --> host messages that configure the
  31. * host data-path SW with the information required for data transfers
  32. * to and from the target.
  33. */
  34. #ifndef _HTT_ISOC_H_
  35. #define _HTT_ISOC_H_
  36. #include <a_types.h> /* A_UINT32, A_UINT8 */
  37. #include <a_osapi.h> /* A_COMPILE_TIME_ASSERT */
  38. #ifdef ATHR_WIN_NWF
  39. #pragma warning(disable:4214) /* bit field types other than int */
  40. #endif
  41. #include "htt_common.h"
  42. /*=== definitions that apply to all messages ================================*/
  43. typedef enum htt_isoc_t2h_msg_type {
  44. /* 0x0 reserved for VERSION message (probably not needed) */
  45. /* PEER_INFO - specify ID and parameters of a new peer */
  46. HTT_ISOC_T2H_MSG_TYPE_PEER_INFO = 0x1,
  47. /* PEER_UNMAP - deallocate the ID that refers to a peer */
  48. HTT_ISOC_T2H_MSG_TYPE_PEER_UNMAP = 0x2,
  49. /* ADDBA - start rx aggregation for the specified peer-TID */
  50. HTT_ISOC_T2H_MSG_TYPE_RX_ADDBA = 0x3,
  51. /* DELBA - stop rx aggregation for the specified peer-TID */
  52. HTT_ISOC_T2H_MSG_TYPE_RX_DELBA = 0x4,
  53. /* TX_COMPL_IND - over-the-air tx completion notification for a tx frame */
  54. HTT_ISOC_T2H_MSG_TYPE_TX_COMPL_IND = 0x5,
  55. /* SEC_IND - notification of the type of security used for a new peer */
  56. HTT_ISOC_T2H_MSG_TYPE_SEC_IND = 0x6,
  57. /* PEER_TX_READY - the target is ready to transmit to a new peer */
  58. HTT_ISOC_T2H_MSG_TYPE_PEER_TX_READY = 0x7,
  59. /* RX_ERR - notification that an rx frame was discarded due to errors */
  60. HTT_ISOC_T2H_MSG_TYPE_RX_ERR = 0x8,
  61. /* NLO_MATCH - notification that target found NLO match */
  62. HTT_ISOC_T2H_MSG_TYPE_NLO_MATCH = 0x9,
  63. /* NLO_SCAN_END - notification that target NLO SCAN END 1:1 map with NLO_MATCH */
  64. HTT_ISOC_T2H_MSG_TYPE_NLO_SCAN_END = 0xA,
  65. /* keep this last */
  66. HTT_ISOC_T2H_NUM_MSGS
  67. } htt_isoc_t2h_msg_type;
  68. /*
  69. * HTT ISOC target to host message type -
  70. * stored in bits 7:0 of the first word of the message
  71. */
  72. #define HTT_ISOC_T2H_MSG_TYPE_M 0xff
  73. #define HTT_ISOC_T2H_MSG_TYPE_S 0
  74. #define HTT_ISOC_T2H_MSG_TYPE_SET(msg_addr, msg_type) \
  75. (*((A_UINT8 *) msg_addr) = (msg_type))
  76. #define HTT_ISOC_T2H_MSG_TYPE_GET(msg_addr) \
  77. (*((A_UINT8 *) msg_addr))
  78. #ifndef INLINE
  79. #ifdef QCA_SUPPORT_INTEGRATED_SOC
  80. /* host SW */
  81. #define INLINE inline
  82. #else
  83. /* target FW */
  84. #define INLINE __inline
  85. #endif
  86. #define HTT_ISOC_INLINE_DEF
  87. #endif /* INLINE */
  88. static INLINE void
  89. htt_isoc_t2h_field_set(
  90. A_UINT32 *msg_addr32,
  91. unsigned offset32,
  92. unsigned mask,
  93. unsigned shift,
  94. unsigned value)
  95. {
  96. /* sanity check: make sure the value fits within the field */
  97. /* qdf_assert(value << shift == (value << shift) | mask); */
  98. msg_addr32 += offset32;
  99. /* clear the field */
  100. *msg_addr32 &= ~mask;
  101. /* write the new value */
  102. *msg_addr32 |= (value << shift);
  103. }
  104. #ifdef HTT_ISOC_INLINE_DEF
  105. #undef HTT_ISOC_INLINE_DEF
  106. #undef INLINE
  107. #endif
  108. #define HTT_ISOC_T2H_FIELD_GET(msg_addr32, offset32, mask, shift) \
  109. (((*(msg_addr32 + offset32)) & mask) >> shift)
  110. typedef enum {
  111. /* ASSOC - "real" peer from STA-AP association */
  112. HTT_ISOC_T2H_PEER_TYPE_ASSOC = 0x0,
  113. /* SELF - self-peer for unicast tx to unassociated peer */
  114. HTT_ISOC_T2H_PEER_TYPE_SELF = 0x1,
  115. /* BSSID - reserved for FW use for BT-AMP+IBSS */
  116. HTT_ISOC_T2H_PEER_TYPE_BSSID = 0x2,
  117. /* BCAST - self-peer for multicast / broadcast tx */
  118. HTT_ISOC_T2H_PEER_TYPE_BCAST = 0x3
  119. } HTT_ISOC_T2H_PEER_TYPE_ENUM;
  120. enum {
  121. HTT_ISOC_NON_QOS = 0,
  122. HTT_ISOC_QOS = 1
  123. };
  124. enum {
  125. HTT_ISOC_RMF_DISABLED = 0,
  126. HTT_ISOC_RMF_ENABLED = 1
  127. };
  128. enum {
  129. HTT_ISOC_TID_MGMT = 7
  130. };
  131. /*=== definitions for specific messages =====================================*/
  132. /*=== PEER_INFO message ===*/
  133. /**
  134. * @brief target -> host peer info message definition
  135. *
  136. * @details
  137. * The following diagram shows the format of the peer info message sent
  138. * from the target to the host. This layout assumes the target operates
  139. * as little-endian.
  140. *
  141. * |31 25|24|23 18|17|16|15 11|10|9|8|7|6| 0|
  142. * |-----------------------------------------------------------------------|
  143. * | mgmt DPU idx | bcast DPU idx | DPU idx | msg type |
  144. * |-----------------------------------------------------------------------|
  145. * | mgmt DPU sig |bcast DPU sig | DPU sig | peer ID |
  146. * |-----------------------------------------------------------------------|
  147. * | MAC addr 1 | MAC addr 0 | vdev ID | |R| peer type |
  148. * |-----------------------------------------------------------------------|
  149. * | MAC addr 5 | MAC addr 4 | MAC addr 3 | MAC addr 2 |
  150. * |-----------------------------------------------------------------------|
  151. *
  152. *
  153. * The following field definitions describe the format of the peer info
  154. * message sent from the target to the host.
  155. *
  156. * WORD 0:
  157. * - MSG_TYPE
  158. * Bits 7:0
  159. * Purpose: identifies this as peer info message
  160. * Value: 0x1
  161. * - DPU_IDX
  162. * Bits 15:8
  163. * Purpose: specify the DPU index (a.k.a. security key ID) to use for
  164. * unicast data frames sent to this peer
  165. * Value: key ID
  166. * - BCAST_DPU_IDX
  167. * Bits 23:16
  168. * Purpose: specify the DPU index (a.k.a. security key ID) to use for
  169. * broadcast data frames sent by this (self) peer
  170. * Value: key ID
  171. * - MGMT_DPU_IDX
  172. * Bits 31:24
  173. * Purpose: specify the DPU index (a.k.a. security key ID) to use for
  174. * unicast management frames sent by this (self) peer
  175. * Value: key ID
  176. * WORD 1:
  177. * - PEER_ID
  178. * Bits 10:0
  179. * Purpose: The ID that the target has allocated to refer to the peer
  180. * - DPU_SIG
  181. * Bits 17:11
  182. * Purpose: specify the DPU signature (a.k.a. security key validity
  183. * magic number) to specify for unicast data frames sent to this peer
  184. * - BCAST_DPU_SIG
  185. * Bits 24:18
  186. * Purpose: specify the DPU signature (a.k.a. security key validity
  187. * magic number) to specify for broadcast data frames sent by this
  188. * (self) peer
  189. * - MGMT_DPU_SIG
  190. * Bits 31:25
  191. * Purpose: specify the DPU signature (a.k.a. security key validity
  192. * magic number) to specify for unicast management frames sent by this
  193. * (self) peer
  194. * WORD 2:
  195. * - PEER_TYPE
  196. * Bits 5:0
  197. * Purpose: specify whether the peer in question is a real peer or
  198. * one of the types of "self-peer" created for the vdev
  199. * Value: HTT_ISOC_T2H_PEER_TYPE enum
  200. * - RMF_ENABLED (R)
  201. * Bit 6
  202. * Purpose: specify whether the peer in question has enable robust
  203. * management frames, to encrypt certain managment frames
  204. * Value: HTT_ISOC_RMF enum
  205. * Value: HTT_ISOC_NON_QOS or HTT_ISOC_QOS
  206. * - VDEV_ID
  207. * Bits 15:8
  208. * Purpose: For a real peer, the vdev ID indicates which virtual device
  209. * the peer is associated with. For a self-peer, the vdev ID shows
  210. * which virtual device the self-peer represents.
  211. * - MAC_ADDR_L16
  212. * Bits 31:16
  213. * Purpose: Identifies which peer the peer ID is for.
  214. * Value: lower 2 bytes of the peer's MAC address
  215. * For a self-peer, the peer's MAC address is the MAC address of the
  216. * vdev the self-peer represents.
  217. * WORD 3:
  218. * - MAC_ADDR_U32
  219. * Bits 31:0
  220. * Purpose: Identifies which peer the peer ID is for.
  221. * Value: upper 4 bytes of the peer's MAC address
  222. * For a self-peer, the peer's MAC address is the MAC address of the
  223. * vdev the self-peer represents.
  224. */
  225. typedef struct htt_isoc_t2h_peer_info_s {
  226. /* word 0 */
  227. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_PEER_INFO */
  228. dpu_idx:8, bcast_dpu_idx:8, mgmt_dpu_idx:8;
  229. /* word 1 */
  230. A_UINT32 peer_id:11, dpu_sig:7, bcast_dpu_sig:7, mgmt_dpu_sig:7;
  231. /* word 2 */
  232. A_UINT32
  233. peer_type:6, rmf_enabled:1, reserved0:1, vdev_id:8, mac_addr_l16:16;
  234. /* word 3 */
  235. A_UINT32 mac_addr_u32;
  236. } htt_isoc_t2h_peer_info_t;
  237. /* word 0 */
  238. #define HTT_ISOC_T2H_PEER_INFO_DPU_IDX_OFFSET32 0
  239. #define HTT_ISOC_T2H_PEER_INFO_DPU_IDX_M 0x0000ff00
  240. #define HTT_ISOC_T2H_PEER_INFO_DPU_IDX_S 8
  241. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_OFFSET32 0
  242. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_M 0x00ff0000
  243. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_S 16
  244. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_OFFSET32 0
  245. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_M 0xff000000
  246. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_S 24
  247. /* word 1 */
  248. #define HTT_ISOC_T2H_PEER_INFO_PEER_ID_OFFSET32 1
  249. #define HTT_ISOC_T2H_PEER_INFO_PEER_ID_M 0x000007ff
  250. #define HTT_ISOC_T2H_PEER_INFO_PEER_ID_S 0
  251. #define HTT_ISOC_T2H_PEER_INFO_DPU_SIG_OFFSET32 1
  252. #define HTT_ISOC_T2H_PEER_INFO_DPU_SIG_M 0x0003f800
  253. #define HTT_ISOC_T2H_PEER_INFO_DPU_SIG_S 11
  254. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_OFFSET32 1
  255. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_M 0x01fc0000
  256. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_S 18
  257. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_SIG_OFFSET32 1
  258. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_SIG_M 0xfe000000
  259. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_SIG_S 25
  260. /* word 2 */
  261. #define HTT_ISOC_T2H_PEER_INFO_PEER_TYPE_OFFSET32 2
  262. #define HTT_ISOC_T2H_PEER_INFO_PEER_TYPE_M 0x0000003f
  263. #define HTT_ISOC_T2H_PEER_INFO_PEER_TYPE_S 0
  264. #define HTT_ISOC_T2H_PEER_INFO_RMF_ENABLED_OFFSET32 2
  265. #define HTT_ISOC_T2H_PEER_INFO_RMF_ENABLED_M 0x00000040
  266. #define HTT_ISOC_T2H_PEER_INFO_RMF_ENABLED_S 6
  267. #define HTT_ISOC_T2H_PEER_INFO_VDEV_ID_OFFSET32 2
  268. #define HTT_ISOC_T2H_PEER_INFO_VDEV_ID_M 0x0000ff00
  269. #define HTT_ISOC_T2H_PEER_INFO_VDEV_ID_S 8
  270. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_L16_OFFSET32 2
  271. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_L16_M 0xffff0000
  272. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_L16_S 16
  273. /* word 3 */
  274. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_U32_OFFSET32 3
  275. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_U32_M 0xffffffff
  276. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_U32_S 0
  277. /* general field access macros */
  278. #define HTT_ISOC_T2H_PEER_INFO_FIELD_SET(field, msg_addr, value) \
  279. htt_isoc_t2h_field_set( \
  280. ((A_UINT32 *) msg_addr), \
  281. HTT_ISOC_T2H_PEER_INFO_ ## field ## _OFFSET32, \
  282. HTT_ISOC_T2H_PEER_INFO_ ## field ## _M, \
  283. HTT_ISOC_T2H_PEER_INFO_ ## field ## _S, \
  284. value)
  285. #define HTT_ISOC_T2H_PEER_INFO_FIELD_GET(field, msg_addr) \
  286. HTT_ISOC_T2H_FIELD_GET( \
  287. ((A_UINT32 *) msg_addr), \
  288. HTT_ISOC_T2H_PEER_INFO_ ## field ## _OFFSET32, \
  289. HTT_ISOC_T2H_PEER_INFO_ ## field ## _M, \
  290. HTT_ISOC_T2H_PEER_INFO_ ## field ## _S)
  291. /* access macros for specific fields */
  292. #define HTT_ISOC_T2H_PEER_INFO_DPU_IDX_SET(msg_addr, value) \
  293. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(DPU_IDX, msg_addr, value)
  294. #define HTT_ISOC_T2H_PEER_INFO_DPU_IDX_GET(msg_addr) \
  295. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(DPU_IDX, msg_addr)
  296. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_M_Size_Check,
  297. (HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_M >> HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_S) \
  298. <= ((A_UINT8)~((A_UINT8)0)));
  299. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_SET(msg_addr, value) \
  300. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(BCAST_DPU_IDX, msg_addr, value)
  301. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_IDX_GET(msg_addr) \
  302. (A_UINT8)(HTT_ISOC_T2H_PEER_INFO_FIELD_GET(BCAST_DPU_IDX, msg_addr))
  303. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_M_Size_Check,
  304. (HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_M >> HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_S) \
  305. <= ((A_UINT8)~((A_UINT8)0)));
  306. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_SET(msg_addr, value) \
  307. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(MGMT_DPU_IDX, msg_addr, value)
  308. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_IDX_GET(msg_addr) \
  309. (A_UINT8)(HTT_ISOC_T2H_PEER_INFO_FIELD_GET(MGMT_DPU_IDX, msg_addr))
  310. #define HTT_ISOC_T2H_PEER_INFO_PEER_ID_SET(msg_addr, value) \
  311. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(PEER_ID, msg_addr, value)
  312. #define HTT_ISOC_T2H_PEER_INFO_PEER_ID_GET(msg_addr) \
  313. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(PEER_ID, msg_addr)
  314. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_INFO_DPU_SIG_M_Size_Check,
  315. (HTT_ISOC_T2H_PEER_INFO_DPU_SIG_M >> HTT_ISOC_T2H_PEER_INFO_DPU_SIG_S)\
  316. <= ((A_UINT8)~((A_UINT8)0)));
  317. #define HTT_ISOC_T2H_PEER_INFO_DPU_SIG_SET(msg_addr, value) \
  318. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(DPU_SIG, msg_addr, value)
  319. #define HTT_ISOC_T2H_PEER_INFO_DPU_SIG_GET(msg_addr) \
  320. (A_UINT8)(HTT_ISOC_T2H_PEER_INFO_FIELD_GET(DPU_SIG, msg_addr))
  321. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_M_Size_Check,
  322. (HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_M >> HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_S)\
  323. <= ((A_UINT8)~((A_UINT8)0)));
  324. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_SET(msg_addr, value) \
  325. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(BCAST_DPU_SIG, msg_addr, value)
  326. #define HTT_ISOC_T2H_PEER_INFO_BCAST_DPU_SIG_GET(msg_addr) \
  327. (A_UINT8)(HTT_ISOC_T2H_PEER_INFO_FIELD_GET(BCAST_DPU_SIG, msg_addr))
  328. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_SIG_SET(msg_addr, value) \
  329. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(MGMT_DPU_SIG, msg_addr, value)
  330. #define HTT_ISOC_T2H_PEER_INFO_MGMT_DPU_SIG_GET(msg_addr) \
  331. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(MGMT_DPU_SIG, msg_addr)
  332. #define HTT_ISOC_T2H_PEER_INFO_PEER_TYPE_SET(msg_addr, value) \
  333. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(PEER_TYPE, msg_addr, value)
  334. #define HTT_ISOC_T2H_PEER_INFO_PEER_TYPE_GET(msg_addr) \
  335. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(PEER_TYPE, msg_addr)
  336. #define HTT_ISOC_T2H_PEER_INFO_QOS_CAPABLE_SET(msg_addr, value) \
  337. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(QOS_CAPABLE, msg_addr, value)
  338. #define HTT_ISOC_T2H_PEER_INFO_QOS_CAPABLE_GET(msg_addr) \
  339. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(QOS_CAPABLE, msg_addr)
  340. #define HTT_ISOC_T2H_PEER_INFO_RMF_ENABLED_SET(msg_addr, value) \
  341. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(RMF_ENABLED, msg_addr, value)
  342. #define HTT_ISOC_T2H_PEER_INFO_RMF_ENABLED_GET(msg_addr) \
  343. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(RMF_ENABLED, msg_addr)
  344. #define HTT_ISOC_T2H_PEER_INFO_VDEV_ID_SET(msg_addr, value) \
  345. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(VDEV_ID, msg_addr, value)
  346. #define HTT_ISOC_T2H_PEER_INFO_VDEV_ID_GET(msg_addr) \
  347. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(VDEV_ID, msg_addr)
  348. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_L16_SET(msg_addr, value) \
  349. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(MAC_ADDR_L16, msg_addr, value)
  350. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_L16_GET(msg_addr) \
  351. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(MAC_ADDR_L16, msg_addr)
  352. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_U32_SET(msg_addr, value) \
  353. HTT_ISOC_T2H_PEER_INFO_FIELD_SET(MAC_ADDR_U32, msg_addr, value)
  354. #define HTT_ISOC_T2H_PEER_INFO_MAC_ADDR_U32_GET(msg_addr) \
  355. HTT_ISOC_T2H_PEER_INFO_FIELD_GET(MAC_ADDR_U32, msg_addr)
  356. /*=== PEER_UNMAP message ===*/
  357. /**
  358. * @brief target -> host peer unmap message definition
  359. *
  360. * @details
  361. * The following diagram shows the format of the peer unmap message sent
  362. * from the target to the host. This layout assumes the target operates
  363. * as little-endian.
  364. *
  365. * |31 19|18 8|7 0|
  366. * |-----------------------------------------------------------------------|
  367. * | reserved | peer ID | msg type |
  368. * |-----------------------------------------------------------------------|
  369. *
  370. *
  371. * The following field definitions describe the format of the peer info
  372. * message sent from the target to the host.
  373. *
  374. * WORD 0:
  375. * - MSG_TYPE
  376. * Bits 7:0
  377. * Purpose: identifies this as peer unmap message
  378. * Value: 0x2
  379. * - PEER_ID
  380. * Bits 18:8
  381. * Purpose: The ID that the target has allocated to refer to the peer
  382. */
  383. typedef struct htt_isoc_t2h_peer_unmap_s {
  384. /* word 0 */
  385. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_PEER_UNMAP */
  386. peer_id:11, reserved0:13;
  387. } htt_isoc_t2h_peer_unmap_t;
  388. /* word 0 */
  389. #define HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_OFFSET32 0
  390. #define HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_M 0x0007ff00
  391. #define HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_S 8
  392. /* general field access macros */
  393. #define HTT_ISOC_T2H_PEER_UNMAP_FIELD_SET(field, msg_addr, value) \
  394. htt_isoc_t2h_field_set( \
  395. ((A_UINT32 *) msg_addr), \
  396. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _OFFSET32, \
  397. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _M, \
  398. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _S, \
  399. value)
  400. #define HTT_ISOC_T2H_PEER_UNMAP_FIELD_GET(field, msg_addr) \
  401. HTT_ISOC_T2H_FIELD_GET( \
  402. ((A_UINT32 *) msg_addr), \
  403. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _OFFSET32, \
  404. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _M, \
  405. HTT_ISOC_T2H_PEER_UNMAP_ ## field ## _S)
  406. /* access macros for specific fields */
  407. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_M_Size_Check,
  408. (HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_M >> HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_S) \
  409. < ((A_UINT16)~((A_UINT16)0)));
  410. #define HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_SET(msg_addr, value) \
  411. HTT_ISOC_T2H_PEER_UNMAP_FIELD_SET(PEER_ID, msg_addr, value)
  412. #define HTT_ISOC_T2H_PEER_UNMAP_PEER_ID_GET(msg_addr) \
  413. (A_UINT16)(HTT_ISOC_T2H_PEER_UNMAP_FIELD_GET(PEER_ID, msg_addr))
  414. /*=== ADDBA message ===*/
  415. enum {
  416. htt_isoc_addba_success = 0,
  417. /* TBD: use different failure values to specify failure causes? */
  418. htt_isoc_addba_fail = 1,
  419. };
  420. /**
  421. * @brief target -> host ADDBA message definition
  422. *
  423. * @details
  424. * The following diagram shows the format of the rx ADDBA message sent
  425. * from the target to the host:
  426. *
  427. * |31 20|19 16|15 12|11 8|7 0|
  428. * |---------------------------------------------------------------------|
  429. * | peer ID | TID | window size | msg type |
  430. * |---------------------------------------------------------------------|
  431. * | reserved |S| start seq num |
  432. * |---------------------------------------------------------------------|
  433. *
  434. * The following field definitions describe the format of the ADDBA
  435. * message sent from the target to the host.
  436. *
  437. * WORD 0:
  438. * - MSG_TYPE
  439. * Bits 7:0
  440. * Purpose: identifies this as an ADDBA message
  441. * Value: 0x3
  442. * - WIN_SIZE
  443. * Bits 15:8
  444. * Purpose: Specifies the length of the block ack window (max = 64).
  445. * Value:
  446. * block ack window length specified by the received ADDBA
  447. * management message.
  448. * - TID
  449. * Bits 19:16
  450. * Purpose: Specifies which traffic identifier the ADDBA is for.
  451. * Value:
  452. * TID specified by the received ADDBA management message.
  453. * - PEER_ID
  454. * Bits 31:20
  455. * Purpose: Identifies which peer sent the ADDBA.
  456. * Value:
  457. * ID (hash value) used by the host for fast, direct lookup of
  458. * host SW peer info, including rx reorder states.
  459. * - START_SEQ_NUM
  460. * Bits 11:0
  461. * Purpose: Specifies the initial location of the block ack window
  462. * Value: start sequence value specified by the ADDBA-request message
  463. * - STATUS
  464. * Bit 12
  465. * Purpose: status of the WMI ADDBA request
  466. * Value: 0 - SUCCESS, 1 - FAILURE
  467. */
  468. typedef struct htt_isoc_t2h_addba_s {
  469. /* word 0 */
  470. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_ADDBA */
  471. win_size:8, tid:4, peer_id:12;
  472. /* word 1 */
  473. A_UINT32 start_seq_num:12, status:1, reserved0:19;
  474. } htt_isoc_t2h_addba_t;
  475. /* word 0 */
  476. #define HTT_ISOC_T2H_ADDBA_WIN_SIZE_OFFSET32 0
  477. #define HTT_ISOC_T2H_ADDBA_WIN_SIZE_M 0x0000ff00
  478. #define HTT_ISOC_T2H_ADDBA_WIN_SIZE_S 8
  479. #define HTT_ISOC_T2H_ADDBA_TID_OFFSET32 0
  480. #define HTT_ISOC_T2H_ADDBA_TID_M 0x000f0000
  481. #define HTT_ISOC_T2H_ADDBA_TID_S 16
  482. #define HTT_ISOC_T2H_ADDBA_PEER_ID_OFFSET32 0
  483. #define HTT_ISOC_T2H_ADDBA_PEER_ID_M 0xfff00000
  484. #define HTT_ISOC_T2H_ADDBA_PEER_ID_S 20
  485. /* word 1 */
  486. #define HTT_ISOC_T2H_ADDBA_START_SEQ_NUM_OFFSET32 1
  487. #define HTT_ISOC_T2H_ADDBA_START_SEQ_NUM_M 0x00000fff
  488. #define HTT_ISOC_T2H_ADDBA_START_SEQ_NUM_S 0
  489. #define HTT_ISOC_T2H_ADDBA_STATUS_OFFSET32 1
  490. #define HTT_ISOC_T2H_ADDBA_STATUS_M 0x00001000
  491. #define HTT_ISOC_T2H_ADDBA_STATUS_S 12
  492. /* general field access macros */
  493. #define HTT_ISOC_T2H_ADDBA_FIELD_SET(field, msg_addr, value) \
  494. htt_isoc_t2h_field_set( \
  495. ((A_UINT32 *) msg_addr), \
  496. HTT_ISOC_T2H_ADDBA_ ## field ## _OFFSET32, \
  497. HTT_ISOC_T2H_ADDBA_ ## field ## _M, \
  498. HTT_ISOC_T2H_ADDBA_ ## field ## _S, \
  499. value)
  500. #define HTT_ISOC_T2H_ADDBA_FIELD_GET(field, msg_addr) \
  501. HTT_ISOC_T2H_FIELD_GET( \
  502. ((A_UINT32 *) msg_addr), \
  503. HTT_ISOC_T2H_ADDBA_ ## field ## _OFFSET32, \
  504. HTT_ISOC_T2H_ADDBA_ ## field ## _M, \
  505. HTT_ISOC_T2H_ADDBA_ ## field ## _S)
  506. /* access macros for specific fields */
  507. #define HTT_ISOC_T2H_ADDBA_WIN_SIZE_SET(msg_addr, value) \
  508. HTT_ISOC_T2H_ADDBA_FIELD_SET(WIN_SIZE, msg_addr, value)
  509. #define HTT_ISOC_T2H_ADDBA_WIN_SIZE_GET(msg_addr) \
  510. HTT_ISOC_T2H_ADDBA_FIELD_GET(WIN_SIZE, msg_addr)
  511. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_ADDBA_TID_M_Size_Check,
  512. (HTT_ISOC_T2H_ADDBA_TID_M >> HTT_ISOC_T2H_ADDBA_TID_S) \
  513. < ((A_UINT8)~((A_UINT8)0)));
  514. #define HTT_ISOC_T2H_ADDBA_TID_SET(msg_addr, value) \
  515. HTT_ISOC_T2H_ADDBA_FIELD_SET(TID, msg_addr, value)
  516. #define HTT_ISOC_T2H_ADDBA_TID_GET(msg_addr) \
  517. (A_UINT8)(HTT_ISOC_T2H_ADDBA_FIELD_GET(TID, msg_addr))
  518. #define HTT_ISOC_T2H_ADDBA_PEER_ID_SET(msg_addr, value) \
  519. HTT_ISOC_T2H_ADDBA_FIELD_SET(PEER_ID, msg_addr, value)
  520. #define HTT_ISOC_T2H_ADDBA_PEER_ID_GET(msg_addr) \
  521. HTT_ISOC_T2H_ADDBA_FIELD_GET(PEER_ID, msg_addr)
  522. #define HTT_ISOC_T2H_ADDBA_START_SEQ_NUM_SET(msg_addr, value) \
  523. HTT_ISOC_T2H_ADDBA_FIELD_SET(START_SEQ_NUM, msg_addr, value)
  524. #define HTT_ISOC_T2H_ADDBA_START_SEQ_NUM_GET(msg_addr) \
  525. HTT_ISOC_T2H_ADDBA_FIELD_GET(START_SEQ_NUM, msg_addr)
  526. #define HTT_ISOC_T2H_ADDBA_STATUS_SET(msg_addr, value) \
  527. HTT_ISOC_T2H_ADDBA_FIELD_SET(STATUS, msg_addr, value)
  528. #define HTT_ISOC_T2H_ADDBA_STATUS_GET(msg_addr) \
  529. HTT_ISOC_T2H_ADDBA_FIELD_GET(STATUS, msg_addr)
  530. /*=== DELBA message ===*/
  531. /**
  532. * @brief target -> host DELBA message definition
  533. *
  534. * @details
  535. * The following diagram shows the format of the rx DELBA message sent
  536. * from the target to the host:
  537. *
  538. * |31 20|19 16|15 12|11 8|7 0|
  539. * |---------------------------------------------------------------------|
  540. * | peer ID | TID | reserved |S| msg type |
  541. * |---------------------------------------------------------------------|
  542. *
  543. * The following field definitions describe the format of the ADDBA
  544. * message sent from the target to the host.
  545. *
  546. * WORD 0:
  547. * - MSG_TYPE
  548. * Bits 7:0
  549. * Purpose: identifies this as an DELBA message
  550. * Value: 0x4
  551. * - TID
  552. * Bits 19:16
  553. * Purpose: Specifies which traffic identifier the DELBA is for.
  554. * Value:
  555. * TID specified by the received DELBA management message.
  556. * - PEER_ID
  557. * Bits 31:20
  558. * Purpose: Identifies which peer sent the DELBA.
  559. * Value:
  560. * ID (hash value) used by the host for fast, direct lookup of
  561. * host SW peer info, including rx reorder states.
  562. * - STATUS
  563. * Bit 8
  564. * Purpose: status of the WMI DELBA request
  565. * Value: 0 - SUCCESS, 1 - FAILURE
  566. */
  567. typedef struct htt_isoc_t2h_delba_s {
  568. /* word 0 */
  569. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_DELBA */
  570. status:1, reserved0:7, tid:4, peer_id:12;
  571. } htt_isoc_t2h_delba_t;
  572. /* word 0 */
  573. #define HTT_ISOC_T2H_DELBA_TID_OFFSET32 0
  574. #define HTT_ISOC_T2H_DELBA_TID_M 0x000f0000
  575. #define HTT_ISOC_T2H_DELBA_TID_S 16
  576. #define HTT_ISOC_T2H_DELBA_PEER_ID_OFFSET32 0
  577. #define HTT_ISOC_T2H_DELBA_PEER_ID_M 0xfff00000
  578. #define HTT_ISOC_T2H_DELBA_PEER_ID_S 20
  579. #define HTT_ISOC_T2H_DELBA_STATUS_OFFSET32 0
  580. #define HTT_ISOC_T2H_DELBA_STATUS_M 0x00000100
  581. #define HTT_ISOC_T2H_DELBA_STATUS_S 8
  582. /* general field access macros */
  583. #define HTT_ISOC_T2H_DELBA_FIELD_SET(field, msg_addr, value) \
  584. htt_isoc_t2h_field_set( \
  585. ((A_UINT32 *) msg_addr), \
  586. HTT_ISOC_T2H_DELBA_ ## field ## _OFFSET32, \
  587. HTT_ISOC_T2H_DELBA_ ## field ## _M, \
  588. HTT_ISOC_T2H_DELBA_ ## field ## _S, \
  589. value)
  590. #define HTT_ISOC_T2H_DELBA_FIELD_GET(field, msg_addr) \
  591. HTT_ISOC_T2H_FIELD_GET( \
  592. ((A_UINT32 *) msg_addr), \
  593. HTT_ISOC_T2H_DELBA_ ## field ## _OFFSET32, \
  594. HTT_ISOC_T2H_DELBA_ ## field ## _M, \
  595. HTT_ISOC_T2H_DELBA_ ## field ## _S)
  596. /* access macros for specific fields */
  597. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_DELBA_TID_M_Size_Check,
  598. (HTT_ISOC_T2H_DELBA_TID_M >> HTT_ISOC_T2H_DELBA_TID_S) \
  599. < ((A_UINT8)~((A_UINT8)0)));
  600. #define HTT_ISOC_T2H_DELBA_TID_SET(msg_addr, value) \
  601. HTT_ISOC_T2H_DELBA_FIELD_SET(TID, msg_addr, value)
  602. #define HTT_ISOC_T2H_DELBA_TID_GET(msg_addr) \
  603. (A_UINT8)HTT_ISOC_T2H_DELBA_FIELD_GET(TID, msg_addr)
  604. #define HTT_ISOC_T2H_DELBA_PEER_ID_SET(msg_addr, value) \
  605. HTT_ISOC_T2H_DELBA_FIELD_SET(PEER_ID, msg_addr, value)
  606. #define HTT_ISOC_T2H_DELBA_PEER_ID_GET(msg_addr) \
  607. HTT_ISOC_T2H_DELBA_FIELD_GET(PEER_ID, msg_addr)
  608. #define HTT_ISOC_T2H_DELBA_STATUS_SET(msg_addr, value) \
  609. HTT_ISOC_T2H_DELBA_FIELD_SET(STATUS, msg_addr, value)
  610. #define HTT_ISOC_T2H_DELBA_STATUS_GET(msg_addr) \
  611. HTT_ISOC_T2H_DELBA_FIELD_GET(STATUS, msg_addr)
  612. /*=== SEC_IND message ===*/
  613. /**
  614. * @brief target -> host Security indication message definition
  615. *
  616. * @details
  617. * The following diagram shows the format of the SEC_IND message sent
  618. * from the target to the host. This layout assumes the target operates
  619. * as little-endian.
  620. *
  621. * |31 25|24|23 18|17|16|15 11|10|9|8|7|6| 0|
  622. * |-----------------------------------------------------------------------|
  623. * | is unicast | sec type | Peer id | msg type |
  624. * |-----------------------------------------------------------------------|
  625. * | mic key1 |
  626. * |-----------------------------------------------------------------------|
  627. * | mic key2 |
  628. * |-----------------------------------------------------------------------|
  629. *
  630. *
  631. * The following field definitions describe the format of the peer info
  632. * message sent from the target to the host.
  633. *
  634. * WORD 0:
  635. * - MSG_TYPE
  636. * Bits 7:0
  637. * Purpose: identifies this as SEC_IND message
  638. * Value: 0x6
  639. * - PEER_ID
  640. * Bits 15:8
  641. * Purpose: The ID that the target has allocated to refer to the peer
  642. * Value: Peer ID
  643. * - SEC_TYPE
  644. * Bits 23:16
  645. * Purpose: specify the security encryption type
  646. * Value: htt_sec_type
  647. * - is unicast
  648. * Bits 31:24
  649. * Purpose: specify unicast/bcast
  650. * Value: 1-unicast/0-bcast
  651. * WORD 1:
  652. * - MIC1
  653. * Bits 31:0
  654. * Purpose: Mickey1
  655. * WORD 2:
  656. * - MIC2
  657. * Bits 31:0
  658. * Purpose: Mickey2
  659. */
  660. typedef struct htt_isoc_t2h_sec_ind_s {
  661. /* word 0 */
  662. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_SEC_IND */
  663. peer_id:8, sec_type:8, is_unicast:8;
  664. /* word 1 */
  665. A_UINT32 mic_key1;
  666. /* word 2 */
  667. A_UINT32 mic_key2;
  668. /* word 3 */
  669. A_UINT32 status;
  670. } htt_isoc_t2h_sec_ind_t;
  671. /* word 0 */
  672. #define HTT_ISOC_T2H_SEC_IND_PEER_ID_OFFSET32 0
  673. #define HTT_ISOC_T2H_SEC_IND_PEER_ID_M 0x0000ff00
  674. #define HTT_ISOC_T2H_SEC_IND_PEER_ID_S 8
  675. #define HTT_ISOC_T2H_SEC_IND_SEC_TYPE_OFFSET32 0
  676. #define HTT_ISOC_T2H_SEC_IND_SEC_TYPE_M 0x00ff0000
  677. #define HTT_ISOC_T2H_SEC_IND_SEC_TYPE_S 16
  678. #define HTT_ISOC_T2H_SEC_IND_IS_UNICAST_OFFSET32 0
  679. #define HTT_ISOC_T2H_SEC_IND_IS_UNICAST_M 0xff000000
  680. #define HTT_ISOC_T2H_SEC_IND_IS_UNICAST_S 24
  681. /* word 1 */
  682. #define HTT_ISOC_T2H_SEC_IND_MIC1_OFFSET32 1
  683. #define HTT_ISOC_T2H_SEC_IND_MIC1_M 0xffffffff
  684. #define HTT_ISOC_T2H_SEC_IND_MIC1_S 0
  685. /* word 2 */
  686. #define HTT_ISOC_T2H_SEC_IND_MIC2_OFFSET32 2
  687. #define HTT_ISOC_T2H_SEC_IND_MIC2_M 0xffffffff
  688. #define HTT_ISOC_T2H_SEC_IND_MIC2_S 0
  689. /* general field access macros */
  690. #define HTT_ISOC_T2H_SEC_IND_FIELD_SET(field, msg_addr, value) \
  691. htt_isoc_t2h_field_set( \
  692. ((A_UINT32 *) msg_addr), \
  693. HTT_ISOC_T2H_SEC_IND_ ## field ## _OFFSET32, \
  694. HTT_ISOC_T2H_SEC_IND_ ## field ## _M, \
  695. HTT_ISOC_T2H_SEC_IND_ ## field ## _S, \
  696. value)
  697. #define HTT_ISOC_T2H_SEC_IND_FIELD_GET(field, msg_addr) \
  698. HTT_ISOC_T2H_FIELD_GET( \
  699. ((A_UINT32 *) msg_addr), \
  700. HTT_ISOC_T2H_SEC_IND_ ## field ## _OFFSET32, \
  701. HTT_ISOC_T2H_SEC_IND_ ## field ## _M, \
  702. HTT_ISOC_T2H_SEC_IND_ ## field ## _S)
  703. /* access macros for specific fields */
  704. #define HTT_ISOC_T2H_SEC_IND_PEER_ID_SET(msg_addr, value) \
  705. HTT_ISOC_T2H_SEC_IND_FIELD_SET(PEER_ID, msg_addr, value)
  706. #define HTT_ISOC_T2H_SEC_IND_PEER_ID_GET(msg_addr) \
  707. HTT_ISOC_T2H_SEC_IND_FIELD_GET(PEER_ID, msg_addr)
  708. #define HTT_ISOC_T2H_SEC_IND_SEC_TYPE_SET(msg_addr, value) \
  709. HTT_ISOC_T2H_SEC_IND_FIELD_SET(SEC_TYPE, msg_addr, value)
  710. #define HTT_ISOC_T2H_SEC_IND_SEC_TYPE_GET(msg_addr) \
  711. HTT_ISOC_T2H_SEC_IND_FIELD_GET(SEC_TYPE, msg_addr)
  712. #define HTT_ISOC_T2H_SEC_IND_IS_UNICAST_SET(msg_addr, value) \
  713. HTT_ISOC_T2H_SEC_IND_FIELD_SET(IS_UNICAST, msg_addr, value)
  714. #define HTT_ISOC_T2H_SEC_IND_IS_UNICAST_GET(msg_addr) \
  715. HTT_ISOC_T2H_SEC_IND_FIELD_GET(IS_UNICAST, msg_addr)
  716. #define HTT_ISOC_T2H_SEC_IND_MIC1_SET(msg_addr, value) \
  717. HTT_ISOC_T2H_SEC_IND_FIELD_SET(MIC1, msg_addr, value)
  718. #define HTT_ISOC_T2H_SEC_IND_MIC1_GET(msg_addr) \
  719. HTT_ISOC_T2H_SEC_IND_FIELD_GET(MIC1, msg_addr)
  720. #define HTT_ISOC_T2H_SEC_IND_MIC2_SET(msg_addr, value) \
  721. HTT_ISOC_T2H_SEC_IND_FIELD_SET(MIC2, msg_addr, value)
  722. #define HTT_ISOC_T2H_SEC_IND_MIC2_GET(msg_addr) \
  723. HTT_ISOC_T2H_SEC_IND_FIELD_GET(MIC2, msg_addr)
  724. /*=== PEER_TX_READY message ===*/
  725. /**
  726. * @brief target -> host peer tx ready message definition
  727. *
  728. * @details
  729. * The following diagram shows the format of the peer tx ready message sent
  730. * from the target to the host. This layout assumes the target operates
  731. * as little-endian.
  732. *
  733. * |31 19|18 8|7 0|
  734. * |-----------------------------------------------------------------------|
  735. * | reserved | peer ID | msg type |
  736. * |-----------------------------------------------------------------------|
  737. *
  738. *
  739. * The following field definitions describe the format of the peer info
  740. * message sent from the target to the host.
  741. *
  742. * WORD 0:
  743. * - MSG_TYPE
  744. * Bits 7:0
  745. * Purpose: identifies this as peer tx ready message
  746. * Value: 0x7
  747. * - PEER_ID
  748. * Bits 18:8
  749. * Purpose: The ID assigned to the peer by the PEER_INFO message
  750. */
  751. typedef struct htt_isoc_t2h_peer_tx_ready_s {
  752. /* word 0 */
  753. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_PEER_TX_READY */
  754. peer_id:11, reserved0:13;
  755. } htt_isoc_t2h_peer_tx_ready_t;
  756. /* word 0 */
  757. #define HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_OFFSET32 0
  758. #define HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_M 0x0007ff00
  759. #define HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_S 8
  760. /* general field access macros */
  761. #define HTT_ISOC_T2H_PEER_TX_READY_FIELD_SET(field, msg_addr, value) \
  762. htt_isoc_t2h_field_set( \
  763. ((A_UINT32 *) msg_addr), \
  764. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _OFFSET32, \
  765. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _M, \
  766. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _S, \
  767. value)
  768. #define HTT_ISOC_T2H_PEER_TX_READY_FIELD_GET(field, msg_addr) \
  769. HTT_ISOC_T2H_FIELD_GET( \
  770. ((A_UINT32 *) msg_addr), \
  771. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _OFFSET32, \
  772. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _M, \
  773. HTT_ISOC_T2H_PEER_TX_READY_ ## field ## _S)
  774. /* access macros for specific fields */
  775. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_M_Size_Check,
  776. (HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_M >> \
  777. HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_S) < ((A_UINT16)~((A_UINT16)0)));
  778. #define HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_SET(msg_addr, value) \
  779. HTT_ISOC_T2H_PEER_TX_READY_FIELD_SET(PEER_ID, msg_addr, value)
  780. #define HTT_ISOC_T2H_PEER_TX_READY_PEER_ID_GET(msg_addr) \
  781. ((A_UINT16)(HTT_ISOC_T2H_PEER_TX_READY_FIELD_GET(PEER_ID, msg_addr)))
  782. /*=== RX_ERR message ===*/
  783. /**
  784. * @brief target -> host rx error notification message definition
  785. *
  786. * @details
  787. * The following diagram shows the format of the rx err message sent
  788. * from the target to the host. This layout assumes the target operates
  789. * as little-endian.
  790. *
  791. * |31 16|15 8|7|6|5|4 0|
  792. * |---------------------------------------------------------------------|
  793. * | peer ID | rx err type | msg type |
  794. * |---------------------------------------------------------------------|
  795. * | reserved | rx err count |M| r | ext TID |
  796. * |---------------------------------------------------------------------|
  797. * M = multicast
  798. * r = reserved
  799. *
  800. * The following field definitions describe the format of the peer info
  801. * message sent from the target to the host.
  802. *
  803. * WORD 0:
  804. * - MSG_TYPE
  805. * Bits 7:0
  806. * Purpose: identifies this as an rx err message
  807. * Value: 0x8
  808. * - RX_ERR_TYPE
  809. * Bits 15:8
  810. * Purpose: specifies which type of rx error is being reported
  811. * Value: htt_rx_ind_mpdu_status enum
  812. * - PEER_ID
  813. * Bits 31:16
  814. * Purpose: specify which peer sent the frame that resulted in an error
  815. * WORD 1:
  816. * - EXT_TID
  817. * Bits 4:0
  818. * Purpose: specifies which traffic type had the rx error
  819. * Value: 0-15 for a real TID value, 16 for non-QoS data, 31 for unknown
  820. * - MCAST
  821. * Bit 6
  822. * Purpose: specify whether the rx error frame was unicast or multicast
  823. * Value: 0 -> unicast, 1 -> multicast
  824. * - L2_HDR_IS_80211
  825. * Bit 7
  826. * Purpose: specifies whether the included L2 header (if present) is in
  827. * 802.3 or 802.11 format
  828. * Value: 0 -> 802.3, 1 -> 802.11
  829. * - L2_HDR_BYTES
  830. * Bits 15:8
  831. * Purpose: Specify the size of the L2 header in this rx error report.
  832. * Value:
  833. * If no L2 header is included, this field shall be 0.
  834. * If a 802.3 + LLC/SNAP header is included, this field shall be
  835. * 14 (ethernet header) + 8 (LLC/SNAP).
  836. * If a 802.11 header is included, this field shall be 24 bytes for
  837. * a basic header, or 26 bytes if a QoS control field is included,
  838. * or 30 bytes if a 4th address is included, or 32 bytes if a 4th
  839. * address and a QoS control field are included, etc.
  840. * Though the L2 header included in the message needs to include
  841. * padding up to a 4-byte boundary, this L2 header size field need
  842. * not account for the padding following the L2 header.
  843. * - SEC_HDR_BYTES
  844. * Bits 23:16
  845. * Purpose: Specify the size of the security encapsulation header in
  846. * this rx error report.
  847. * Value:
  848. * If no security header is included, this field shall be 0.
  849. * If a security header is included, this field depends on the
  850. * security type, which can be inferred from the rx error type.
  851. * For TKIP MIC errors, the security header could be any of:
  852. * 8 - if IV / KeyID and Extended IV are included
  853. * 16 - if MIC is also included
  854. * 20 - if ICV is also included
  855. * - RX_ERR_CNT
  856. * Bits 31:24
  857. * Purpose: specifies how many rx errors are reported in this message
  858. * Value:
  859. * Rx error reports that include a L2 header and/or security header
  860. * will set this field to 1, to indicate that the error notification
  861. * is for a single frame.
  862. * Rx error reports that don't include a L2 header or security header
  863. * can use this field to send a single message to report multiple
  864. * erroneous rx frames.
  865. */
  866. typedef struct htt_isoc_t2h_rx_err_s {
  867. /* word 0 */
  868. A_UINT32 msg_type:8, /* HTT_ISOC_T2H_MSG_TYPE_RX_ERR */
  869. rx_err_type:8, peer_id:16;
  870. /* word 1 */
  871. A_UINT32
  872. ext_tid:5,
  873. reserved1:1,
  874. mcast:1,
  875. l2_hdr_is_80211:1, l2_hdr_bytes:8, sec_hdr_bytes:8, rx_err_cnt:8;
  876. /* words 2 - M-1: L2 header */
  877. /* words M - N: security header */
  878. } htt_isoc_t2h_rx_err_t;
  879. /* This needs to be exact bytes for structure htt_isoc_t2h_rx_err_t
  880. * * Since it is shared between host and FW, sizeof may not be used.
  881. * * */
  882. #define HTT_ISOC_T2H_RX_ERR_BASE_BYTES 20
  883. /* word 0 */
  884. #define HTT_ISOC_T2H_RX_ERR_TYPE_OFFSET32 0
  885. #define HTT_ISOC_T2H_RX_ERR_TYPE_M 0x0000ff00
  886. #define HTT_ISOC_T2H_RX_ERR_TYPE_ID_S 8
  887. #define HTT_ISOC_T2H_RX_ERR_PEER_ID_OFFSET32 0
  888. #define HTT_ISOC_T2H_RX_ERR_PEER_ID_M 0xffff0000
  889. #define HTT_ISOC_T2H_RX_ERR_PEER_ID_S 16
  890. /* word 1 */
  891. #define HTT_ISOC_T2H_RX_ERR_EXT_TID_OFFSET32 1
  892. #define HTT_ISOC_T2H_RX_ERR_EXT_TID_M 0x0000001f
  893. #define HTT_ISOC_T2H_RX_ERR_EXT_TID_S 0
  894. #define HTT_ISOC_T2H_RX_ERR_MCAST_OFFSET32 1
  895. #define HTT_ISOC_T2H_RX_ERR_MCAST_M 0x00000040
  896. #define HTT_ISOC_T2H_RX_ERR_MCAST_S 6
  897. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_IS_80211_OFFSET32 1
  898. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_IS_80211_M 0x00000080
  899. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_IS_80211_S 7
  900. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_BYTES_OFFSET32 1
  901. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_BYTES_M 0x0000ff00
  902. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_BYTES_S 8
  903. #define HTT_ISOC_T2H_RX_ERR_SEC_HDR_BYTES_OFFSET32 1
  904. #define HTT_ISOC_T2H_RX_ERR_SEC_HDR_BYTES_M 0x00ff0000
  905. #define HTT_ISOC_T2H_RX_ERR_SEC_HDR_BYTES_S 16
  906. #define HTT_ISOC_T2H_RX_ERR_CNT_OFFSET32 1
  907. #define HTT_ISOC_T2H_RX_ERR_CNT_M 0xff000000
  908. #define HTT_ISOC_T2H_RX_ERR_CNT_S 24
  909. /* general field access macros */
  910. #define HTT_ISOC_T2H_RX_ERR_FIELD_SET(field, msg_addr, value) \
  911. htt_isoc_t2h_field_set( \
  912. ((A_UINT32 *) msg_addr), \
  913. HTT_ISOC_T2H_RX_ERR_ ## field ## _OFFSET32, \
  914. HTT_ISOC_T2H_RX_ERR_ ## field ## _M, \
  915. HTT_ISOC_T2H_RX_ERR_ ## field ## _S, \
  916. value)
  917. #define HTT_ISOC_T2H_RX_ERR_FIELD_GET(field, msg_addr) \
  918. HTT_ISOC_T2H_FIELD_GET( \
  919. ((A_UINT32 *) msg_addr), \
  920. HTT_ISOC_T2H_RX_ERR_ ## field ## _OFFSET32, \
  921. HTT_ISOC_T2H_RX_ERR_ ## field ## _M, \
  922. HTT_ISOC_T2H_RX_ERR_ ## field ## _S)
  923. /* access macros for specific fields */
  924. #define HTT_ISOC_T2H_RX_ERR_TYPE_SET(msg_addr, value) \
  925. HTT_ISOC_T2H_RX_ERR_FIELD_SET(TYPE, msg_addr, value)
  926. #define HTT_ISOC_T2H_RX_ERR_TYPE_GET(msg_addr) \
  927. HTT_ISOC_T2H_RX_ERR_FIELD_GET(TYPE, msg_addr)
  928. A_COMPILE_TIME_ASSERT(HTT_ISOC_T2H_RX_ERR_PEER_ID_M_Size_Check,
  929. (HTT_ISOC_T2H_RX_ERR_PEER_ID_M >> HTT_ISOC_T2H_RX_ERR_PEER_ID_S) \
  930. <= ((A_UINT16)~((A_UINT16)0)));
  931. #define HTT_ISOC_T2H_RX_ERR_PEER_ID_SET(msg_addr, value) \
  932. HTT_ISOC_T2H_RX_ERR_FIELD_SET(PEER_ID, msg_addr, value)
  933. #define HTT_ISOC_T2H_RX_ERR_PEER_ID_GET(msg_addr) \
  934. ((A_UINT16)HTT_ISOC_T2H_RX_ERR_FIELD_GET(PEER_ID, msg_addr))
  935. #define HTT_ISOC_T2H_RX_ERR_EXT_TID_SET(msg_addr, value) \
  936. HTT_ISOC_T2H_RX_ERR_FIELD_SET(EXT_TID, msg_addr, value)
  937. #define HTT_ISOC_T2H_RX_ERR_EXT_TID_GET(msg_addr) \
  938. HTT_ISOC_T2H_RX_ERR_FIELD_GET(EXT_TID, msg_addr)
  939. #define HTT_ISOC_T2H_RX_ERR_MCAST_SET(msg_addr, value) \
  940. HTT_ISOC_T2H_RX_ERR_FIELD_SET(MCAST, msg_addr, value)
  941. #define HTT_ISOC_T2H_RX_ERR_MCAST_GET(msg_addr) \
  942. HTT_ISOC_T2H_RX_ERR_FIELD_GET(MCAST, msg_addr)
  943. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_IS_80211_SET(msg_addr, value) \
  944. HTT_ISOC_T2H_RX_ERR_FIELD_SET(L2_HDR_IS_80211, msg_addr, value)
  945. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_IS_80211_GET(msg_addr) \
  946. HTT_ISOC_T2H_RX_ERR_FIELD_GET(L2_HDR_IS_80211, msg_addr)
  947. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_BYTES_SET(msg_addr, value) \
  948. HTT_ISOC_T2H_RX_ERR_FIELD_SET(L2_HDR_BYTES, msg_addr, value)
  949. #define HTT_ISOC_T2H_RX_ERR_L2_HDR_BYTES_GET(msg_addr) \
  950. HTT_ISOC_T2H_RX_ERR_FIELD_GET(L2_HDR_BYTES, msg_addr)
  951. #define HTT_ISOC_T2H_RX_ERR_SEC_HDR_BYTES_SET(msg_addr, value) \
  952. HTT_ISOC_T2H_RX_ERR_FIELD_SET(SEC_HDR_BYTES, msg_addr, value)
  953. #define HTT_ISOC_T2H_RX_ERR_SEC_HDR_BYTES_GET(msg_addr) \
  954. HTT_ISOC_T2H_RX_ERR_FIELD_GET(SEC_HDR_BYTES, msg_addr)
  955. #define HTT_ISOC_T2H_RX_ERR_CNT_SET(msg_addr, value) \
  956. HTT_ISOC_T2H_RX_ERR_FIELD_SET(CNT, msg_addr, value)
  957. #define HTT_ISOC_T2H_RX_ERR_CNT_GET(msg_addr) \
  958. HTT_ISOC_T2H_RX_ERR_FIELD_GET(CNT, msg_addr)
  959. /*=== TX OTA complete indication message ===*/
  960. /**
  961. * @brief target -> tx complete indicate message
  962. *
  963. * @details
  964. * The following diagram shows the format of the tx complete indication message sent
  965. * from the target to the host. This layout assumes the target operates
  966. * as little-endian.
  967. *
  968. * |31 19|18 8|7 0|
  969. * |-----------------------------------------------------------------------|
  970. * | reserved | status | msg type |
  971. * |-----------------------------------------------------------------------|
  972. *
  973. *
  974. * The following field definitions describe the format of the peer info
  975. * message sent from the target to the host.
  976. *
  977. * WORD 0:
  978. * - MSG_TYPE
  979. * Bits 7:0
  980. * Purpose: identifies this as tx complete indication message
  981. * Value: 0x7
  982. * - status
  983. * Bits 18:8
  984. * Purpose: TX completion status
  985. */
  986. typedef struct htt_isoc_t2h_tx_compl_s {
  987. /* word 0 */
  988. A_UINT32
  989. /* HTT_ISOC_T2H_MSG_TYPE_TX_COMPL_IND */
  990. qmsg_type:8,
  991. status:11,
  992. reserved0:13;
  993. } htt_isoc_t2h_tx_compl_t;
  994. /* word 0 */
  995. #define HTT_ISOC_T2H_TX_COMPL_IND_STATUS_OFFSET32 0
  996. #define HTT_ISOC_T2H_TX_COMPL_IND_STATUS_M 0x0007ff00
  997. #define HTT_ISOC_T2H_TX_COMPL_IND_STATUS_S 8
  998. /* general field access macros */
  999. #define HTT_ISOC_T2H_TX_COMPL_IND_FIELD_SET(field, msg_addr, value) \
  1000. htt_isoc_t2h_field_set( \
  1001. ((A_UINT32 *) msg_addr), \
  1002. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _OFFSET32, \
  1003. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _M, \
  1004. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _S, \
  1005. value)
  1006. #define HTT_ISOC_T2H_TX_COMPL_IND_FIELD_GET(field, msg_addr) \
  1007. HTT_ISOC_T2H_FIELD_GET( \
  1008. ((A_UINT32 *) msg_addr), \
  1009. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _OFFSET32, \
  1010. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _M, \
  1011. HTT_ISOC_T2H_TX_COMPL_IND_ ## field ## _S)
  1012. /* access macros for specific fields */
  1013. #define HTT_ISOC_T2H_TX_COMPL_IND_STATUS_SET(msg_addr, value) \
  1014. HTT_ISOC_T2H_TX_COMPL_IND_FIELD_SET(STATUS, msg_addr, value)
  1015. #define HTT_ISOC_T2H_TX_COMPL_IND_STATUS_GET(msg_addr) \
  1016. HTT_ISOC_T2H_TX_COMPL_IND_FIELD_GET(STATUS, msg_addr)
  1017. #define HTT_TX_COMPL_IND_STAT_OK 0
  1018. #define HTT_TX_COMPL_IND_STAT_DISCARD 1
  1019. #define HTT_TX_COMPL_IND_STAT_NO_ACK 2
  1020. #define HTT_TX_COMPL_IND_STAT_POSTPONE 3
  1021. /*=== NLO indication message ===*/
  1022. /**
  1023. * @brief target -> NLO indicate message
  1024. *
  1025. * @details
  1026. * The following diagram shows the format of the NLO indication message sent
  1027. * from the target to the host. This layout assumes the target operates
  1028. * as little-endian.
  1029. *
  1030. * |31 8|7 0|
  1031. * |-----------------------------------------------------------------------|
  1032. * | reserved | msg type |
  1033. * |-----------------------------------------------------------------------|
  1034. *
  1035. *
  1036. * The following field definitions describe the format of NLO MATCH indication
  1037. * message sent from the target to the host.
  1038. *
  1039. * WORD 0:
  1040. * - MSG_TYPE
  1041. * Bits 7:0
  1042. * Purpose: identifies this as NLO indication message
  1043. * Value: 0x9 - HTT_ISOC_T2H_MSG_TYPE_NLO_MATCH
  1044. * Value: 0xA - HTT_ISOC_T2H_MSG_TYPE_NLO_SCAN_END
  1045. */
  1046. typedef struct htt_isoc_t2h_nlo_ind_s {
  1047. /* word 0 */
  1048. A_UINT32
  1049. msg_type:8,
  1050. vdev_id:8,
  1051. reserved0:16;
  1052. } htt_isoc_t2h_nlo_ind_t;
  1053. /* word 0 */
  1054. #define HTT_ISOC_T2H_NLO_IND_VDEVID_OFFSET32 0
  1055. #define HTT_ISOC_T2H_NLO_IND_VDEVID_M 0x0000ff00
  1056. #define HTT_ISOC_T2H_NLO_IND_VDEVID_S 8
  1057. /* general field access macros */
  1058. #define HTT_ISOC_T2H_NLO_IND_FIELD_SET(field, msg_addr, value) \
  1059. htt_isoc_t2h_field_set( \
  1060. ((A_UINT32 *) msg_addr), \
  1061. HTT_ISOC_T2H_NLO_IND_ ## field ## _OFFSET32, \
  1062. HTT_ISOC_T2H_NLO_IND_ ## field ## _M, \
  1063. HTT_ISOC_T2H_NLO_IND_ ## field ## _S, \
  1064. value)
  1065. #define HTT_ISOC_T2H_NLO_IND_FIELD_GET(field, msg_addr) \
  1066. HTT_ISOC_T2H_FIELD_GET( \
  1067. ((A_UINT32 *) msg_addr), \
  1068. HTT_ISOC_T2H_NLO_IND_ ## field ## _OFFSET32, \
  1069. HTT_ISOC_T2H_NLO_IND_ ## field ## _M, \
  1070. HTT_ISOC_T2H_NLO_IND_ ## field ## _S)
  1071. /* access macros for specific fields */
  1072. #define HTT_ISOC_T2H_NLO_IND_VDEVID_SET(msg_addr, value) \
  1073. HTT_ISOC_T2H_NLO_IND_FIELD_SET(VDEVID, msg_addr, value)
  1074. #define HTT_ISOC_T2H_NLO_IND_VDEVID_GET(msg_addr) \
  1075. HTT_ISOC_T2H_NLO_IND_FIELD_GET(VDEVID, msg_addr)
  1076. #endif /* _HTT_ISOC_H_ */