rx_frame_bitmap_ack.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. /*
  2. * Copyright (c) 2023 Qualcomm Innovation Center, Inc. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for any
  5. * purpose with or without fee is hereby granted, provided that the above
  6. * copyright notice and this permission notice appear in all copies.
  7. *
  8. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
  9. * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
  10. * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
  11. * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  12. * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
  13. * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
  14. * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  15. */
  16. #ifndef _RX_FRAME_BITMAP_ACK_H_
  17. #define _RX_FRAME_BITMAP_ACK_H_
  18. #if !defined(__ASSEMBLER__)
  19. #endif
  20. #define NUM_OF_DWORDS_RX_FRAME_BITMAP_ACK 14
  21. #define NUM_OF_QWORDS_RX_FRAME_BITMAP_ACK 7
  22. struct rx_frame_bitmap_ack {
  23. #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
  24. uint32_t no_bitmap_available : 1, // [0:0]
  25. explicit_ack : 1, // [1:1]
  26. explict_ack_type : 3, // [4:2]
  27. ba_bitmap_size : 2, // [6:5]
  28. reserved_0a : 3, // [9:7]
  29. ba_tid : 4, // [13:10]
  30. sta_full_aid : 13, // [26:14]
  31. reserved_0b : 5; // [31:27]
  32. uint32_t addr1_31_0 : 32; // [31:0]
  33. uint32_t addr1_47_32 : 16, // [15:0]
  34. addr2_15_0 : 16; // [31:16]
  35. uint32_t addr2_47_16 : 32; // [31:0]
  36. uint32_t ba_ts_ctrl : 16, // [15:0]
  37. ba_ts_seq : 16; // [31:16]
  38. uint32_t ba_ts_bitmap_31_0 : 32; // [31:0]
  39. uint32_t ba_ts_bitmap_63_32 : 32; // [31:0]
  40. uint32_t ba_ts_bitmap_95_64 : 32; // [31:0]
  41. uint32_t ba_ts_bitmap_127_96 : 32; // [31:0]
  42. uint32_t ba_ts_bitmap_159_128 : 32; // [31:0]
  43. uint32_t ba_ts_bitmap_191_160 : 32; // [31:0]
  44. uint32_t ba_ts_bitmap_223_192 : 32; // [31:0]
  45. uint32_t ba_ts_bitmap_255_224 : 32; // [31:0]
  46. uint32_t tlv64_padding : 32; // [31:0]
  47. #else
  48. uint32_t reserved_0b : 5, // [31:27]
  49. sta_full_aid : 13, // [26:14]
  50. ba_tid : 4, // [13:10]
  51. reserved_0a : 3, // [9:7]
  52. ba_bitmap_size : 2, // [6:5]
  53. explict_ack_type : 3, // [4:2]
  54. explicit_ack : 1, // [1:1]
  55. no_bitmap_available : 1; // [0:0]
  56. uint32_t addr1_31_0 : 32; // [31:0]
  57. uint32_t addr2_15_0 : 16, // [31:16]
  58. addr1_47_32 : 16; // [15:0]
  59. uint32_t addr2_47_16 : 32; // [31:0]
  60. uint32_t ba_ts_seq : 16, // [31:16]
  61. ba_ts_ctrl : 16; // [15:0]
  62. uint32_t ba_ts_bitmap_31_0 : 32; // [31:0]
  63. uint32_t ba_ts_bitmap_63_32 : 32; // [31:0]
  64. uint32_t ba_ts_bitmap_95_64 : 32; // [31:0]
  65. uint32_t ba_ts_bitmap_127_96 : 32; // [31:0]
  66. uint32_t ba_ts_bitmap_159_128 : 32; // [31:0]
  67. uint32_t ba_ts_bitmap_191_160 : 32; // [31:0]
  68. uint32_t ba_ts_bitmap_223_192 : 32; // [31:0]
  69. uint32_t ba_ts_bitmap_255_224 : 32; // [31:0]
  70. uint32_t tlv64_padding : 32; // [31:0]
  71. #endif
  72. };
  73. /* Description NO_BITMAP_AVAILABLE
  74. When set, RXPCU does not have any info available for the
  75. requested user.
  76. RXPCU will set the TA/RA, addresses with the devices OWN
  77. address.
  78. All other fields are set to 0
  79. TXPCU will just blindly follow RXPCUs info.
  80. (only for status reporting is TXPCU using this).
  81. Note that this field and field "Explicit_ack" can not be
  82. simultaneously set.
  83. <legal all>
  84. */
  85. #define RX_FRAME_BITMAP_ACK_NO_BITMAP_AVAILABLE_OFFSET 0x0000000000000000
  86. #define RX_FRAME_BITMAP_ACK_NO_BITMAP_AVAILABLE_LSB 0
  87. #define RX_FRAME_BITMAP_ACK_NO_BITMAP_AVAILABLE_MSB 0
  88. #define RX_FRAME_BITMAP_ACK_NO_BITMAP_AVAILABLE_MASK 0x0000000000000001
  89. /* Description EXPLICIT_ACK
  90. When set, no BA is needed for this STA. Instead just a single
  91. ACK indication
  92. Note that this field and field "No_bitmap_available" can
  93. not be simultaneously set.
  94. Also note that RXPCU might not know if the response that
  95. TXPCU is generating is a single ACK or M(sta) BA.
  96. For that reason, RXPCU shall also properly fill in all the
  97. BA related fields. TXPCU will based on the explicit ack
  98. type and in case of BA type response, blindely copy the
  99. required BA related fields and not change their contents:
  100. The related fields are:
  101. Ba_tid
  102. ba_ts_ctrl
  103. ba_ts_seq
  104. ba_ts_bitmap_...
  105. <legal all>
  106. */
  107. #define RX_FRAME_BITMAP_ACK_EXPLICIT_ACK_OFFSET 0x0000000000000000
  108. #define RX_FRAME_BITMAP_ACK_EXPLICIT_ACK_LSB 1
  109. #define RX_FRAME_BITMAP_ACK_EXPLICIT_ACK_MSB 1
  110. #define RX_FRAME_BITMAP_ACK_EXPLICIT_ACK_MASK 0x0000000000000002
  111. /* Description EXPLICT_ACK_TYPE
  112. Field only valid when Explicit_ack is set
  113. Note that TXPCU only needs to evaluate this field in case
  114. of generating a multi (STA) BA
  115. <enum 0 ack_for_single_data_frame> set when only a single
  116. data frame was received that indicated explicitly a 'normal'
  117. ack (no BA) to be sent.
  118. <enum 1 ack_for_management> set when a management frame
  119. was received
  120. <enum 2 ack_for_PSPOLL> set when a PS_POLL frame was received
  121. <enum 3 ack_for_assoc_request> set when an association request
  122. was received from an unassociated STA.
  123. <enum 4 ack_for_all_frames> set when RXPCU determined that
  124. all frames have been properly received.
  125. <legal 0-4>
  126. */
  127. #define RX_FRAME_BITMAP_ACK_EXPLICT_ACK_TYPE_OFFSET 0x0000000000000000
  128. #define RX_FRAME_BITMAP_ACK_EXPLICT_ACK_TYPE_LSB 2
  129. #define RX_FRAME_BITMAP_ACK_EXPLICT_ACK_TYPE_MSB 4
  130. #define RX_FRAME_BITMAP_ACK_EXPLICT_ACK_TYPE_MASK 0x000000000000001c
  131. /* Description BA_BITMAP_SIZE
  132. Field not valid when "No_bitmap_available" or "Explicit_ack"
  133. is set.
  134. <enum 0 BA_bitmap_32 > Bitmap size set to window of 32
  135. <enum 1 BA_bitmap_64 > Bitmap size set to window of 64
  136. <enum 2 BA_bitmap_128 > Bitmap size set to window of 128
  137. <enum 3 BA_bitmap_256 > Bitmap size set to window of 256
  138. <legal 0-3>
  139. */
  140. #define RX_FRAME_BITMAP_ACK_BA_BITMAP_SIZE_OFFSET 0x0000000000000000
  141. #define RX_FRAME_BITMAP_ACK_BA_BITMAP_SIZE_LSB 5
  142. #define RX_FRAME_BITMAP_ACK_BA_BITMAP_SIZE_MSB 6
  143. #define RX_FRAME_BITMAP_ACK_BA_BITMAP_SIZE_MASK 0x0000000000000060
  144. /* Description RESERVED_0A
  145. <legal 0>
  146. */
  147. #define RX_FRAME_BITMAP_ACK_RESERVED_0A_OFFSET 0x0000000000000000
  148. #define RX_FRAME_BITMAP_ACK_RESERVED_0A_LSB 7
  149. #define RX_FRAME_BITMAP_ACK_RESERVED_0A_MSB 9
  150. #define RX_FRAME_BITMAP_ACK_RESERVED_0A_MASK 0x0000000000000380
  151. /* Description BA_TID
  152. The tid for the BA
  153. */
  154. #define RX_FRAME_BITMAP_ACK_BA_TID_OFFSET 0x0000000000000000
  155. #define RX_FRAME_BITMAP_ACK_BA_TID_LSB 10
  156. #define RX_FRAME_BITMAP_ACK_BA_TID_MSB 13
  157. #define RX_FRAME_BITMAP_ACK_BA_TID_MASK 0x0000000000003c00
  158. /* Description STA_FULL_AID
  159. The full AID of this station.
  160. */
  161. #define RX_FRAME_BITMAP_ACK_STA_FULL_AID_OFFSET 0x0000000000000000
  162. #define RX_FRAME_BITMAP_ACK_STA_FULL_AID_LSB 14
  163. #define RX_FRAME_BITMAP_ACK_STA_FULL_AID_MSB 26
  164. #define RX_FRAME_BITMAP_ACK_STA_FULL_AID_MASK 0x0000000007ffc000
  165. /* Description RESERVED_0B
  166. <legal 0>
  167. */
  168. #define RX_FRAME_BITMAP_ACK_RESERVED_0B_OFFSET 0x0000000000000000
  169. #define RX_FRAME_BITMAP_ACK_RESERVED_0B_LSB 27
  170. #define RX_FRAME_BITMAP_ACK_RESERVED_0B_MSB 31
  171. #define RX_FRAME_BITMAP_ACK_RESERVED_0B_MASK 0x00000000f8000000
  172. /* Description ADDR1_31_0
  173. lower 32 bits of addr1 of the received frame
  174. */
  175. #define RX_FRAME_BITMAP_ACK_ADDR1_31_0_OFFSET 0x0000000000000000
  176. #define RX_FRAME_BITMAP_ACK_ADDR1_31_0_LSB 32
  177. #define RX_FRAME_BITMAP_ACK_ADDR1_31_0_MSB 63
  178. #define RX_FRAME_BITMAP_ACK_ADDR1_31_0_MASK 0xffffffff00000000
  179. /* Description ADDR1_47_32
  180. upper 16 bits of addr1 of the received frame
  181. */
  182. #define RX_FRAME_BITMAP_ACK_ADDR1_47_32_OFFSET 0x0000000000000008
  183. #define RX_FRAME_BITMAP_ACK_ADDR1_47_32_LSB 0
  184. #define RX_FRAME_BITMAP_ACK_ADDR1_47_32_MSB 15
  185. #define RX_FRAME_BITMAP_ACK_ADDR1_47_32_MASK 0x000000000000ffff
  186. /* Description ADDR2_15_0
  187. lower 16 bits of addr2 of the received frame
  188. */
  189. #define RX_FRAME_BITMAP_ACK_ADDR2_15_0_OFFSET 0x0000000000000008
  190. #define RX_FRAME_BITMAP_ACK_ADDR2_15_0_LSB 16
  191. #define RX_FRAME_BITMAP_ACK_ADDR2_15_0_MSB 31
  192. #define RX_FRAME_BITMAP_ACK_ADDR2_15_0_MASK 0x00000000ffff0000
  193. /* Description ADDR2_47_16
  194. upper 32 bits of addr2 of the received frame
  195. */
  196. #define RX_FRAME_BITMAP_ACK_ADDR2_47_16_OFFSET 0x0000000000000008
  197. #define RX_FRAME_BITMAP_ACK_ADDR2_47_16_LSB 32
  198. #define RX_FRAME_BITMAP_ACK_ADDR2_47_16_MSB 63
  199. #define RX_FRAME_BITMAP_ACK_ADDR2_47_16_MASK 0xffffffff00000000
  200. /* Description BA_TS_CTRL
  201. Transmit BA control
  202. RXPCU assumes the C-BA format, NOT M-BA format.
  203. In case TXPCU is responding with M-BA, TXPCU will ignore
  204. this field. TXPCU will generate it
  205. */
  206. #define RX_FRAME_BITMAP_ACK_BA_TS_CTRL_OFFSET 0x0000000000000010
  207. #define RX_FRAME_BITMAP_ACK_BA_TS_CTRL_LSB 0
  208. #define RX_FRAME_BITMAP_ACK_BA_TS_CTRL_MSB 15
  209. #define RX_FRAME_BITMAP_ACK_BA_TS_CTRL_MASK 0x000000000000ffff
  210. /* Description BA_TS_SEQ
  211. Transmit BA sequence number.
  212. */
  213. #define RX_FRAME_BITMAP_ACK_BA_TS_SEQ_OFFSET 0x0000000000000010
  214. #define RX_FRAME_BITMAP_ACK_BA_TS_SEQ_LSB 16
  215. #define RX_FRAME_BITMAP_ACK_BA_TS_SEQ_MSB 31
  216. #define RX_FRAME_BITMAP_ACK_BA_TS_SEQ_MASK 0x00000000ffff0000
  217. /* Description BA_TS_BITMAP_31_0
  218. Transmit BA bitmap[31:0]
  219. */
  220. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_31_0_OFFSET 0x0000000000000010
  221. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_31_0_LSB 32
  222. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_31_0_MSB 63
  223. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_31_0_MASK 0xffffffff00000000
  224. /* Description BA_TS_BITMAP_63_32
  225. Transmit BA bitmap[63:32]
  226. */
  227. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_63_32_OFFSET 0x0000000000000018
  228. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_63_32_LSB 0
  229. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_63_32_MSB 31
  230. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_63_32_MASK 0x00000000ffffffff
  231. /* Description BA_TS_BITMAP_95_64
  232. Transmit BA bitmap[95:64]
  233. */
  234. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_95_64_OFFSET 0x0000000000000018
  235. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_95_64_LSB 32
  236. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_95_64_MSB 63
  237. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_95_64_MASK 0xffffffff00000000
  238. /* Description BA_TS_BITMAP_127_96
  239. Transmit BA bitmap[127:96]
  240. */
  241. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_127_96_OFFSET 0x0000000000000020
  242. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_127_96_LSB 0
  243. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_127_96_MSB 31
  244. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_127_96_MASK 0x00000000ffffffff
  245. /* Description BA_TS_BITMAP_159_128
  246. Transmit BA bitmap[159:128]
  247. */
  248. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_159_128_OFFSET 0x0000000000000020
  249. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_159_128_LSB 32
  250. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_159_128_MSB 63
  251. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_159_128_MASK 0xffffffff00000000
  252. /* Description BA_TS_BITMAP_191_160
  253. Transmit BA bitmap[191:160]
  254. */
  255. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_191_160_OFFSET 0x0000000000000028
  256. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_191_160_LSB 0
  257. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_191_160_MSB 31
  258. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_191_160_MASK 0x00000000ffffffff
  259. /* Description BA_TS_BITMAP_223_192
  260. Transmit BA bitmap[223:192]
  261. */
  262. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_223_192_OFFSET 0x0000000000000028
  263. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_223_192_LSB 32
  264. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_223_192_MSB 63
  265. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_223_192_MASK 0xffffffff00000000
  266. /* Description BA_TS_BITMAP_255_224
  267. Transmit BA bitmap[255:224]
  268. */
  269. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_255_224_OFFSET 0x0000000000000030
  270. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_255_224_LSB 0
  271. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_255_224_MSB 31
  272. #define RX_FRAME_BITMAP_ACK_BA_TS_BITMAP_255_224_MASK 0x00000000ffffffff
  273. /* Description TLV64_PADDING
  274. Automatic DWORD padding inserted while converting TLV32
  275. to TLV64 for 64 bit ARCH
  276. <legal 0>
  277. */
  278. #define RX_FRAME_BITMAP_ACK_TLV64_PADDING_OFFSET 0x0000000000000030
  279. #define RX_FRAME_BITMAP_ACK_TLV64_PADDING_LSB 32
  280. #define RX_FRAME_BITMAP_ACK_TLV64_PADDING_MSB 63
  281. #define RX_FRAME_BITMAP_ACK_TLV64_PADDING_MASK 0xffffffff00000000
  282. #endif // RX_FRAME_BITMAP_ACK