rx_reo_queue.h 47 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661
  1. /*
  2. * Copyright (c) 2016-2017 The Linux Foundation. All rights reserved.
  3. *
  4. * Permission to use, copy, modify, and/or distribute this software for
  5. * any purpose with or without fee is hereby granted, provided that the
  6. * above copyright notice and this permission notice appear in all
  7. * copies.
  8. *
  9. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  10. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  11. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  12. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  13. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  14. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  15. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  16. * PERFORMANCE OF THIS SOFTWARE.
  17. */
  18. //
  19. // DO NOT EDIT! This file is automatically generated
  20. // These definitions are tied to a particular hardware layout
  21. #ifndef _RX_REO_QUEUE_H_
  22. #define _RX_REO_QUEUE_H_
  23. #if !defined(__ASSEMBLER__)
  24. #endif
  25. #include "uniform_descriptor_header.h"
  26. // ################ START SUMMARY #################
  27. //
  28. // Dword Fields
  29. // 0 struct uniform_descriptor_header descriptor_header;
  30. // 1 receive_queue_number[15:0], reserved_1b[31:16]
  31. // 2 vld[0], associated_link_descriptor_counter[2:1], disable_duplicate_detection[3], soft_reorder_enable[4], ac[6:5], bar[7], rty[8], chk_2k_mode[9], oor_mode[10], ba_window_size[18:11], pn_check_needed[19], pn_shall_be_even[20], pn_shall_be_uneven[21], pn_handling_enable[22], pn_size[24:23], ignore_ampdu_flag[25], reserved_2b[31:26]
  32. // 3 svld[0], ssn[12:1], current_index[20:13], seq_2k_error_detected_flag[21], pn_error_detected_flag[22], reserved_3a[30:23], pn_valid[31]
  33. // 4 pn_31_0[31:0]
  34. // 5 pn_63_32[31:0]
  35. // 6 pn_95_64[31:0]
  36. // 7 pn_127_96[31:0]
  37. // 8 last_rx_enqueue_timestamp[31:0]
  38. // 9 last_rx_dequeue_timestamp[31:0]
  39. // 10 ptr_to_next_aging_queue_31_0[31:0]
  40. // 11 ptr_to_next_aging_queue_39_32[7:0], reserved_11a[31:8]
  41. // 12 ptr_to_previous_aging_queue_31_0[31:0]
  42. // 13 ptr_to_previous_aging_queue_39_32[7:0], reserved_13a[31:8]
  43. // 14 rx_bitmap_31_0[31:0]
  44. // 15 rx_bitmap_63_32[31:0]
  45. // 16 rx_bitmap_95_64[31:0]
  46. // 17 rx_bitmap_127_96[31:0]
  47. // 18 rx_bitmap_159_128[31:0]
  48. // 19 rx_bitmap_191_160[31:0]
  49. // 20 rx_bitmap_223_192[31:0]
  50. // 21 rx_bitmap_255_224[31:0]
  51. // 22 current_mpdu_count[6:0], current_msdu_count[31:7]
  52. // 23 reserved_23[3:0], timeout_count[9:4], forward_due_to_bar_count[15:10], duplicate_count[31:16]
  53. // 24 frames_in_order_count[23:0], bar_received_count[31:24]
  54. // 25 mpdu_frames_processed_count[31:0]
  55. // 26 msdu_frames_processed_count[31:0]
  56. // 27 total_processed_byte_count[31:0]
  57. // 28 late_receive_mpdu_count[11:0], window_jump_2k[15:12], hole_count[31:16]
  58. // 29 reserved_29[31:0]
  59. // 30 reserved_30[31:0]
  60. // 31 reserved_31[31:0]
  61. //
  62. // ################ END SUMMARY #################
  63. #define NUM_OF_DWORDS_RX_REO_QUEUE 32
  64. struct rx_reo_queue {
  65. struct uniform_descriptor_header descriptor_header;
  66. uint32_t receive_queue_number : 16, //[15:0]
  67. reserved_1b : 16; //[31:16]
  68. uint32_t vld : 1, //[0]
  69. associated_link_descriptor_counter: 2, //[2:1]
  70. disable_duplicate_detection : 1, //[3]
  71. soft_reorder_enable : 1, //[4]
  72. ac : 2, //[6:5]
  73. bar : 1, //[7]
  74. rty : 1, //[8]
  75. chk_2k_mode : 1, //[9]
  76. oor_mode : 1, //[10]
  77. ba_window_size : 8, //[18:11]
  78. pn_check_needed : 1, //[19]
  79. pn_shall_be_even : 1, //[20]
  80. pn_shall_be_uneven : 1, //[21]
  81. pn_handling_enable : 1, //[22]
  82. pn_size : 2, //[24:23]
  83. ignore_ampdu_flag : 1, //[25]
  84. reserved_2b : 6; //[31:26]
  85. uint32_t svld : 1, //[0]
  86. ssn : 12, //[12:1]
  87. current_index : 8, //[20:13]
  88. seq_2k_error_detected_flag : 1, //[21]
  89. pn_error_detected_flag : 1, //[22]
  90. reserved_3a : 8, //[30:23]
  91. pn_valid : 1; //[31]
  92. uint32_t pn_31_0 : 32; //[31:0]
  93. uint32_t pn_63_32 : 32; //[31:0]
  94. uint32_t pn_95_64 : 32; //[31:0]
  95. uint32_t pn_127_96 : 32; //[31:0]
  96. uint32_t last_rx_enqueue_timestamp : 32; //[31:0]
  97. uint32_t last_rx_dequeue_timestamp : 32; //[31:0]
  98. uint32_t ptr_to_next_aging_queue_31_0 : 32; //[31:0]
  99. uint32_t ptr_to_next_aging_queue_39_32 : 8, //[7:0]
  100. reserved_11a : 24; //[31:8]
  101. uint32_t ptr_to_previous_aging_queue_31_0: 32; //[31:0]
  102. uint32_t ptr_to_previous_aging_queue_39_32: 8, //[7:0]
  103. reserved_13a : 24; //[31:8]
  104. uint32_t rx_bitmap_31_0 : 32; //[31:0]
  105. uint32_t rx_bitmap_63_32 : 32; //[31:0]
  106. uint32_t rx_bitmap_95_64 : 32; //[31:0]
  107. uint32_t rx_bitmap_127_96 : 32; //[31:0]
  108. uint32_t rx_bitmap_159_128 : 32; //[31:0]
  109. uint32_t rx_bitmap_191_160 : 32; //[31:0]
  110. uint32_t rx_bitmap_223_192 : 32; //[31:0]
  111. uint32_t rx_bitmap_255_224 : 32; //[31:0]
  112. uint32_t current_mpdu_count : 7, //[6:0]
  113. current_msdu_count : 25; //[31:7]
  114. uint32_t reserved_23 : 4, //[3:0]
  115. timeout_count : 6, //[9:4]
  116. forward_due_to_bar_count : 6, //[15:10]
  117. duplicate_count : 16; //[31:16]
  118. uint32_t frames_in_order_count : 24, //[23:0]
  119. bar_received_count : 8; //[31:24]
  120. uint32_t mpdu_frames_processed_count : 32; //[31:0]
  121. uint32_t msdu_frames_processed_count : 32; //[31:0]
  122. uint32_t total_processed_byte_count : 32; //[31:0]
  123. uint32_t late_receive_mpdu_count : 12, //[11:0]
  124. window_jump_2k : 4, //[15:12]
  125. hole_count : 16; //[31:16]
  126. uint32_t reserved_29 : 32; //[31:0]
  127. uint32_t reserved_30 : 32; //[31:0]
  128. uint32_t reserved_31 : 32; //[31:0]
  129. };
  130. /*
  131. struct uniform_descriptor_header descriptor_header
  132. Details about which module owns this struct.
  133. Note that sub field Buffer_type shall be set to
  134. Receive_REO_queue_descriptor
  135. receive_queue_number
  136. Indicates the MPDU queue ID to which this MPDU link
  137. descriptor belongs
  138. Used for tracking and debugging
  139. <legal all>
  140. reserved_1b
  141. <legal 0>
  142. vld
  143. Valid bit indicating a session is established and the
  144. queue descriptor is valid(Filled by SW)
  145. <legal all>
  146. associated_link_descriptor_counter
  147. Indicates which of the 3 link descriptor counters shall
  148. be incremented or decremented when link descriptors are
  149. added or removed from this flow queue.
  150. MSDU link descriptors related with MPDUs stored in the
  151. re-order buffer shall also be included in this count.
  152. <legal 0-2>
  153. disable_duplicate_detection
  154. When set, do not perform any duplicate detection.
  155. <legal all>
  156. soft_reorder_enable
  157. When set, REO has been instructed to not perform the
  158. actual re-ordering of frames for this queue, but just to
  159. insert the reorder opcodes.
  160. Note that this implies that REO is also not going to
  161. perform any MSDU level operations, and the entire MPDU (and
  162. thus pointer to the MSDU link descriptor) will be pushed to
  163. a destination ring that SW has programmed in a SW
  164. programmable configuration register in REO
  165. <legal all>
  166. ac
  167. Indicates which access category the queue descriptor
  168. belongs to(filled by SW)
  169. <legal all>
  170. bar
  171. Indicates if BAR has been received (mostly used for
  172. debug purpose and this is filled by REO)
  173. <legal all>
  174. rty
  175. Retry bit is checked if this bit is set.
  176. <legal all>
  177. chk_2k_mode
  178. Indicates what type of operation is expected from Reo
  179. when the received frame SN falls within the 2K window
  180. See REO MLD document for programming details.
  181. <legal all>
  182. oor_mode
  183. Out of Order mode:
  184. Indicates what type of operation is expected when the
  185. received frame falls within the OOR window.
  186. See REO MLD document for programming details.
  187. <legal all>
  188. ba_window_size
  189. Indicates the negotiated (window size + 1).
  190. it can go up to Max of 256bits.
  191. A value 255 means 256 bitmap, 63 means 64 bitmap, 0
  192. (means non-BA session, with window size of 0). The 3 values
  193. here are the main values validated, but other values should
  194. work as well.
  195. A BA window size of 0 (=> one frame entry bitmat), means
  196. that there is NO RX_REO_QUEUE_EXT descriptor following this
  197. RX_REO_QUEUE STRUCT in memory
  198. A BA window size of 1 - 105, means that there is 1
  199. RX_REO_QUEUE_EXT descriptor directly following this
  200. RX_REO_QUEUE STRUCT in memory.
  201. A BA window size of 106 - 210, means that there are 2
  202. RX_REO_QUEUE_EXT descriptors directly following this
  203. RX_REO_QUEUE STRUCT in memory
  204. A BA window size of 211 - 256, means that there are 3
  205. RX_REO_QUEUE_EXT descriptors directly following this
  206. RX_REO_QUEUE STRUCT in memory
  207. <legal 0 - 255>
  208. pn_check_needed
  209. When set, REO shall perform the PN increment check
  210. <legal all>
  211. pn_shall_be_even
  212. Field only valid when 'pn_check_needed' is set.
  213. When set, REO shall confirm that the received PN number
  214. is not only incremented, but also always an even number
  215. <legal all>
  216. pn_shall_be_uneven
  217. Field only valid when 'pn_check_needed' is set.
  218. When set, REO shall confirm that the received PN number
  219. is not only incremented, but also always an uneven number
  220. <legal all>
  221. pn_handling_enable
  222. Field only valid when 'pn_check_needed' is set.
  223. When set, and REO detected a PN error, HW shall set the
  224. 'pn_error_detected_flag'.
  225. <legal all>
  226. pn_size
  227. Size of the PN field check.
  228. Needed for wrap around handling...
  229. <enum 0 pn_size_24>
  230. <enum 1 pn_size_48>
  231. <enum 2 pn_size_128>
  232. <legal 0-2>
  233. ignore_ampdu_flag
  234. When set, REO shall ignore the ampdu_flag on the
  235. entrance descriptor for this queue.
  236. <legal all>
  237. reserved_2b
  238. <legal 0>
  239. svld
  240. Sequence number in next field is valid one. It can be
  241. filled by SW if the want to fill in the any negotiated SSN,
  242. otherwise REO will fill the sequence number of first
  243. received packet and set this bit to 1.
  244. <legal all>
  245. ssn
  246. Starting Sequence number of the session, this changes
  247. whenever window moves. (can be filled by SW then maintained
  248. by REO)
  249. <legal all>
  250. current_index
  251. Points to last forwarded packet
  252. <legal all>
  253. seq_2k_error_detected_flag
  254. Set by REO, can only be cleared by SW
  255. When set, REO has detected a 2k error jump in the
  256. sequence number and from that moment forward, all new frames
  257. are forwarded directly to FW, without duplicate detect,
  258. reordering, etc.
  259. <legal all>
  260. pn_error_detected_flag
  261. Set by REO, can only be cleared by SW
  262. When set, REO has detected a PN error and from that
  263. moment forward, all new frames are forwarded directly to FW,
  264. without duplicate detect, reordering, etc.
  265. <legal all>
  266. reserved_3a
  267. <legal 0>
  268. pn_valid
  269. PN number in next fields are valid. It can be filled by
  270. SW if it wants to fill in the any negotiated SSN, otherwise
  271. REO will fill the pn based on the first received packet and
  272. set this bit to 1.
  273. <legal all>
  274. pn_31_0
  275. <legal all>
  276. pn_63_32
  277. Bits [63:32] of the PN number.
  278. <legal all>
  279. pn_95_64
  280. Bits [95:64] of the PN number.
  281. <legal all>
  282. pn_127_96
  283. Bits [127:96] of the PN number.
  284. <legal all>
  285. last_rx_enqueue_timestamp
  286. This timestamp is updated when an MPDU is received and
  287. accesses this Queue Descriptor. It does not include the
  288. access due to Command TLVs or Aging (which will be updated
  289. in Last_rx_dequeue_timestamp).
  290. <legal all>
  291. last_rx_dequeue_timestamp
  292. This timestamp is used for Aging. When an MPDU or
  293. multiple MPDUs are forwarded, either due to window movement,
  294. bar, aging or command flush, this timestamp is updated. Also
  295. when the bitmap is all zero and the first time an MPDU is
  296. queued (opcode=QCUR), this timestamp is updated for aging.
  297. <legal all>
  298. ptr_to_next_aging_queue_31_0
  299. Address (address bits 31-0)of next RX_REO_QUEUE
  300. descriptor in the 'receive timestamp' ordered list.
  301. From it the Position of this queue descriptor in the per
  302. AC aging waitlist can be derived.
  303. Value 0x0 indicates the 'NULL' pointer which implies
  304. that this is the last entry in the list.
  305. <legal all>
  306. ptr_to_next_aging_queue_39_32
  307. Address (address bits 39-32)of next RX_REO_QUEUE
  308. descriptor in the 'receive timestamp' ordered list.
  309. From it the Position of this queue descriptor in the per
  310. AC aging waitlist can be derived.
  311. Value 0x0 indicates the 'NULL' pointer which implies
  312. that this is the last entry in the list.
  313. <legal all>
  314. reserved_11a
  315. <legal 0>
  316. ptr_to_previous_aging_queue_31_0
  317. Address (address bits 31-0)of next RX_REO_QUEUE
  318. descriptor in the 'receive timestamp' ordered list.
  319. From it the Position of this queue descriptor in the per
  320. AC aging waitlist can be derived.
  321. Value 0x0 indicates the 'NULL' pointer which implies
  322. that this is the first entry in the list.
  323. <legal all>
  324. ptr_to_previous_aging_queue_39_32
  325. Address (address bits 39-32)of next RX_REO_QUEUE
  326. descriptor in the 'receive timestamp' ordered list.
  327. From it the Position of this queue descriptor in the per
  328. AC aging waitlist can be derived.
  329. Value 0x0 indicates the 'NULL' pointer which implies
  330. that this is the first entry in the list.
  331. <legal all>
  332. reserved_13a
  333. <legal 0>
  334. rx_bitmap_31_0
  335. When a bit is set, the corresponding frame is currently
  336. held in the re-order queue.
  337. The bitmap is Fully managed by HW.
  338. SW shall init this to 0, and then never ever change it
  339. <legal all>
  340. rx_bitmap_63_32
  341. See Rx_bitmap_31_0 description
  342. <legal all>
  343. rx_bitmap_95_64
  344. See Rx_bitmap_31_0 description
  345. <legal all>
  346. rx_bitmap_127_96
  347. See Rx_bitmap_31_0 description
  348. <legal all>
  349. rx_bitmap_159_128
  350. See Rx_bitmap_31_0 description
  351. <legal all>
  352. rx_bitmap_191_160
  353. See Rx_bitmap_31_0 description
  354. <legal all>
  355. rx_bitmap_223_192
  356. See Rx_bitmap_31_0 description
  357. <legal all>
  358. rx_bitmap_255_224
  359. See Rx_bitmap_31_0 description
  360. <legal all>
  361. current_mpdu_count
  362. The number of MPDUs in the queue.
  363. <legal all>
  364. current_msdu_count
  365. The number of MSDUs in the queue.
  366. <legal all>
  367. reserved_23
  368. <legal 0>
  369. timeout_count
  370. The number of times that REO started forwarding frames
  371. even though there is a hole in the bitmap. Forwarding reason
  372. is Timeout
  373. The counter saturates and freezes at 0x3F
  374. <legal all>
  375. forward_due_to_bar_count
  376. The number of times that REO started forwarding frames
  377. even though there is a hole in the bitmap. Forwarding reason
  378. is reception of BAR frame.
  379. The counter saturates and freezes at 0x3F
  380. <legal all>
  381. duplicate_count
  382. The number of duplicate frames that have been detected
  383. <legal all>
  384. frames_in_order_count
  385. The number of frames that have been received in order
  386. (without a hole that prevented them from being forwarded
  387. immediately)
  388. This corresponds to the Reorder opcodes:
  389. 'FWDCUR' and 'FWD BUF'
  390. <legal all>
  391. bar_received_count
  392. The number of times a BAR frame is received.
  393. This corresponds to the Reorder opcodes with 'DROP'
  394. The counter saturates and freezes at 0xFF
  395. <legal all>
  396. mpdu_frames_processed_count
  397. The total number of MPDU frames that have been processed
  398. by REO. 'Processing' here means that REO has received them
  399. out of the entrance ring, and retrieved the corresponding
  400. RX_REO_QUEUE Descriptor.
  401. Note that this count includes duplicates, frames that
  402. later had errors, etc.
  403. Note that field 'Duplicate_count' indicates how many of
  404. these MPDUs were duplicates.
  405. <legal all>
  406. msdu_frames_processed_count
  407. The total number of MSDU frames that have been processed
  408. by REO. 'Processing' here means that REO has received them
  409. out of the entrance ring, and retrieved the corresponding
  410. RX_REO_QUEUE Descriptor.
  411. Note that this count includes duplicates, frames that
  412. later had errors, etc.
  413. <legal all>
  414. total_processed_byte_count
  415. An approximation of the number of bytes processed for
  416. this queue.
  417. 'Processing' here means that REO has received them out
  418. of the entrance ring, and retrieved the corresponding
  419. RX_REO_QUEUE Descriptor.
  420. Note that this count includes duplicates, frames that
  421. later had errors, etc.
  422. In 64 byte units
  423. <legal all>
  424. late_receive_mpdu_count
  425. The number of MPDUs received after the window had
  426. already moved on. The 'late' sequence window is defined as
  427. (Window SSN - 256) - (Window SSN - 1)
  428. This corresponds with Out of order detection in
  429. duplicate detect FSM
  430. The counter saturates and freezes at 0xFFF
  431. <legal all>
  432. window_jump_2k
  433. The number of times the window moved more then 2K
  434. The counter saturates and freezes at 0xF
  435. (Note: field name can not start with number: previous
  436. 2k_window_jump)
  437. <legal all>
  438. hole_count
  439. The number of times a hole was created in the receive
  440. bitmap.
  441. This corresponds to the Reorder opcodes with 'QCUR'
  442. <legal all>
  443. reserved_29
  444. <legal 0>
  445. reserved_30
  446. <legal 0>
  447. reserved_31
  448. <legal 0>
  449. */
  450. #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_OFFSET 0x00000000
  451. #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_LSB 0
  452. #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_MASK 0xffffffff
  453. /* Description RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER
  454. Indicates the MPDU queue ID to which this MPDU link
  455. descriptor belongs
  456. Used for tracking and debugging
  457. <legal all>
  458. */
  459. #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_OFFSET 0x00000004
  460. #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_LSB 0
  461. #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_MASK 0x0000ffff
  462. /* Description RX_REO_QUEUE_1_RESERVED_1B
  463. <legal 0>
  464. */
  465. #define RX_REO_QUEUE_1_RESERVED_1B_OFFSET 0x00000004
  466. #define RX_REO_QUEUE_1_RESERVED_1B_LSB 16
  467. #define RX_REO_QUEUE_1_RESERVED_1B_MASK 0xffff0000
  468. /* Description RX_REO_QUEUE_2_VLD
  469. Valid bit indicating a session is established and the
  470. queue descriptor is valid(Filled by SW)
  471. <legal all>
  472. */
  473. #define RX_REO_QUEUE_2_VLD_OFFSET 0x00000008
  474. #define RX_REO_QUEUE_2_VLD_LSB 0
  475. #define RX_REO_QUEUE_2_VLD_MASK 0x00000001
  476. /* Description RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER
  477. Indicates which of the 3 link descriptor counters shall
  478. be incremented or decremented when link descriptors are
  479. added or removed from this flow queue.
  480. MSDU link descriptors related with MPDUs stored in the
  481. re-order buffer shall also be included in this count.
  482. <legal 0-2>
  483. */
  484. #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_OFFSET 0x00000008
  485. #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_LSB 1
  486. #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_MASK 0x00000006
  487. /* Description RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION
  488. When set, do not perform any duplicate detection.
  489. <legal all>
  490. */
  491. #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_OFFSET 0x00000008
  492. #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_LSB 3
  493. #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_MASK 0x00000008
  494. /* Description RX_REO_QUEUE_2_SOFT_REORDER_ENABLE
  495. When set, REO has been instructed to not perform the
  496. actual re-ordering of frames for this queue, but just to
  497. insert the reorder opcodes.
  498. Note that this implies that REO is also not going to
  499. perform any MSDU level operations, and the entire MPDU (and
  500. thus pointer to the MSDU link descriptor) will be pushed to
  501. a destination ring that SW has programmed in a SW
  502. programmable configuration register in REO
  503. <legal all>
  504. */
  505. #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_OFFSET 0x00000008
  506. #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_LSB 4
  507. #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_MASK 0x00000010
  508. /* Description RX_REO_QUEUE_2_AC
  509. Indicates which access category the queue descriptor
  510. belongs to(filled by SW)
  511. <legal all>
  512. */
  513. #define RX_REO_QUEUE_2_AC_OFFSET 0x00000008
  514. #define RX_REO_QUEUE_2_AC_LSB 5
  515. #define RX_REO_QUEUE_2_AC_MASK 0x00000060
  516. /* Description RX_REO_QUEUE_2_BAR
  517. Indicates if BAR has been received (mostly used for
  518. debug purpose and this is filled by REO)
  519. <legal all>
  520. */
  521. #define RX_REO_QUEUE_2_BAR_OFFSET 0x00000008
  522. #define RX_REO_QUEUE_2_BAR_LSB 7
  523. #define RX_REO_QUEUE_2_BAR_MASK 0x00000080
  524. /* Description RX_REO_QUEUE_2_RTY
  525. Retry bit is checked if this bit is set.
  526. <legal all>
  527. */
  528. #define RX_REO_QUEUE_2_RTY_OFFSET 0x00000008
  529. #define RX_REO_QUEUE_2_RTY_LSB 8
  530. #define RX_REO_QUEUE_2_RTY_MASK 0x00000100
  531. /* Description RX_REO_QUEUE_2_CHK_2K_MODE
  532. Indicates what type of operation is expected from Reo
  533. when the received frame SN falls within the 2K window
  534. See REO MLD document for programming details.
  535. <legal all>
  536. */
  537. #define RX_REO_QUEUE_2_CHK_2K_MODE_OFFSET 0x00000008
  538. #define RX_REO_QUEUE_2_CHK_2K_MODE_LSB 9
  539. #define RX_REO_QUEUE_2_CHK_2K_MODE_MASK 0x00000200
  540. /* Description RX_REO_QUEUE_2_OOR_MODE
  541. Out of Order mode:
  542. Indicates what type of operation is expected when the
  543. received frame falls within the OOR window.
  544. See REO MLD document for programming details.
  545. <legal all>
  546. */
  547. #define RX_REO_QUEUE_2_OOR_MODE_OFFSET 0x00000008
  548. #define RX_REO_QUEUE_2_OOR_MODE_LSB 10
  549. #define RX_REO_QUEUE_2_OOR_MODE_MASK 0x00000400
  550. /* Description RX_REO_QUEUE_2_BA_WINDOW_SIZE
  551. Indicates the negotiated (window size + 1).
  552. it can go up to Max of 256bits.
  553. A value 255 means 256 bitmap, 63 means 64 bitmap, 0
  554. (means non-BA session, with window size of 0). The 3 values
  555. here are the main values validated, but other values should
  556. work as well.
  557. A BA window size of 0 (=> one frame entry bitmat), means
  558. that there is NO RX_REO_QUEUE_EXT descriptor following this
  559. RX_REO_QUEUE STRUCT in memory
  560. A BA window size of 1 - 105, means that there is 1
  561. RX_REO_QUEUE_EXT descriptor directly following this
  562. RX_REO_QUEUE STRUCT in memory.
  563. A BA window size of 106 - 210, means that there are 2
  564. RX_REO_QUEUE_EXT descriptors directly following this
  565. RX_REO_QUEUE STRUCT in memory
  566. A BA window size of 211 - 256, means that there are 3
  567. RX_REO_QUEUE_EXT descriptors directly following this
  568. RX_REO_QUEUE STRUCT in memory
  569. <legal 0 - 255>
  570. */
  571. #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_OFFSET 0x00000008
  572. #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_LSB 11
  573. #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_MASK 0x0007f800
  574. /* Description RX_REO_QUEUE_2_PN_CHECK_NEEDED
  575. When set, REO shall perform the PN increment check
  576. <legal all>
  577. */
  578. #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_OFFSET 0x00000008
  579. #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_LSB 19
  580. #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_MASK 0x00080000
  581. /* Description RX_REO_QUEUE_2_PN_SHALL_BE_EVEN
  582. Field only valid when 'pn_check_needed' is set.
  583. When set, REO shall confirm that the received PN number
  584. is not only incremented, but also always an even number
  585. <legal all>
  586. */
  587. #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_OFFSET 0x00000008
  588. #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_LSB 20
  589. #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_MASK 0x00100000
  590. /* Description RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN
  591. Field only valid when 'pn_check_needed' is set.
  592. When set, REO shall confirm that the received PN number
  593. is not only incremented, but also always an uneven number
  594. <legal all>
  595. */
  596. #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_OFFSET 0x00000008
  597. #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_LSB 21
  598. #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_MASK 0x00200000
  599. /* Description RX_REO_QUEUE_2_PN_HANDLING_ENABLE
  600. Field only valid when 'pn_check_needed' is set.
  601. When set, and REO detected a PN error, HW shall set the
  602. 'pn_error_detected_flag'.
  603. <legal all>
  604. */
  605. #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_OFFSET 0x00000008
  606. #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_LSB 22
  607. #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_MASK 0x00400000
  608. /* Description RX_REO_QUEUE_2_PN_SIZE
  609. Size of the PN field check.
  610. Needed for wrap around handling...
  611. <enum 0 pn_size_24>
  612. <enum 1 pn_size_48>
  613. <enum 2 pn_size_128>
  614. <legal 0-2>
  615. */
  616. #define RX_REO_QUEUE_2_PN_SIZE_OFFSET 0x00000008
  617. #define RX_REO_QUEUE_2_PN_SIZE_LSB 23
  618. #define RX_REO_QUEUE_2_PN_SIZE_MASK 0x01800000
  619. /* Description RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG
  620. When set, REO shall ignore the ampdu_flag on the
  621. entrance descriptor for this queue.
  622. <legal all>
  623. */
  624. #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_OFFSET 0x00000008
  625. #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_LSB 25
  626. #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_MASK 0x02000000
  627. /* Description RX_REO_QUEUE_2_RESERVED_2B
  628. <legal 0>
  629. */
  630. #define RX_REO_QUEUE_2_RESERVED_2B_OFFSET 0x00000008
  631. #define RX_REO_QUEUE_2_RESERVED_2B_LSB 26
  632. #define RX_REO_QUEUE_2_RESERVED_2B_MASK 0xfc000000
  633. /* Description RX_REO_QUEUE_3_SVLD
  634. Sequence number in next field is valid one. It can be
  635. filled by SW if the want to fill in the any negotiated SSN,
  636. otherwise REO will fill the sequence number of first
  637. received packet and set this bit to 1.
  638. <legal all>
  639. */
  640. #define RX_REO_QUEUE_3_SVLD_OFFSET 0x0000000c
  641. #define RX_REO_QUEUE_3_SVLD_LSB 0
  642. #define RX_REO_QUEUE_3_SVLD_MASK 0x00000001
  643. /* Description RX_REO_QUEUE_3_SSN
  644. Starting Sequence number of the session, this changes
  645. whenever window moves. (can be filled by SW then maintained
  646. by REO)
  647. <legal all>
  648. */
  649. #define RX_REO_QUEUE_3_SSN_OFFSET 0x0000000c
  650. #define RX_REO_QUEUE_3_SSN_LSB 1
  651. #define RX_REO_QUEUE_3_SSN_MASK 0x00001ffe
  652. /* Description RX_REO_QUEUE_3_CURRENT_INDEX
  653. Points to last forwarded packet
  654. <legal all>
  655. */
  656. #define RX_REO_QUEUE_3_CURRENT_INDEX_OFFSET 0x0000000c
  657. #define RX_REO_QUEUE_3_CURRENT_INDEX_LSB 13
  658. #define RX_REO_QUEUE_3_CURRENT_INDEX_MASK 0x001fe000
  659. /* Description RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG
  660. Set by REO, can only be cleared by SW
  661. When set, REO has detected a 2k error jump in the
  662. sequence number and from that moment forward, all new frames
  663. are forwarded directly to FW, without duplicate detect,
  664. reordering, etc.
  665. <legal all>
  666. */
  667. #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_OFFSET 0x0000000c
  668. #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_LSB 21
  669. #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_MASK 0x00200000
  670. /* Description RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG
  671. Set by REO, can only be cleared by SW
  672. When set, REO has detected a PN error and from that
  673. moment forward, all new frames are forwarded directly to FW,
  674. without duplicate detect, reordering, etc.
  675. <legal all>
  676. */
  677. #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_OFFSET 0x0000000c
  678. #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_LSB 22
  679. #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_MASK 0x00400000
  680. /* Description RX_REO_QUEUE_3_RESERVED_3A
  681. <legal 0>
  682. */
  683. #define RX_REO_QUEUE_3_RESERVED_3A_OFFSET 0x0000000c
  684. #define RX_REO_QUEUE_3_RESERVED_3A_LSB 23
  685. #define RX_REO_QUEUE_3_RESERVED_3A_MASK 0x7f800000
  686. /* Description RX_REO_QUEUE_3_PN_VALID
  687. PN number in next fields are valid. It can be filled by
  688. SW if it wants to fill in the any negotiated SSN, otherwise
  689. REO will fill the pn based on the first received packet and
  690. set this bit to 1.
  691. <legal all>
  692. */
  693. #define RX_REO_QUEUE_3_PN_VALID_OFFSET 0x0000000c
  694. #define RX_REO_QUEUE_3_PN_VALID_LSB 31
  695. #define RX_REO_QUEUE_3_PN_VALID_MASK 0x80000000
  696. /* Description RX_REO_QUEUE_4_PN_31_0
  697. <legal all>
  698. */
  699. #define RX_REO_QUEUE_4_PN_31_0_OFFSET 0x00000010
  700. #define RX_REO_QUEUE_4_PN_31_0_LSB 0
  701. #define RX_REO_QUEUE_4_PN_31_0_MASK 0xffffffff
  702. /* Description RX_REO_QUEUE_5_PN_63_32
  703. Bits [63:32] of the PN number.
  704. <legal all>
  705. */
  706. #define RX_REO_QUEUE_5_PN_63_32_OFFSET 0x00000014
  707. #define RX_REO_QUEUE_5_PN_63_32_LSB 0
  708. #define RX_REO_QUEUE_5_PN_63_32_MASK 0xffffffff
  709. /* Description RX_REO_QUEUE_6_PN_95_64
  710. Bits [95:64] of the PN number.
  711. <legal all>
  712. */
  713. #define RX_REO_QUEUE_6_PN_95_64_OFFSET 0x00000018
  714. #define RX_REO_QUEUE_6_PN_95_64_LSB 0
  715. #define RX_REO_QUEUE_6_PN_95_64_MASK 0xffffffff
  716. /* Description RX_REO_QUEUE_7_PN_127_96
  717. Bits [127:96] of the PN number.
  718. <legal all>
  719. */
  720. #define RX_REO_QUEUE_7_PN_127_96_OFFSET 0x0000001c
  721. #define RX_REO_QUEUE_7_PN_127_96_LSB 0
  722. #define RX_REO_QUEUE_7_PN_127_96_MASK 0xffffffff
  723. /* Description RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP
  724. This timestamp is updated when an MPDU is received and
  725. accesses this Queue Descriptor. It does not include the
  726. access due to Command TLVs or Aging (which will be updated
  727. in Last_rx_dequeue_timestamp).
  728. <legal all>
  729. */
  730. #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_OFFSET 0x00000020
  731. #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_LSB 0
  732. #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_MASK 0xffffffff
  733. /* Description RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP
  734. This timestamp is used for Aging. When an MPDU or
  735. multiple MPDUs are forwarded, either due to window movement,
  736. bar, aging or command flush, this timestamp is updated. Also
  737. when the bitmap is all zero and the first time an MPDU is
  738. queued (opcode=QCUR), this timestamp is updated for aging.
  739. <legal all>
  740. */
  741. #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_OFFSET 0x00000024
  742. #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_LSB 0
  743. #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_MASK 0xffffffff
  744. /* Description RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0
  745. Address (address bits 31-0)of next RX_REO_QUEUE
  746. descriptor in the 'receive timestamp' ordered list.
  747. From it the Position of this queue descriptor in the per
  748. AC aging waitlist can be derived.
  749. Value 0x0 indicates the 'NULL' pointer which implies
  750. that this is the last entry in the list.
  751. <legal all>
  752. */
  753. #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_OFFSET 0x00000028
  754. #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_LSB 0
  755. #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_MASK 0xffffffff
  756. /* Description RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32
  757. Address (address bits 39-32)of next RX_REO_QUEUE
  758. descriptor in the 'receive timestamp' ordered list.
  759. From it the Position of this queue descriptor in the per
  760. AC aging waitlist can be derived.
  761. Value 0x0 indicates the 'NULL' pointer which implies
  762. that this is the last entry in the list.
  763. <legal all>
  764. */
  765. #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_OFFSET 0x0000002c
  766. #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_LSB 0
  767. #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_MASK 0x000000ff
  768. /* Description RX_REO_QUEUE_11_RESERVED_11A
  769. <legal 0>
  770. */
  771. #define RX_REO_QUEUE_11_RESERVED_11A_OFFSET 0x0000002c
  772. #define RX_REO_QUEUE_11_RESERVED_11A_LSB 8
  773. #define RX_REO_QUEUE_11_RESERVED_11A_MASK 0xffffff00
  774. /* Description RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0
  775. Address (address bits 31-0)of next RX_REO_QUEUE
  776. descriptor in the 'receive timestamp' ordered list.
  777. From it the Position of this queue descriptor in the per
  778. AC aging waitlist can be derived.
  779. Value 0x0 indicates the 'NULL' pointer which implies
  780. that this is the first entry in the list.
  781. <legal all>
  782. */
  783. #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_OFFSET 0x00000030
  784. #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_LSB 0
  785. #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_MASK 0xffffffff
  786. /* Description RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32
  787. Address (address bits 39-32)of next RX_REO_QUEUE
  788. descriptor in the 'receive timestamp' ordered list.
  789. From it the Position of this queue descriptor in the per
  790. AC aging waitlist can be derived.
  791. Value 0x0 indicates the 'NULL' pointer which implies
  792. that this is the first entry in the list.
  793. <legal all>
  794. */
  795. #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_OFFSET 0x00000034
  796. #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_LSB 0
  797. #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_MASK 0x000000ff
  798. /* Description RX_REO_QUEUE_13_RESERVED_13A
  799. <legal 0>
  800. */
  801. #define RX_REO_QUEUE_13_RESERVED_13A_OFFSET 0x00000034
  802. #define RX_REO_QUEUE_13_RESERVED_13A_LSB 8
  803. #define RX_REO_QUEUE_13_RESERVED_13A_MASK 0xffffff00
  804. /* Description RX_REO_QUEUE_14_RX_BITMAP_31_0
  805. When a bit is set, the corresponding frame is currently
  806. held in the re-order queue.
  807. The bitmap is Fully managed by HW.
  808. SW shall init this to 0, and then never ever change it
  809. <legal all>
  810. */
  811. #define RX_REO_QUEUE_14_RX_BITMAP_31_0_OFFSET 0x00000038
  812. #define RX_REO_QUEUE_14_RX_BITMAP_31_0_LSB 0
  813. #define RX_REO_QUEUE_14_RX_BITMAP_31_0_MASK 0xffffffff
  814. /* Description RX_REO_QUEUE_15_RX_BITMAP_63_32
  815. See Rx_bitmap_31_0 description
  816. <legal all>
  817. */
  818. #define RX_REO_QUEUE_15_RX_BITMAP_63_32_OFFSET 0x0000003c
  819. #define RX_REO_QUEUE_15_RX_BITMAP_63_32_LSB 0
  820. #define RX_REO_QUEUE_15_RX_BITMAP_63_32_MASK 0xffffffff
  821. /* Description RX_REO_QUEUE_16_RX_BITMAP_95_64
  822. See Rx_bitmap_31_0 description
  823. <legal all>
  824. */
  825. #define RX_REO_QUEUE_16_RX_BITMAP_95_64_OFFSET 0x00000040
  826. #define RX_REO_QUEUE_16_RX_BITMAP_95_64_LSB 0
  827. #define RX_REO_QUEUE_16_RX_BITMAP_95_64_MASK 0xffffffff
  828. /* Description RX_REO_QUEUE_17_RX_BITMAP_127_96
  829. See Rx_bitmap_31_0 description
  830. <legal all>
  831. */
  832. #define RX_REO_QUEUE_17_RX_BITMAP_127_96_OFFSET 0x00000044
  833. #define RX_REO_QUEUE_17_RX_BITMAP_127_96_LSB 0
  834. #define RX_REO_QUEUE_17_RX_BITMAP_127_96_MASK 0xffffffff
  835. /* Description RX_REO_QUEUE_18_RX_BITMAP_159_128
  836. See Rx_bitmap_31_0 description
  837. <legal all>
  838. */
  839. #define RX_REO_QUEUE_18_RX_BITMAP_159_128_OFFSET 0x00000048
  840. #define RX_REO_QUEUE_18_RX_BITMAP_159_128_LSB 0
  841. #define RX_REO_QUEUE_18_RX_BITMAP_159_128_MASK 0xffffffff
  842. /* Description RX_REO_QUEUE_19_RX_BITMAP_191_160
  843. See Rx_bitmap_31_0 description
  844. <legal all>
  845. */
  846. #define RX_REO_QUEUE_19_RX_BITMAP_191_160_OFFSET 0x0000004c
  847. #define RX_REO_QUEUE_19_RX_BITMAP_191_160_LSB 0
  848. #define RX_REO_QUEUE_19_RX_BITMAP_191_160_MASK 0xffffffff
  849. /* Description RX_REO_QUEUE_20_RX_BITMAP_223_192
  850. See Rx_bitmap_31_0 description
  851. <legal all>
  852. */
  853. #define RX_REO_QUEUE_20_RX_BITMAP_223_192_OFFSET 0x00000050
  854. #define RX_REO_QUEUE_20_RX_BITMAP_223_192_LSB 0
  855. #define RX_REO_QUEUE_20_RX_BITMAP_223_192_MASK 0xffffffff
  856. /* Description RX_REO_QUEUE_21_RX_BITMAP_255_224
  857. See Rx_bitmap_31_0 description
  858. <legal all>
  859. */
  860. #define RX_REO_QUEUE_21_RX_BITMAP_255_224_OFFSET 0x00000054
  861. #define RX_REO_QUEUE_21_RX_BITMAP_255_224_LSB 0
  862. #define RX_REO_QUEUE_21_RX_BITMAP_255_224_MASK 0xffffffff
  863. /* Description RX_REO_QUEUE_22_CURRENT_MPDU_COUNT
  864. The number of MPDUs in the queue.
  865. <legal all>
  866. */
  867. #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_OFFSET 0x00000058
  868. #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_LSB 0
  869. #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_MASK 0x0000007f
  870. /* Description RX_REO_QUEUE_22_CURRENT_MSDU_COUNT
  871. The number of MSDUs in the queue.
  872. <legal all>
  873. */
  874. #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_OFFSET 0x00000058
  875. #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_LSB 7
  876. #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_MASK 0xffffff80
  877. /* Description RX_REO_QUEUE_23_RESERVED_23
  878. <legal 0>
  879. */
  880. #define RX_REO_QUEUE_23_RESERVED_23_OFFSET 0x0000005c
  881. #define RX_REO_QUEUE_23_RESERVED_23_LSB 0
  882. #define RX_REO_QUEUE_23_RESERVED_23_MASK 0x0000000f
  883. /* Description RX_REO_QUEUE_23_TIMEOUT_COUNT
  884. The number of times that REO started forwarding frames
  885. even though there is a hole in the bitmap. Forwarding reason
  886. is Timeout
  887. The counter saturates and freezes at 0x3F
  888. <legal all>
  889. */
  890. #define RX_REO_QUEUE_23_TIMEOUT_COUNT_OFFSET 0x0000005c
  891. #define RX_REO_QUEUE_23_TIMEOUT_COUNT_LSB 4
  892. #define RX_REO_QUEUE_23_TIMEOUT_COUNT_MASK 0x000003f0
  893. /* Description RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT
  894. The number of times that REO started forwarding frames
  895. even though there is a hole in the bitmap. Forwarding reason
  896. is reception of BAR frame.
  897. The counter saturates and freezes at 0x3F
  898. <legal all>
  899. */
  900. #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_OFFSET 0x0000005c
  901. #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_LSB 10
  902. #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_MASK 0x0000fc00
  903. /* Description RX_REO_QUEUE_23_DUPLICATE_COUNT
  904. The number of duplicate frames that have been detected
  905. <legal all>
  906. */
  907. #define RX_REO_QUEUE_23_DUPLICATE_COUNT_OFFSET 0x0000005c
  908. #define RX_REO_QUEUE_23_DUPLICATE_COUNT_LSB 16
  909. #define RX_REO_QUEUE_23_DUPLICATE_COUNT_MASK 0xffff0000
  910. /* Description RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT
  911. The number of frames that have been received in order
  912. (without a hole that prevented them from being forwarded
  913. immediately)
  914. This corresponds to the Reorder opcodes:
  915. 'FWDCUR' and 'FWD BUF'
  916. <legal all>
  917. */
  918. #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_OFFSET 0x00000060
  919. #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_LSB 0
  920. #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_MASK 0x00ffffff
  921. /* Description RX_REO_QUEUE_24_BAR_RECEIVED_COUNT
  922. The number of times a BAR frame is received.
  923. This corresponds to the Reorder opcodes with 'DROP'
  924. The counter saturates and freezes at 0xFF
  925. <legal all>
  926. */
  927. #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_OFFSET 0x00000060
  928. #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_LSB 24
  929. #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_MASK 0xff000000
  930. /* Description RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT
  931. The total number of MPDU frames that have been processed
  932. by REO. 'Processing' here means that REO has received them
  933. out of the entrance ring, and retrieved the corresponding
  934. RX_REO_QUEUE Descriptor.
  935. Note that this count includes duplicates, frames that
  936. later had errors, etc.
  937. Note that field 'Duplicate_count' indicates how many of
  938. these MPDUs were duplicates.
  939. <legal all>
  940. */
  941. #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_OFFSET 0x00000064
  942. #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_LSB 0
  943. #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_MASK 0xffffffff
  944. /* Description RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT
  945. The total number of MSDU frames that have been processed
  946. by REO. 'Processing' here means that REO has received them
  947. out of the entrance ring, and retrieved the corresponding
  948. RX_REO_QUEUE Descriptor.
  949. Note that this count includes duplicates, frames that
  950. later had errors, etc.
  951. <legal all>
  952. */
  953. #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_OFFSET 0x00000068
  954. #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_LSB 0
  955. #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_MASK 0xffffffff
  956. /* Description RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT
  957. An approximation of the number of bytes processed for
  958. this queue.
  959. 'Processing' here means that REO has received them out
  960. of the entrance ring, and retrieved the corresponding
  961. RX_REO_QUEUE Descriptor.
  962. Note that this count includes duplicates, frames that
  963. later had errors, etc.
  964. In 64 byte units
  965. <legal all>
  966. */
  967. #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_OFFSET 0x0000006c
  968. #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_LSB 0
  969. #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_MASK 0xffffffff
  970. /* Description RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT
  971. The number of MPDUs received after the window had
  972. already moved on. The 'late' sequence window is defined as
  973. (Window SSN - 256) - (Window SSN - 1)
  974. This corresponds with Out of order detection in
  975. duplicate detect FSM
  976. The counter saturates and freezes at 0xFFF
  977. <legal all>
  978. */
  979. #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_OFFSET 0x00000070
  980. #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_LSB 0
  981. #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_MASK 0x00000fff
  982. /* Description RX_REO_QUEUE_28_WINDOW_JUMP_2K
  983. The number of times the window moved more then 2K
  984. The counter saturates and freezes at 0xF
  985. (Note: field name can not start with number: previous
  986. 2k_window_jump)
  987. <legal all>
  988. */
  989. #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_OFFSET 0x00000070
  990. #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_LSB 12
  991. #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_MASK 0x0000f000
  992. /* Description RX_REO_QUEUE_28_HOLE_COUNT
  993. The number of times a hole was created in the receive
  994. bitmap.
  995. This corresponds to the Reorder opcodes with 'QCUR'
  996. <legal all>
  997. */
  998. #define RX_REO_QUEUE_28_HOLE_COUNT_OFFSET 0x00000070
  999. #define RX_REO_QUEUE_28_HOLE_COUNT_LSB 16
  1000. #define RX_REO_QUEUE_28_HOLE_COUNT_MASK 0xffff0000
  1001. /* Description RX_REO_QUEUE_29_RESERVED_29
  1002. <legal 0>
  1003. */
  1004. #define RX_REO_QUEUE_29_RESERVED_29_OFFSET 0x00000074
  1005. #define RX_REO_QUEUE_29_RESERVED_29_LSB 0
  1006. #define RX_REO_QUEUE_29_RESERVED_29_MASK 0xffffffff
  1007. /* Description RX_REO_QUEUE_30_RESERVED_30
  1008. <legal 0>
  1009. */
  1010. #define RX_REO_QUEUE_30_RESERVED_30_OFFSET 0x00000078
  1011. #define RX_REO_QUEUE_30_RESERVED_30_LSB 0
  1012. #define RX_REO_QUEUE_30_RESERVED_30_MASK 0xffffffff
  1013. /* Description RX_REO_QUEUE_31_RESERVED_31
  1014. <legal 0>
  1015. */
  1016. #define RX_REO_QUEUE_31_RESERVED_31_OFFSET 0x0000007c
  1017. #define RX_REO_QUEUE_31_RESERVED_31_LSB 0
  1018. #define RX_REO_QUEUE_31_RESERVED_31_MASK 0xffffffff
  1019. #endif // _RX_REO_QUEUE_H_