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 // $ATH_LICENSE_HW_HDR_C$ 20 // 21 // DO NOT EDIT! This file is automatically generated 22 // These definitions are tied to a particular hardware layout 23 24 25 #ifndef _RX_REO_QUEUE_H_ 26 #define _RX_REO_QUEUE_H_ 27 #if !defined(__ASSEMBLER__) 28 #endif 29 30 #include "uniform_descriptor_header.h" 31 32 // ################ START SUMMARY ################# 33 // 34 // Dword Fields 35 // 0 struct uniform_descriptor_header descriptor_header; 36 // 1 receive_queue_number[15:0], reserved_1b[31:16] 37 // 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] 38 // 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] 39 // 4 pn_31_0[31:0] 40 // 5 pn_63_32[31:0] 41 // 6 pn_95_64[31:0] 42 // 7 pn_127_96[31:0] 43 // 8 last_rx_enqueue_timestamp[31:0] 44 // 9 last_rx_dequeue_timestamp[31:0] 45 // 10 ptr_to_next_aging_queue_31_0[31:0] 46 // 11 ptr_to_next_aging_queue_39_32[7:0], reserved_11a[31:8] 47 // 12 ptr_to_previous_aging_queue_31_0[31:0] 48 // 13 ptr_to_previous_aging_queue_39_32[7:0], reserved_13a[31:8] 49 // 14 rx_bitmap_31_0[31:0] 50 // 15 rx_bitmap_63_32[31:0] 51 // 16 rx_bitmap_95_64[31:0] 52 // 17 rx_bitmap_127_96[31:0] 53 // 18 rx_bitmap_159_128[31:0] 54 // 19 rx_bitmap_191_160[31:0] 55 // 20 rx_bitmap_223_192[31:0] 56 // 21 rx_bitmap_255_224[31:0] 57 // 22 current_mpdu_count[6:0], current_msdu_count[31:7] 58 // 23 reserved_23[3:0], timeout_count[9:4], forward_due_to_bar_count[15:10], duplicate_count[31:16] 59 // 24 frames_in_order_count[23:0], bar_received_count[31:24] 60 // 25 mpdu_frames_processed_count[31:0] 61 // 26 msdu_frames_processed_count[31:0] 62 // 27 total_processed_byte_count[31:0] 63 // 28 late_receive_mpdu_count[11:0], window_jump_2k[15:12], hole_count[31:16] 64 // 29 reserved_29[31:0] 65 // 30 reserved_30[31:0] 66 // 31 reserved_31[31:0] 67 // 68 // ################ END SUMMARY ################# 69 70 #define NUM_OF_DWORDS_RX_REO_QUEUE 32 71 72 struct rx_reo_queue { 73 struct uniform_descriptor_header descriptor_header; 74 uint32_t receive_queue_number : 16, //[15:0] 75 reserved_1b : 16; //[31:16] 76 uint32_t vld : 1, //[0] 77 associated_link_descriptor_counter: 2, //[2:1] 78 disable_duplicate_detection : 1, //[3] 79 soft_reorder_enable : 1, //[4] 80 ac : 2, //[6:5] 81 bar : 1, //[7] 82 rty : 1, //[8] 83 chk_2k_mode : 1, //[9] 84 oor_mode : 1, //[10] 85 ba_window_size : 8, //[18:11] 86 pn_check_needed : 1, //[19] 87 pn_shall_be_even : 1, //[20] 88 pn_shall_be_uneven : 1, //[21] 89 pn_handling_enable : 1, //[22] 90 pn_size : 2, //[24:23] 91 ignore_ampdu_flag : 1, //[25] 92 reserved_2b : 6; //[31:26] 93 uint32_t svld : 1, //[0] 94 ssn : 12, //[12:1] 95 current_index : 8, //[20:13] 96 seq_2k_error_detected_flag : 1, //[21] 97 pn_error_detected_flag : 1, //[22] 98 reserved_3a : 8, //[30:23] 99 pn_valid : 1; //[31] 100 uint32_t pn_31_0 : 32; //[31:0] 101 uint32_t pn_63_32 : 32; //[31:0] 102 uint32_t pn_95_64 : 32; //[31:0] 103 uint32_t pn_127_96 : 32; //[31:0] 104 uint32_t last_rx_enqueue_timestamp : 32; //[31:0] 105 uint32_t last_rx_dequeue_timestamp : 32; //[31:0] 106 uint32_t ptr_to_next_aging_queue_31_0 : 32; //[31:0] 107 uint32_t ptr_to_next_aging_queue_39_32 : 8, //[7:0] 108 reserved_11a : 24; //[31:8] 109 uint32_t ptr_to_previous_aging_queue_31_0: 32; //[31:0] 110 uint32_t ptr_to_previous_aging_queue_39_32: 8, //[7:0] 111 reserved_13a : 24; //[31:8] 112 uint32_t rx_bitmap_31_0 : 32; //[31:0] 113 uint32_t rx_bitmap_63_32 : 32; //[31:0] 114 uint32_t rx_bitmap_95_64 : 32; //[31:0] 115 uint32_t rx_bitmap_127_96 : 32; //[31:0] 116 uint32_t rx_bitmap_159_128 : 32; //[31:0] 117 uint32_t rx_bitmap_191_160 : 32; //[31:0] 118 uint32_t rx_bitmap_223_192 : 32; //[31:0] 119 uint32_t rx_bitmap_255_224 : 32; //[31:0] 120 uint32_t current_mpdu_count : 7, //[6:0] 121 current_msdu_count : 25; //[31:7] 122 uint32_t reserved_23 : 4, //[3:0] 123 timeout_count : 6, //[9:4] 124 forward_due_to_bar_count : 6, //[15:10] 125 duplicate_count : 16; //[31:16] 126 uint32_t frames_in_order_count : 24, //[23:0] 127 bar_received_count : 8; //[31:24] 128 uint32_t mpdu_frames_processed_count : 32; //[31:0] 129 uint32_t msdu_frames_processed_count : 32; //[31:0] 130 uint32_t total_processed_byte_count : 32; //[31:0] 131 uint32_t late_receive_mpdu_count : 12, //[11:0] 132 window_jump_2k : 4, //[15:12] 133 hole_count : 16; //[31:16] 134 uint32_t reserved_29 : 32; //[31:0] 135 uint32_t reserved_30 : 32; //[31:0] 136 uint32_t reserved_31 : 32; //[31:0] 137 }; 138 139 /* 140 141 struct uniform_descriptor_header descriptor_header 142 143 Details about which module owns this struct. 144 145 Note that sub field Buffer_type shall be set to 146 Receive_REO_queue_descriptor 147 148 receive_queue_number 149 150 Indicates the MPDU queue ID to which this MPDU link 151 descriptor belongs 152 153 Used for tracking and debugging 154 155 <legal all> 156 157 reserved_1b 158 159 <legal 0> 160 161 vld 162 163 Valid bit indicating a session is established and the 164 queue descriptor is valid(Filled by SW) 165 166 <legal all> 167 168 associated_link_descriptor_counter 169 170 Indicates which of the 3 link descriptor counters shall 171 be incremented or decremented when link descriptors are 172 added or removed from this flow queue. 173 174 MSDU link descriptors related with MPDUs stored in the 175 re-order buffer shall also be included in this count. 176 177 178 179 <legal 0-2> 180 181 disable_duplicate_detection 182 183 When set, do not perform any duplicate detection. 184 185 186 187 <legal all> 188 189 soft_reorder_enable 190 191 When set, REO has been instructed to not perform the 192 actual re-ordering of frames for this queue, but just to 193 insert the reorder opcodes. 194 195 196 197 Note that this implies that REO is also not going to 198 perform any MSDU level operations, and the entire MPDU (and 199 thus pointer to the MSDU link descriptor) will be pushed to 200 a destination ring that SW has programmed in a SW 201 programmable configuration register in REO 202 203 204 205 <legal all> 206 207 ac 208 209 Indicates which access category the queue descriptor 210 belongs to(filled by SW) 211 212 <legal all> 213 214 bar 215 216 Indicates if BAR has been received (mostly used for 217 debug purpose and this is filled by REO) 218 219 <legal all> 220 221 rty 222 223 Retry bit is checked if this bit is set. 224 225 <legal all> 226 227 chk_2k_mode 228 229 Indicates what type of operation is expected from Reo 230 when the received frame SN falls within the 2K window 231 232 233 234 See REO MLD document for programming details. 235 236 <legal all> 237 238 oor_mode 239 240 Out of Order mode: 241 242 Indicates what type of operation is expected when the 243 received frame falls within the OOR window. 244 245 246 247 See REO MLD document for programming details. 248 249 <legal all> 250 251 ba_window_size 252 253 Indicates the negotiated (window size + 1). 254 255 it can go up to Max of 256bits. 256 257 258 259 A value 255 means 256 bitmap, 63 means 64 bitmap, 0 260 (means non-BA session, with window size of 0). The 3 values 261 here are the main values validated, but other values should 262 work as well. 263 264 265 266 A BA window size of 0 (=> one frame entry bitmat), means 267 that there is NO RX_REO_QUEUE_EXT descriptor following this 268 RX_REO_QUEUE STRUCT in memory 269 270 271 272 A BA window size of 1 - 105, means that there is 1 273 RX_REO_QUEUE_EXT descriptor directly following this 274 RX_REO_QUEUE STRUCT in memory. 275 276 277 278 A BA window size of 106 - 210, means that there are 2 279 RX_REO_QUEUE_EXT descriptors directly following this 280 RX_REO_QUEUE STRUCT in memory 281 282 283 284 A BA window size of 211 - 256, means that there are 3 285 RX_REO_QUEUE_EXT descriptors directly following this 286 RX_REO_QUEUE STRUCT in memory 287 288 289 290 <legal 0 - 255> 291 292 pn_check_needed 293 294 When set, REO shall perform the PN increment check 295 296 <legal all> 297 298 pn_shall_be_even 299 300 Field only valid when 'pn_check_needed' is set. 301 302 303 304 When set, REO shall confirm that the received PN number 305 is not only incremented, but also always an even number 306 307 <legal all> 308 309 pn_shall_be_uneven 310 311 Field only valid when 'pn_check_needed' is set. 312 313 314 315 When set, REO shall confirm that the received PN number 316 is not only incremented, but also always an uneven number 317 318 <legal all> 319 320 pn_handling_enable 321 322 Field only valid when 'pn_check_needed' is set. 323 324 325 326 When set, and REO detected a PN error, HW shall set the 327 'pn_error_detected_flag'. 328 329 <legal all> 330 331 pn_size 332 333 Size of the PN field check. 334 335 Needed for wrap around handling... 336 337 338 339 <enum 0 pn_size_24> 340 341 <enum 1 pn_size_48> 342 343 <enum 2 pn_size_128> 344 345 346 347 <legal 0-2> 348 349 ignore_ampdu_flag 350 351 When set, REO shall ignore the ampdu_flag on the 352 entrance descriptor for this queue. 353 354 <legal all> 355 356 reserved_2b 357 358 <legal 0> 359 360 svld 361 362 Sequence number in next field is valid one. It can be 363 filled by SW if the want to fill in the any negotiated SSN, 364 otherwise REO will fill the sequence number of first 365 received packet and set this bit to 1. 366 367 <legal all> 368 369 ssn 370 371 Starting Sequence number of the session, this changes 372 whenever window moves. (can be filled by SW then maintained 373 by REO) 374 375 <legal all> 376 377 current_index 378 379 Points to last forwarded packet 380 381 <legal all> 382 383 seq_2k_error_detected_flag 384 385 Set by REO, can only be cleared by SW 386 387 388 389 When set, REO has detected a 2k error jump in the 390 sequence number and from that moment forward, all new frames 391 are forwarded directly to FW, without duplicate detect, 392 reordering, etc. 393 394 <legal all> 395 396 pn_error_detected_flag 397 398 Set by REO, can only be cleared by SW 399 400 401 402 When set, REO has detected a PN error and from that 403 moment forward, all new frames are forwarded directly to FW, 404 without duplicate detect, reordering, etc. 405 406 <legal all> 407 408 reserved_3a 409 410 <legal 0> 411 412 pn_valid 413 414 PN number in next fields are valid. It can be filled by 415 SW if it wants to fill in the any negotiated SSN, otherwise 416 REO will fill the pn based on the first received packet and 417 set this bit to 1. 418 419 <legal all> 420 421 pn_31_0 422 423 424 <legal all> 425 426 pn_63_32 427 428 Bits [63:32] of the PN number. 429 430 <legal all> 431 432 pn_95_64 433 434 Bits [95:64] of the PN number. 435 436 <legal all> 437 438 pn_127_96 439 440 Bits [127:96] of the PN number. 441 442 <legal all> 443 444 last_rx_enqueue_timestamp 445 446 This timestamp is updated when an MPDU is received and 447 accesses this Queue Descriptor. It does not include the 448 access due to Command TLVs or Aging (which will be updated 449 in Last_rx_dequeue_timestamp). 450 451 <legal all> 452 453 last_rx_dequeue_timestamp 454 455 This timestamp is used for Aging. When an MPDU or 456 multiple MPDUs are forwarded, either due to window movement, 457 bar, aging or command flush, this timestamp is updated. Also 458 when the bitmap is all zero and the first time an MPDU is 459 queued (opcode=QCUR), this timestamp is updated for aging. 460 461 <legal all> 462 463 ptr_to_next_aging_queue_31_0 464 465 Address (address bits 31-0)of next RX_REO_QUEUE 466 descriptor in the 'receive timestamp' ordered list. 467 468 From it the Position of this queue descriptor in the per 469 AC aging waitlist can be derived. 470 471 Value 0x0 indicates the 'NULL' pointer which implies 472 that this is the last entry in the list. 473 474 <legal all> 475 476 ptr_to_next_aging_queue_39_32 477 478 Address (address bits 39-32)of next RX_REO_QUEUE 479 descriptor in the 'receive timestamp' ordered list. 480 481 From it the Position of this queue descriptor in the per 482 AC aging waitlist can be derived. 483 484 Value 0x0 indicates the 'NULL' pointer which implies 485 that this is the last entry in the list. 486 487 <legal all> 488 489 reserved_11a 490 491 <legal 0> 492 493 ptr_to_previous_aging_queue_31_0 494 495 Address (address bits 31-0)of next RX_REO_QUEUE 496 descriptor in the 'receive timestamp' ordered list. 497 498 From it the Position of this queue descriptor in the per 499 AC aging waitlist can be derived. 500 501 Value 0x0 indicates the 'NULL' pointer which implies 502 that this is the first entry in the list. 503 504 <legal all> 505 506 ptr_to_previous_aging_queue_39_32 507 508 Address (address bits 39-32)of next RX_REO_QUEUE 509 descriptor in the 'receive timestamp' ordered list. 510 511 From it the Position of this queue descriptor in the per 512 AC aging waitlist can be derived. 513 514 Value 0x0 indicates the 'NULL' pointer which implies 515 that this is the first entry in the list. 516 517 <legal all> 518 519 reserved_13a 520 521 <legal 0> 522 523 rx_bitmap_31_0 524 525 When a bit is set, the corresponding frame is currently 526 held in the re-order queue. 527 528 The bitmap is Fully managed by HW. 529 530 SW shall init this to 0, and then never ever change it 531 532 <legal all> 533 534 rx_bitmap_63_32 535 536 See Rx_bitmap_31_0 description 537 538 <legal all> 539 540 rx_bitmap_95_64 541 542 See Rx_bitmap_31_0 description 543 544 <legal all> 545 546 rx_bitmap_127_96 547 548 See Rx_bitmap_31_0 description 549 550 <legal all> 551 552 rx_bitmap_159_128 553 554 See Rx_bitmap_31_0 description 555 556 <legal all> 557 558 rx_bitmap_191_160 559 560 See Rx_bitmap_31_0 description 561 562 <legal all> 563 564 rx_bitmap_223_192 565 566 See Rx_bitmap_31_0 description 567 568 <legal all> 569 570 rx_bitmap_255_224 571 572 See Rx_bitmap_31_0 description 573 574 <legal all> 575 576 current_mpdu_count 577 578 The number of MPDUs in the queue. 579 580 581 582 <legal all> 583 584 current_msdu_count 585 586 The number of MSDUs in the queue. 587 588 <legal all> 589 590 reserved_23 591 592 <legal 0> 593 594 timeout_count 595 596 The number of times that REO started forwarding frames 597 even though there is a hole in the bitmap. Forwarding reason 598 is Timeout 599 600 601 602 The counter saturates and freezes at 0x3F 603 604 605 606 <legal all> 607 608 forward_due_to_bar_count 609 610 The number of times that REO started forwarding frames 611 even though there is a hole in the bitmap. Forwarding reason 612 is reception of BAR frame. 613 614 615 616 The counter saturates and freezes at 0x3F 617 618 619 620 <legal all> 621 622 duplicate_count 623 624 The number of duplicate frames that have been detected 625 626 <legal all> 627 628 frames_in_order_count 629 630 The number of frames that have been received in order 631 (without a hole that prevented them from being forwarded 632 immediately) 633 634 635 636 This corresponds to the Reorder opcodes: 637 638 'FWDCUR' and 'FWD BUF' 639 640 641 642 <legal all> 643 644 bar_received_count 645 646 The number of times a BAR frame is received. 647 648 649 650 This corresponds to the Reorder opcodes with 'DROP' 651 652 653 654 The counter saturates and freezes at 0xFF 655 656 <legal all> 657 658 mpdu_frames_processed_count 659 660 The total number of MPDU frames that have been processed 661 by REO. 'Processing' here means that REO has received them 662 out of the entrance ring, and retrieved the corresponding 663 RX_REO_QUEUE Descriptor. 664 665 666 667 Note that this count includes duplicates, frames that 668 later had errors, etc. 669 670 671 672 Note that field 'Duplicate_count' indicates how many of 673 these MPDUs were duplicates. 674 675 676 677 <legal all> 678 679 msdu_frames_processed_count 680 681 The total number of MSDU frames that have been processed 682 by REO. 'Processing' here means that REO has received them 683 out of the entrance ring, and retrieved the corresponding 684 RX_REO_QUEUE Descriptor. 685 686 687 688 Note that this count includes duplicates, frames that 689 later had errors, etc. 690 691 692 693 <legal all> 694 695 total_processed_byte_count 696 697 An approximation of the number of bytes processed for 698 this queue. 699 700 'Processing' here means that REO has received them out 701 of the entrance ring, and retrieved the corresponding 702 RX_REO_QUEUE Descriptor. 703 704 705 706 Note that this count includes duplicates, frames that 707 later had errors, etc. 708 709 710 711 In 64 byte units 712 713 <legal all> 714 715 late_receive_mpdu_count 716 717 The number of MPDUs received after the window had 718 already moved on. The 'late' sequence window is defined as 719 (Window SSN - 256) - (Window SSN - 1) 720 721 722 723 This corresponds with Out of order detection in 724 duplicate detect FSM 725 726 727 728 The counter saturates and freezes at 0xFFF 729 730 731 732 <legal all> 733 734 window_jump_2k 735 736 The number of times the window moved more then 2K 737 738 739 740 The counter saturates and freezes at 0xF 741 742 743 744 (Note: field name can not start with number: previous 745 2k_window_jump) 746 747 748 749 <legal all> 750 751 hole_count 752 753 The number of times a hole was created in the receive 754 bitmap. 755 756 757 758 This corresponds to the Reorder opcodes with 'QCUR' 759 760 761 762 <legal all> 763 764 reserved_29 765 766 <legal 0> 767 768 reserved_30 769 770 <legal 0> 771 772 reserved_31 773 774 <legal 0> 775 */ 776 777 #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_OFFSET 0x00000000 778 #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_LSB 0 779 #define RX_REO_QUEUE_0_UNIFORM_DESCRIPTOR_HEADER_DESCRIPTOR_HEADER_MASK 0xffffffff 780 781 /* Description RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER 782 783 Indicates the MPDU queue ID to which this MPDU link 784 descriptor belongs 785 786 Used for tracking and debugging 787 788 <legal all> 789 */ 790 #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_OFFSET 0x00000004 791 #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_LSB 0 792 #define RX_REO_QUEUE_1_RECEIVE_QUEUE_NUMBER_MASK 0x0000ffff 793 794 /* Description RX_REO_QUEUE_1_RESERVED_1B 795 796 <legal 0> 797 */ 798 #define RX_REO_QUEUE_1_RESERVED_1B_OFFSET 0x00000004 799 #define RX_REO_QUEUE_1_RESERVED_1B_LSB 16 800 #define RX_REO_QUEUE_1_RESERVED_1B_MASK 0xffff0000 801 802 /* Description RX_REO_QUEUE_2_VLD 803 804 Valid bit indicating a session is established and the 805 queue descriptor is valid(Filled by SW) 806 807 <legal all> 808 */ 809 #define RX_REO_QUEUE_2_VLD_OFFSET 0x00000008 810 #define RX_REO_QUEUE_2_VLD_LSB 0 811 #define RX_REO_QUEUE_2_VLD_MASK 0x00000001 812 813 /* Description RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER 814 815 Indicates which of the 3 link descriptor counters shall 816 be incremented or decremented when link descriptors are 817 added or removed from this flow queue. 818 819 MSDU link descriptors related with MPDUs stored in the 820 re-order buffer shall also be included in this count. 821 822 823 824 <legal 0-2> 825 */ 826 #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_OFFSET 0x00000008 827 #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_LSB 1 828 #define RX_REO_QUEUE_2_ASSOCIATED_LINK_DESCRIPTOR_COUNTER_MASK 0x00000006 829 830 /* Description RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION 831 832 When set, do not perform any duplicate detection. 833 834 835 836 <legal all> 837 */ 838 #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_OFFSET 0x00000008 839 #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_LSB 3 840 #define RX_REO_QUEUE_2_DISABLE_DUPLICATE_DETECTION_MASK 0x00000008 841 842 /* Description RX_REO_QUEUE_2_SOFT_REORDER_ENABLE 843 844 When set, REO has been instructed to not perform the 845 actual re-ordering of frames for this queue, but just to 846 insert the reorder opcodes. 847 848 849 850 Note that this implies that REO is also not going to 851 perform any MSDU level operations, and the entire MPDU (and 852 thus pointer to the MSDU link descriptor) will be pushed to 853 a destination ring that SW has programmed in a SW 854 programmable configuration register in REO 855 856 857 858 <legal all> 859 */ 860 #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_OFFSET 0x00000008 861 #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_LSB 4 862 #define RX_REO_QUEUE_2_SOFT_REORDER_ENABLE_MASK 0x00000010 863 864 /* Description RX_REO_QUEUE_2_AC 865 866 Indicates which access category the queue descriptor 867 belongs to(filled by SW) 868 869 <legal all> 870 */ 871 #define RX_REO_QUEUE_2_AC_OFFSET 0x00000008 872 #define RX_REO_QUEUE_2_AC_LSB 5 873 #define RX_REO_QUEUE_2_AC_MASK 0x00000060 874 875 /* Description RX_REO_QUEUE_2_BAR 876 877 Indicates if BAR has been received (mostly used for 878 debug purpose and this is filled by REO) 879 880 <legal all> 881 */ 882 #define RX_REO_QUEUE_2_BAR_OFFSET 0x00000008 883 #define RX_REO_QUEUE_2_BAR_LSB 7 884 #define RX_REO_QUEUE_2_BAR_MASK 0x00000080 885 886 /* Description RX_REO_QUEUE_2_RTY 887 888 Retry bit is checked if this bit is set. 889 890 <legal all> 891 */ 892 #define RX_REO_QUEUE_2_RTY_OFFSET 0x00000008 893 #define RX_REO_QUEUE_2_RTY_LSB 8 894 #define RX_REO_QUEUE_2_RTY_MASK 0x00000100 895 896 /* Description RX_REO_QUEUE_2_CHK_2K_MODE 897 898 Indicates what type of operation is expected from Reo 899 when the received frame SN falls within the 2K window 900 901 902 903 See REO MLD document for programming details. 904 905 <legal all> 906 */ 907 #define RX_REO_QUEUE_2_CHK_2K_MODE_OFFSET 0x00000008 908 #define RX_REO_QUEUE_2_CHK_2K_MODE_LSB 9 909 #define RX_REO_QUEUE_2_CHK_2K_MODE_MASK 0x00000200 910 911 /* Description RX_REO_QUEUE_2_OOR_MODE 912 913 Out of Order mode: 914 915 Indicates what type of operation is expected when the 916 received frame falls within the OOR window. 917 918 919 920 See REO MLD document for programming details. 921 922 <legal all> 923 */ 924 #define RX_REO_QUEUE_2_OOR_MODE_OFFSET 0x00000008 925 #define RX_REO_QUEUE_2_OOR_MODE_LSB 10 926 #define RX_REO_QUEUE_2_OOR_MODE_MASK 0x00000400 927 928 /* Description RX_REO_QUEUE_2_BA_WINDOW_SIZE 929 930 Indicates the negotiated (window size + 1). 931 932 it can go up to Max of 256bits. 933 934 935 936 A value 255 means 256 bitmap, 63 means 64 bitmap, 0 937 (means non-BA session, with window size of 0). The 3 values 938 here are the main values validated, but other values should 939 work as well. 940 941 942 943 A BA window size of 0 (=> one frame entry bitmat), means 944 that there is NO RX_REO_QUEUE_EXT descriptor following this 945 RX_REO_QUEUE STRUCT in memory 946 947 948 949 A BA window size of 1 - 105, means that there is 1 950 RX_REO_QUEUE_EXT descriptor directly following this 951 RX_REO_QUEUE STRUCT in memory. 952 953 954 955 A BA window size of 106 - 210, means that there are 2 956 RX_REO_QUEUE_EXT descriptors directly following this 957 RX_REO_QUEUE STRUCT in memory 958 959 960 961 A BA window size of 211 - 256, means that there are 3 962 RX_REO_QUEUE_EXT descriptors directly following this 963 RX_REO_QUEUE STRUCT in memory 964 965 966 967 <legal 0 - 255> 968 */ 969 #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_OFFSET 0x00000008 970 #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_LSB 11 971 #define RX_REO_QUEUE_2_BA_WINDOW_SIZE_MASK 0x0007f800 972 973 /* Description RX_REO_QUEUE_2_PN_CHECK_NEEDED 974 975 When set, REO shall perform the PN increment check 976 977 <legal all> 978 */ 979 #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_OFFSET 0x00000008 980 #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_LSB 19 981 #define RX_REO_QUEUE_2_PN_CHECK_NEEDED_MASK 0x00080000 982 983 /* Description RX_REO_QUEUE_2_PN_SHALL_BE_EVEN 984 985 Field only valid when 'pn_check_needed' is set. 986 987 988 989 When set, REO shall confirm that the received PN number 990 is not only incremented, but also always an even number 991 992 <legal all> 993 */ 994 #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_OFFSET 0x00000008 995 #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_LSB 20 996 #define RX_REO_QUEUE_2_PN_SHALL_BE_EVEN_MASK 0x00100000 997 998 /* Description RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN 999 1000 Field only valid when 'pn_check_needed' is set. 1001 1002 1003 1004 When set, REO shall confirm that the received PN number 1005 is not only incremented, but also always an uneven number 1006 1007 <legal all> 1008 */ 1009 #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_OFFSET 0x00000008 1010 #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_LSB 21 1011 #define RX_REO_QUEUE_2_PN_SHALL_BE_UNEVEN_MASK 0x00200000 1012 1013 /* Description RX_REO_QUEUE_2_PN_HANDLING_ENABLE 1014 1015 Field only valid when 'pn_check_needed' is set. 1016 1017 1018 1019 When set, and REO detected a PN error, HW shall set the 1020 'pn_error_detected_flag'. 1021 1022 <legal all> 1023 */ 1024 #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_OFFSET 0x00000008 1025 #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_LSB 22 1026 #define RX_REO_QUEUE_2_PN_HANDLING_ENABLE_MASK 0x00400000 1027 1028 /* Description RX_REO_QUEUE_2_PN_SIZE 1029 1030 Size of the PN field check. 1031 1032 Needed for wrap around handling... 1033 1034 1035 1036 <enum 0 pn_size_24> 1037 1038 <enum 1 pn_size_48> 1039 1040 <enum 2 pn_size_128> 1041 1042 1043 1044 <legal 0-2> 1045 */ 1046 #define RX_REO_QUEUE_2_PN_SIZE_OFFSET 0x00000008 1047 #define RX_REO_QUEUE_2_PN_SIZE_LSB 23 1048 #define RX_REO_QUEUE_2_PN_SIZE_MASK 0x01800000 1049 1050 /* Description RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG 1051 1052 When set, REO shall ignore the ampdu_flag on the 1053 entrance descriptor for this queue. 1054 1055 <legal all> 1056 */ 1057 #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_OFFSET 0x00000008 1058 #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_LSB 25 1059 #define RX_REO_QUEUE_2_IGNORE_AMPDU_FLAG_MASK 0x02000000 1060 1061 /* Description RX_REO_QUEUE_2_RESERVED_2B 1062 1063 <legal 0> 1064 */ 1065 #define RX_REO_QUEUE_2_RESERVED_2B_OFFSET 0x00000008 1066 #define RX_REO_QUEUE_2_RESERVED_2B_LSB 26 1067 #define RX_REO_QUEUE_2_RESERVED_2B_MASK 0xfc000000 1068 1069 /* Description RX_REO_QUEUE_3_SVLD 1070 1071 Sequence number in next field is valid one. It can be 1072 filled by SW if the want to fill in the any negotiated SSN, 1073 otherwise REO will fill the sequence number of first 1074 received packet and set this bit to 1. 1075 1076 <legal all> 1077 */ 1078 #define RX_REO_QUEUE_3_SVLD_OFFSET 0x0000000c 1079 #define RX_REO_QUEUE_3_SVLD_LSB 0 1080 #define RX_REO_QUEUE_3_SVLD_MASK 0x00000001 1081 1082 /* Description RX_REO_QUEUE_3_SSN 1083 1084 Starting Sequence number of the session, this changes 1085 whenever window moves. (can be filled by SW then maintained 1086 by REO) 1087 1088 <legal all> 1089 */ 1090 #define RX_REO_QUEUE_3_SSN_OFFSET 0x0000000c 1091 #define RX_REO_QUEUE_3_SSN_LSB 1 1092 #define RX_REO_QUEUE_3_SSN_MASK 0x00001ffe 1093 1094 /* Description RX_REO_QUEUE_3_CURRENT_INDEX 1095 1096 Points to last forwarded packet 1097 1098 <legal all> 1099 */ 1100 #define RX_REO_QUEUE_3_CURRENT_INDEX_OFFSET 0x0000000c 1101 #define RX_REO_QUEUE_3_CURRENT_INDEX_LSB 13 1102 #define RX_REO_QUEUE_3_CURRENT_INDEX_MASK 0x001fe000 1103 1104 /* Description RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG 1105 1106 Set by REO, can only be cleared by SW 1107 1108 1109 1110 When set, REO has detected a 2k error jump in the 1111 sequence number and from that moment forward, all new frames 1112 are forwarded directly to FW, without duplicate detect, 1113 reordering, etc. 1114 1115 <legal all> 1116 */ 1117 #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_OFFSET 0x0000000c 1118 #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_LSB 21 1119 #define RX_REO_QUEUE_3_SEQ_2K_ERROR_DETECTED_FLAG_MASK 0x00200000 1120 1121 /* Description RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG 1122 1123 Set by REO, can only be cleared by SW 1124 1125 1126 1127 When set, REO has detected a PN error and from that 1128 moment forward, all new frames are forwarded directly to FW, 1129 without duplicate detect, reordering, etc. 1130 1131 <legal all> 1132 */ 1133 #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_OFFSET 0x0000000c 1134 #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_LSB 22 1135 #define RX_REO_QUEUE_3_PN_ERROR_DETECTED_FLAG_MASK 0x00400000 1136 1137 /* Description RX_REO_QUEUE_3_RESERVED_3A 1138 1139 <legal 0> 1140 */ 1141 #define RX_REO_QUEUE_3_RESERVED_3A_OFFSET 0x0000000c 1142 #define RX_REO_QUEUE_3_RESERVED_3A_LSB 23 1143 #define RX_REO_QUEUE_3_RESERVED_3A_MASK 0x7f800000 1144 1145 /* Description RX_REO_QUEUE_3_PN_VALID 1146 1147 PN number in next fields are valid. It can be filled by 1148 SW if it wants to fill in the any negotiated SSN, otherwise 1149 REO will fill the pn based on the first received packet and 1150 set this bit to 1. 1151 1152 <legal all> 1153 */ 1154 #define RX_REO_QUEUE_3_PN_VALID_OFFSET 0x0000000c 1155 #define RX_REO_QUEUE_3_PN_VALID_LSB 31 1156 #define RX_REO_QUEUE_3_PN_VALID_MASK 0x80000000 1157 1158 /* Description RX_REO_QUEUE_4_PN_31_0 1159 1160 1161 <legal all> 1162 */ 1163 #define RX_REO_QUEUE_4_PN_31_0_OFFSET 0x00000010 1164 #define RX_REO_QUEUE_4_PN_31_0_LSB 0 1165 #define RX_REO_QUEUE_4_PN_31_0_MASK 0xffffffff 1166 1167 /* Description RX_REO_QUEUE_5_PN_63_32 1168 1169 Bits [63:32] of the PN number. 1170 1171 <legal all> 1172 */ 1173 #define RX_REO_QUEUE_5_PN_63_32_OFFSET 0x00000014 1174 #define RX_REO_QUEUE_5_PN_63_32_LSB 0 1175 #define RX_REO_QUEUE_5_PN_63_32_MASK 0xffffffff 1176 1177 /* Description RX_REO_QUEUE_6_PN_95_64 1178 1179 Bits [95:64] of the PN number. 1180 1181 <legal all> 1182 */ 1183 #define RX_REO_QUEUE_6_PN_95_64_OFFSET 0x00000018 1184 #define RX_REO_QUEUE_6_PN_95_64_LSB 0 1185 #define RX_REO_QUEUE_6_PN_95_64_MASK 0xffffffff 1186 1187 /* Description RX_REO_QUEUE_7_PN_127_96 1188 1189 Bits [127:96] of the PN number. 1190 1191 <legal all> 1192 */ 1193 #define RX_REO_QUEUE_7_PN_127_96_OFFSET 0x0000001c 1194 #define RX_REO_QUEUE_7_PN_127_96_LSB 0 1195 #define RX_REO_QUEUE_7_PN_127_96_MASK 0xffffffff 1196 1197 /* Description RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP 1198 1199 This timestamp is updated when an MPDU is received and 1200 accesses this Queue Descriptor. It does not include the 1201 access due to Command TLVs or Aging (which will be updated 1202 in Last_rx_dequeue_timestamp). 1203 1204 <legal all> 1205 */ 1206 #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_OFFSET 0x00000020 1207 #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_LSB 0 1208 #define RX_REO_QUEUE_8_LAST_RX_ENQUEUE_TIMESTAMP_MASK 0xffffffff 1209 1210 /* Description RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP 1211 1212 This timestamp is used for Aging. When an MPDU or 1213 multiple MPDUs are forwarded, either due to window movement, 1214 bar, aging or command flush, this timestamp is updated. Also 1215 when the bitmap is all zero and the first time an MPDU is 1216 queued (opcode=QCUR), this timestamp is updated for aging. 1217 1218 <legal all> 1219 */ 1220 #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_OFFSET 0x00000024 1221 #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_LSB 0 1222 #define RX_REO_QUEUE_9_LAST_RX_DEQUEUE_TIMESTAMP_MASK 0xffffffff 1223 1224 /* Description RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0 1225 1226 Address (address bits 31-0)of next RX_REO_QUEUE 1227 descriptor in the 'receive timestamp' ordered list. 1228 1229 From it the Position of this queue descriptor in the per 1230 AC aging waitlist can be derived. 1231 1232 Value 0x0 indicates the 'NULL' pointer which implies 1233 that this is the last entry in the list. 1234 1235 <legal all> 1236 */ 1237 #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_OFFSET 0x00000028 1238 #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_LSB 0 1239 #define RX_REO_QUEUE_10_PTR_TO_NEXT_AGING_QUEUE_31_0_MASK 0xffffffff 1240 1241 /* Description RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32 1242 1243 Address (address bits 39-32)of next RX_REO_QUEUE 1244 descriptor in the 'receive timestamp' ordered list. 1245 1246 From it the Position of this queue descriptor in the per 1247 AC aging waitlist can be derived. 1248 1249 Value 0x0 indicates the 'NULL' pointer which implies 1250 that this is the last entry in the list. 1251 1252 <legal all> 1253 */ 1254 #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_OFFSET 0x0000002c 1255 #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_LSB 0 1256 #define RX_REO_QUEUE_11_PTR_TO_NEXT_AGING_QUEUE_39_32_MASK 0x000000ff 1257 1258 /* Description RX_REO_QUEUE_11_RESERVED_11A 1259 1260 <legal 0> 1261 */ 1262 #define RX_REO_QUEUE_11_RESERVED_11A_OFFSET 0x0000002c 1263 #define RX_REO_QUEUE_11_RESERVED_11A_LSB 8 1264 #define RX_REO_QUEUE_11_RESERVED_11A_MASK 0xffffff00 1265 1266 /* Description RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0 1267 1268 Address (address bits 31-0)of next RX_REO_QUEUE 1269 descriptor in the 'receive timestamp' ordered list. 1270 1271 From it the Position of this queue descriptor in the per 1272 AC aging waitlist can be derived. 1273 1274 Value 0x0 indicates the 'NULL' pointer which implies 1275 that this is the first entry in the list. 1276 1277 <legal all> 1278 */ 1279 #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_OFFSET 0x00000030 1280 #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_LSB 0 1281 #define RX_REO_QUEUE_12_PTR_TO_PREVIOUS_AGING_QUEUE_31_0_MASK 0xffffffff 1282 1283 /* Description RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32 1284 1285 Address (address bits 39-32)of next RX_REO_QUEUE 1286 descriptor in the 'receive timestamp' ordered list. 1287 1288 From it the Position of this queue descriptor in the per 1289 AC aging waitlist can be derived. 1290 1291 Value 0x0 indicates the 'NULL' pointer which implies 1292 that this is the first entry in the list. 1293 1294 <legal all> 1295 */ 1296 #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_OFFSET 0x00000034 1297 #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_LSB 0 1298 #define RX_REO_QUEUE_13_PTR_TO_PREVIOUS_AGING_QUEUE_39_32_MASK 0x000000ff 1299 1300 /* Description RX_REO_QUEUE_13_RESERVED_13A 1301 1302 <legal 0> 1303 */ 1304 #define RX_REO_QUEUE_13_RESERVED_13A_OFFSET 0x00000034 1305 #define RX_REO_QUEUE_13_RESERVED_13A_LSB 8 1306 #define RX_REO_QUEUE_13_RESERVED_13A_MASK 0xffffff00 1307 1308 /* Description RX_REO_QUEUE_14_RX_BITMAP_31_0 1309 1310 When a bit is set, the corresponding frame is currently 1311 held in the re-order queue. 1312 1313 The bitmap is Fully managed by HW. 1314 1315 SW shall init this to 0, and then never ever change it 1316 1317 <legal all> 1318 */ 1319 #define RX_REO_QUEUE_14_RX_BITMAP_31_0_OFFSET 0x00000038 1320 #define RX_REO_QUEUE_14_RX_BITMAP_31_0_LSB 0 1321 #define RX_REO_QUEUE_14_RX_BITMAP_31_0_MASK 0xffffffff 1322 1323 /* Description RX_REO_QUEUE_15_RX_BITMAP_63_32 1324 1325 See Rx_bitmap_31_0 description 1326 1327 <legal all> 1328 */ 1329 #define RX_REO_QUEUE_15_RX_BITMAP_63_32_OFFSET 0x0000003c 1330 #define RX_REO_QUEUE_15_RX_BITMAP_63_32_LSB 0 1331 #define RX_REO_QUEUE_15_RX_BITMAP_63_32_MASK 0xffffffff 1332 1333 /* Description RX_REO_QUEUE_16_RX_BITMAP_95_64 1334 1335 See Rx_bitmap_31_0 description 1336 1337 <legal all> 1338 */ 1339 #define RX_REO_QUEUE_16_RX_BITMAP_95_64_OFFSET 0x00000040 1340 #define RX_REO_QUEUE_16_RX_BITMAP_95_64_LSB 0 1341 #define RX_REO_QUEUE_16_RX_BITMAP_95_64_MASK 0xffffffff 1342 1343 /* Description RX_REO_QUEUE_17_RX_BITMAP_127_96 1344 1345 See Rx_bitmap_31_0 description 1346 1347 <legal all> 1348 */ 1349 #define RX_REO_QUEUE_17_RX_BITMAP_127_96_OFFSET 0x00000044 1350 #define RX_REO_QUEUE_17_RX_BITMAP_127_96_LSB 0 1351 #define RX_REO_QUEUE_17_RX_BITMAP_127_96_MASK 0xffffffff 1352 1353 /* Description RX_REO_QUEUE_18_RX_BITMAP_159_128 1354 1355 See Rx_bitmap_31_0 description 1356 1357 <legal all> 1358 */ 1359 #define RX_REO_QUEUE_18_RX_BITMAP_159_128_OFFSET 0x00000048 1360 #define RX_REO_QUEUE_18_RX_BITMAP_159_128_LSB 0 1361 #define RX_REO_QUEUE_18_RX_BITMAP_159_128_MASK 0xffffffff 1362 1363 /* Description RX_REO_QUEUE_19_RX_BITMAP_191_160 1364 1365 See Rx_bitmap_31_0 description 1366 1367 <legal all> 1368 */ 1369 #define RX_REO_QUEUE_19_RX_BITMAP_191_160_OFFSET 0x0000004c 1370 #define RX_REO_QUEUE_19_RX_BITMAP_191_160_LSB 0 1371 #define RX_REO_QUEUE_19_RX_BITMAP_191_160_MASK 0xffffffff 1372 1373 /* Description RX_REO_QUEUE_20_RX_BITMAP_223_192 1374 1375 See Rx_bitmap_31_0 description 1376 1377 <legal all> 1378 */ 1379 #define RX_REO_QUEUE_20_RX_BITMAP_223_192_OFFSET 0x00000050 1380 #define RX_REO_QUEUE_20_RX_BITMAP_223_192_LSB 0 1381 #define RX_REO_QUEUE_20_RX_BITMAP_223_192_MASK 0xffffffff 1382 1383 /* Description RX_REO_QUEUE_21_RX_BITMAP_255_224 1384 1385 See Rx_bitmap_31_0 description 1386 1387 <legal all> 1388 */ 1389 #define RX_REO_QUEUE_21_RX_BITMAP_255_224_OFFSET 0x00000054 1390 #define RX_REO_QUEUE_21_RX_BITMAP_255_224_LSB 0 1391 #define RX_REO_QUEUE_21_RX_BITMAP_255_224_MASK 0xffffffff 1392 1393 /* Description RX_REO_QUEUE_22_CURRENT_MPDU_COUNT 1394 1395 The number of MPDUs in the queue. 1396 1397 1398 1399 <legal all> 1400 */ 1401 #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_OFFSET 0x00000058 1402 #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_LSB 0 1403 #define RX_REO_QUEUE_22_CURRENT_MPDU_COUNT_MASK 0x0000007f 1404 1405 /* Description RX_REO_QUEUE_22_CURRENT_MSDU_COUNT 1406 1407 The number of MSDUs in the queue. 1408 1409 <legal all> 1410 */ 1411 #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_OFFSET 0x00000058 1412 #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_LSB 7 1413 #define RX_REO_QUEUE_22_CURRENT_MSDU_COUNT_MASK 0xffffff80 1414 1415 /* Description RX_REO_QUEUE_23_RESERVED_23 1416 1417 <legal 0> 1418 */ 1419 #define RX_REO_QUEUE_23_RESERVED_23_OFFSET 0x0000005c 1420 #define RX_REO_QUEUE_23_RESERVED_23_LSB 0 1421 #define RX_REO_QUEUE_23_RESERVED_23_MASK 0x0000000f 1422 1423 /* Description RX_REO_QUEUE_23_TIMEOUT_COUNT 1424 1425 The number of times that REO started forwarding frames 1426 even though there is a hole in the bitmap. Forwarding reason 1427 is Timeout 1428 1429 1430 1431 The counter saturates and freezes at 0x3F 1432 1433 1434 1435 <legal all> 1436 */ 1437 #define RX_REO_QUEUE_23_TIMEOUT_COUNT_OFFSET 0x0000005c 1438 #define RX_REO_QUEUE_23_TIMEOUT_COUNT_LSB 4 1439 #define RX_REO_QUEUE_23_TIMEOUT_COUNT_MASK 0x000003f0 1440 1441 /* Description RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT 1442 1443 The number of times that REO started forwarding frames 1444 even though there is a hole in the bitmap. Forwarding reason 1445 is reception of BAR frame. 1446 1447 1448 1449 The counter saturates and freezes at 0x3F 1450 1451 1452 1453 <legal all> 1454 */ 1455 #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_OFFSET 0x0000005c 1456 #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_LSB 10 1457 #define RX_REO_QUEUE_23_FORWARD_DUE_TO_BAR_COUNT_MASK 0x0000fc00 1458 1459 /* Description RX_REO_QUEUE_23_DUPLICATE_COUNT 1460 1461 The number of duplicate frames that have been detected 1462 1463 <legal all> 1464 */ 1465 #define RX_REO_QUEUE_23_DUPLICATE_COUNT_OFFSET 0x0000005c 1466 #define RX_REO_QUEUE_23_DUPLICATE_COUNT_LSB 16 1467 #define RX_REO_QUEUE_23_DUPLICATE_COUNT_MASK 0xffff0000 1468 1469 /* Description RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT 1470 1471 The number of frames that have been received in order 1472 (without a hole that prevented them from being forwarded 1473 immediately) 1474 1475 1476 1477 This corresponds to the Reorder opcodes: 1478 1479 'FWDCUR' and 'FWD BUF' 1480 1481 1482 1483 <legal all> 1484 */ 1485 #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_OFFSET 0x00000060 1486 #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_LSB 0 1487 #define RX_REO_QUEUE_24_FRAMES_IN_ORDER_COUNT_MASK 0x00ffffff 1488 1489 /* Description RX_REO_QUEUE_24_BAR_RECEIVED_COUNT 1490 1491 The number of times a BAR frame is received. 1492 1493 1494 1495 This corresponds to the Reorder opcodes with 'DROP' 1496 1497 1498 1499 The counter saturates and freezes at 0xFF 1500 1501 <legal all> 1502 */ 1503 #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_OFFSET 0x00000060 1504 #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_LSB 24 1505 #define RX_REO_QUEUE_24_BAR_RECEIVED_COUNT_MASK 0xff000000 1506 1507 /* Description RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT 1508 1509 The total number of MPDU frames that have been processed 1510 by REO. 'Processing' here means that REO has received them 1511 out of the entrance ring, and retrieved the corresponding 1512 RX_REO_QUEUE Descriptor. 1513 1514 1515 1516 Note that this count includes duplicates, frames that 1517 later had errors, etc. 1518 1519 1520 1521 Note that field 'Duplicate_count' indicates how many of 1522 these MPDUs were duplicates. 1523 1524 1525 1526 <legal all> 1527 */ 1528 #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_OFFSET 0x00000064 1529 #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_LSB 0 1530 #define RX_REO_QUEUE_25_MPDU_FRAMES_PROCESSED_COUNT_MASK 0xffffffff 1531 1532 /* Description RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT 1533 1534 The total number of MSDU frames that have been processed 1535 by REO. 'Processing' here means that REO has received them 1536 out of the entrance ring, and retrieved the corresponding 1537 RX_REO_QUEUE Descriptor. 1538 1539 1540 1541 Note that this count includes duplicates, frames that 1542 later had errors, etc. 1543 1544 1545 1546 <legal all> 1547 */ 1548 #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_OFFSET 0x00000068 1549 #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_LSB 0 1550 #define RX_REO_QUEUE_26_MSDU_FRAMES_PROCESSED_COUNT_MASK 0xffffffff 1551 1552 /* Description RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT 1553 1554 An approximation of the number of bytes processed for 1555 this queue. 1556 1557 'Processing' here means that REO has received them out 1558 of the entrance ring, and retrieved the corresponding 1559 RX_REO_QUEUE Descriptor. 1560 1561 1562 1563 Note that this count includes duplicates, frames that 1564 later had errors, etc. 1565 1566 1567 1568 In 64 byte units 1569 1570 <legal all> 1571 */ 1572 #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_OFFSET 0x0000006c 1573 #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_LSB 0 1574 #define RX_REO_QUEUE_27_TOTAL_PROCESSED_BYTE_COUNT_MASK 0xffffffff 1575 1576 /* Description RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT 1577 1578 The number of MPDUs received after the window had 1579 already moved on. The 'late' sequence window is defined as 1580 (Window SSN - 256) - (Window SSN - 1) 1581 1582 1583 1584 This corresponds with Out of order detection in 1585 duplicate detect FSM 1586 1587 1588 1589 The counter saturates and freezes at 0xFFF 1590 1591 1592 1593 <legal all> 1594 */ 1595 #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_OFFSET 0x00000070 1596 #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_LSB 0 1597 #define RX_REO_QUEUE_28_LATE_RECEIVE_MPDU_COUNT_MASK 0x00000fff 1598 1599 /* Description RX_REO_QUEUE_28_WINDOW_JUMP_2K 1600 1601 The number of times the window moved more then 2K 1602 1603 1604 1605 The counter saturates and freezes at 0xF 1606 1607 1608 1609 (Note: field name can not start with number: previous 1610 2k_window_jump) 1611 1612 1613 1614 <legal all> 1615 */ 1616 #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_OFFSET 0x00000070 1617 #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_LSB 12 1618 #define RX_REO_QUEUE_28_WINDOW_JUMP_2K_MASK 0x0000f000 1619 1620 /* Description RX_REO_QUEUE_28_HOLE_COUNT 1621 1622 The number of times a hole was created in the receive 1623 bitmap. 1624 1625 1626 1627 This corresponds to the Reorder opcodes with 'QCUR' 1628 1629 1630 1631 <legal all> 1632 */ 1633 #define RX_REO_QUEUE_28_HOLE_COUNT_OFFSET 0x00000070 1634 #define RX_REO_QUEUE_28_HOLE_COUNT_LSB 16 1635 #define RX_REO_QUEUE_28_HOLE_COUNT_MASK 0xffff0000 1636 1637 /* Description RX_REO_QUEUE_29_RESERVED_29 1638 1639 <legal 0> 1640 */ 1641 #define RX_REO_QUEUE_29_RESERVED_29_OFFSET 0x00000074 1642 #define RX_REO_QUEUE_29_RESERVED_29_LSB 0 1643 #define RX_REO_QUEUE_29_RESERVED_29_MASK 0xffffffff 1644 1645 /* Description RX_REO_QUEUE_30_RESERVED_30 1646 1647 <legal 0> 1648 */ 1649 #define RX_REO_QUEUE_30_RESERVED_30_OFFSET 0x00000078 1650 #define RX_REO_QUEUE_30_RESERVED_30_LSB 0 1651 #define RX_REO_QUEUE_30_RESERVED_30_MASK 0xffffffff 1652 1653 /* Description RX_REO_QUEUE_31_RESERVED_31 1654 1655 <legal 0> 1656 */ 1657 #define RX_REO_QUEUE_31_RESERVED_31_OFFSET 0x0000007c 1658 #define RX_REO_QUEUE_31_RESERVED_31_LSB 0 1659 #define RX_REO_QUEUE_31_RESERVED_31_MASK 0xffffffff 1660 1661 1662 #endif // _RX_REO_QUEUE_H_ 1663