1 /* 2 * Copyright (c) 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 #ifndef _HE_SIG_A_SU_INFO_H_ 20 #define _HE_SIG_A_SU_INFO_H_ 21 #if !defined(__ASSEMBLER__) 22 #endif 23 24 25 // ################ START SUMMARY ################# 26 // 27 // Dword Fields 28 // 0 format_indication[0], beam_change[1], dl_ul_flag[2], transmit_mcs[6:3], dcm[7], bss_color_id[13:8], reserved_0a[14], spatial_reuse[18:15], transmit_bw[20:19], cp_ltf_size[22:21], nsts[25:23], reserved_0b[31:26] 29 // 1 txop_duration[6:0], coding[7], ldpc_extra_symbol[8], stbc[9], txbf[10], packet_extension_a_factor[12:11], packet_extension_pe_disambiguity[13], reserved_1a[14], doppler_indication[15], crc[19:16], tail[25:20], dot11ax_su_extended[26], dot11ax_ext_ru_size[30:27], rx_ndp[31] 30 // 31 // ################ END SUMMARY ################# 32 33 #define NUM_OF_DWORDS_HE_SIG_A_SU_INFO 2 34 35 struct he_sig_a_su_info { 36 uint32_t format_indication : 1, //[0] 37 beam_change : 1, //[1] 38 dl_ul_flag : 1, //[2] 39 transmit_mcs : 4, //[6:3] 40 dcm : 1, //[7] 41 bss_color_id : 6, //[13:8] 42 reserved_0a : 1, //[14] 43 spatial_reuse : 4, //[18:15] 44 transmit_bw : 2, //[20:19] 45 cp_ltf_size : 2, //[22:21] 46 nsts : 3, //[25:23] 47 reserved_0b : 6; //[31:26] 48 uint32_t txop_duration : 7, //[6:0] 49 coding : 1, //[7] 50 ldpc_extra_symbol : 1, //[8] 51 stbc : 1, //[9] 52 txbf : 1, //[10] 53 packet_extension_a_factor : 2, //[12:11] 54 packet_extension_pe_disambiguity: 1, //[13] 55 reserved_1a : 1, //[14] 56 doppler_indication : 1, //[15] 57 crc : 4, //[19:16] 58 tail : 6, //[25:20] 59 dot11ax_su_extended : 1, //[26] 60 dot11ax_ext_ru_size : 4, //[30:27] 61 rx_ndp : 1; //[31] 62 }; 63 64 /* 65 66 format_indication 67 68 <enum 0 HE_SIGA_FORMAT_HE_TRIG> 69 70 <enum 1 HE_SIGA_FORMAT_SU_OR_EXT_SU> 71 72 <legal all> 73 74 beam_change 75 76 Indicates whether spatial mapping is changed between 77 legacy and HE portion of preamble. If not, channel 78 estimation can include legacy preamble to improve accuracy 79 80 <legal all> 81 82 dl_ul_flag 83 84 Differentiates between DL and UL transmission 85 86 87 88 <enum 0 DL_UL_FLAG_IS_DL_OR_TDLS> 89 90 <enum 1 DL_UL_FLAG_IS_UL> 91 92 <legal all> 93 94 transmit_mcs 95 96 Indicates the data MCS 97 98 99 100 Field Used by MAC HW 101 102 <legal all> 103 104 dcm 105 106 107 0: No DCM 108 109 1:DCM 110 111 <legal all> 112 113 bss_color_id 114 115 BSS color ID 116 117 118 119 Field Used by MAC HW 120 121 <legal all> 122 123 reserved_0a 124 125 Note: spec indicates this shall be set to 1 126 127 <legal 1> 128 129 spatial_reuse 130 131 Spatial reuse 132 133 134 135 For 20MHz one SR field corresponding to entire 20MHz 136 (other 3 fields indicate identical values) 137 138 For 40MHz two SR fields for each 20MHz (other 2 fields 139 indicate identical values) 140 141 For 80MHz four SR fields for each 20MHz 142 143 For 160MHz four SR fields for each 40MHz 144 145 <legal all> 146 147 transmit_bw 148 149 Bandwidth of the PPDU. 150 151 152 153 For HE SU PPDU 154 155 156 <enum 0 HE_SIG_A_BW20> 20 Mhz 157 158 <enum 1 HE_SIG_A_BW40> 40 Mhz 159 160 <enum 2 HE_SIG_A_BW80> 80 Mhz 161 162 <enum 3 HE_SIG_A_BW160> 160 MHz or 80+80 MHz 163 164 165 166 For HE Extended Range SU PPDU 167 168 Set to 0 for 242-tone RU 169 Set to 1 for right 106-tone RU within the primary 20 MHz 170 171 172 173 On RX side, Field Used by MAC HW 174 175 <legal all> 176 177 cp_ltf_size 178 179 Indicates the CP and HE-LTF type 180 181 182 183 <enum 0 OneX_LTF_0_8CP> 1xLTF + 0.8 us CP (See note for 184 proprietary mode) 185 186 <enum 1 TwoX_LTF_0_8CP> 2x LTF + 0.8 µs CP (See note 187 for proprietary mode) 188 189 <enum 2 TwoX_LTF_1_6CP> 2x LTF + 1.6 µs CP (See note 190 for proprietary mode) 191 192 193 194 <enum 3 FourX_LTF_0_8CP_3_2CP> 195 196 When DCM == 0 OR STBC == 0: 4x LTF + 3.2 µs CP 197 198 When DCM == 1 AND STBC == 1: 4x LTF + 0.8 µs CP. Note: 199 In this scenario, Neither DCM nor STBC is applied to HE data 200 field. 201 202 (See note for proprietary mode) 203 204 205 206 NOTE: 207 208 For QCA proprietary mode 209 210 If ( DCM == 1 ) and ( MCS > 0 ) and (STBC == 0) 211 212 0 = 1xLTF + 0.4 usec 213 214 1 = 2xLTF + 0.4 usec 215 216 2~3 = Reserved 217 218 219 220 <legal all> 221 222 nsts 223 224 225 226 227 For HE SU PPDU 228 229 230 231 For HE Extended Range PPDU 232 233 <legal all> 234 235 reserved_0b 236 237 <legal 0> 238 239 txop_duration 240 241 Indicates the remaining time in the current TXOP 242 243 244 245 Field Used by MAC HW 246 247 <legal all> 248 249 coding 250 251 Distinguishes between BCC and LDPC coding. 252 253 254 255 0: BCC 256 257 1: LDPC 258 259 <legal all> 260 261 ldpc_extra_symbol 262 263 If LDPC, 264 265 0: LDPC extra symbol not present 266 267 1: LDPC extra symbol present 268 269 Else 270 271 Set to 1 272 273 <legal all> 274 275 stbc 276 277 Indicates whether STBC is applied 278 279 0: No STBC 280 281 1: STBC 282 283 <legal all> 284 285 txbf 286 287 Indicates whether beamforming is applied 288 289 0: No beamforming 290 291 1: beamforming 292 293 <legal all> 294 295 packet_extension_a_factor 296 297 Common trigger info 298 299 300 301 the packet extension duration of the trigger-based PPDU 302 response with these two bits indicating the a-factor 303 304 305 306 <enum 0 a_factor_4> 307 308 <enum 1 a_factor_1> 309 310 <enum 2 a_factor_2> 311 312 <enum 3 a_factor_3> 313 314 315 316 <legal all> 317 318 packet_extension_pe_disambiguity 319 320 Common trigger info 321 322 323 324 the packet extension duration of the trigger-based PPDU 325 response with this bit indicating the PE-Disambiguity 326 327 <legal all> 328 329 reserved_1a 330 331 Note: per standard, set to 1 332 333 <legal 1> 334 335 doppler_indication 336 337 0: No Doppler support 338 339 1: Doppler support 340 341 <legal all> 342 343 crc 344 345 CRC for HE-SIG-A contents. 346 347 <legal all> 348 349 tail 350 351 <legal 0> 352 353 dot11ax_su_extended 354 355 TX side: 356 357 Set to 0 358 359 360 361 RX side: 362 363 On RX side, evaluated by MAC HW. This is the only way 364 for MAC RX to know that this was an HE_SIG_A_SU received in 365 'extended' format 366 367 368 369 370 <legal all> 371 372 dot11ax_ext_ru_size 373 374 TX side: 375 376 Set to 0 377 378 379 380 RX side: 381 382 Field only contains valid info when dot11ax_su_extended 383 is set. 384 385 386 387 On RX side, evaluated by MAC HW. This is the only way 388 for MAC RX to know what the number of based RUs was in this 389 extended range reception. It is used by the MAC to determine 390 the RU size for the response... 391 392 <legal all> 393 394 rx_ndp 395 396 TX side: 397 398 Set to 0 399 400 401 402 RX side:Valid on RX side only, and looked at by MAC HW 403 404 405 406 When set, PHY has received (expected) NDP frame 407 408 <legal all> 409 */ 410 411 412 /* Description HE_SIG_A_SU_INFO_0_FORMAT_INDICATION 413 414 <enum 0 HE_SIGA_FORMAT_HE_TRIG> 415 416 <enum 1 HE_SIGA_FORMAT_SU_OR_EXT_SU> 417 418 <legal all> 419 */ 420 #define HE_SIG_A_SU_INFO_0_FORMAT_INDICATION_OFFSET 0x00000000 421 #define HE_SIG_A_SU_INFO_0_FORMAT_INDICATION_LSB 0 422 #define HE_SIG_A_SU_INFO_0_FORMAT_INDICATION_MASK 0x00000001 423 424 /* Description HE_SIG_A_SU_INFO_0_BEAM_CHANGE 425 426 Indicates whether spatial mapping is changed between 427 legacy and HE portion of preamble. If not, channel 428 estimation can include legacy preamble to improve accuracy 429 430 <legal all> 431 */ 432 #define HE_SIG_A_SU_INFO_0_BEAM_CHANGE_OFFSET 0x00000000 433 #define HE_SIG_A_SU_INFO_0_BEAM_CHANGE_LSB 1 434 #define HE_SIG_A_SU_INFO_0_BEAM_CHANGE_MASK 0x00000002 435 436 /* Description HE_SIG_A_SU_INFO_0_DL_UL_FLAG 437 438 Differentiates between DL and UL transmission 439 440 441 442 <enum 0 DL_UL_FLAG_IS_DL_OR_TDLS> 443 444 <enum 1 DL_UL_FLAG_IS_UL> 445 446 <legal all> 447 */ 448 #define HE_SIG_A_SU_INFO_0_DL_UL_FLAG_OFFSET 0x00000000 449 #define HE_SIG_A_SU_INFO_0_DL_UL_FLAG_LSB 2 450 #define HE_SIG_A_SU_INFO_0_DL_UL_FLAG_MASK 0x00000004 451 452 /* Description HE_SIG_A_SU_INFO_0_TRANSMIT_MCS 453 454 Indicates the data MCS 455 456 457 458 Field Used by MAC HW 459 460 <legal all> 461 */ 462 #define HE_SIG_A_SU_INFO_0_TRANSMIT_MCS_OFFSET 0x00000000 463 #define HE_SIG_A_SU_INFO_0_TRANSMIT_MCS_LSB 3 464 #define HE_SIG_A_SU_INFO_0_TRANSMIT_MCS_MASK 0x00000078 465 466 /* Description HE_SIG_A_SU_INFO_0_DCM 467 468 469 0: No DCM 470 471 1:DCM 472 473 <legal all> 474 */ 475 #define HE_SIG_A_SU_INFO_0_DCM_OFFSET 0x00000000 476 #define HE_SIG_A_SU_INFO_0_DCM_LSB 7 477 #define HE_SIG_A_SU_INFO_0_DCM_MASK 0x00000080 478 479 /* Description HE_SIG_A_SU_INFO_0_BSS_COLOR_ID 480 481 BSS color ID 482 483 484 485 Field Used by MAC HW 486 487 <legal all> 488 */ 489 #define HE_SIG_A_SU_INFO_0_BSS_COLOR_ID_OFFSET 0x00000000 490 #define HE_SIG_A_SU_INFO_0_BSS_COLOR_ID_LSB 8 491 #define HE_SIG_A_SU_INFO_0_BSS_COLOR_ID_MASK 0x00003f00 492 493 /* Description HE_SIG_A_SU_INFO_0_RESERVED_0A 494 495 Note: spec indicates this shall be set to 1 496 497 <legal 1> 498 */ 499 #define HE_SIG_A_SU_INFO_0_RESERVED_0A_OFFSET 0x00000000 500 #define HE_SIG_A_SU_INFO_0_RESERVED_0A_LSB 14 501 #define HE_SIG_A_SU_INFO_0_RESERVED_0A_MASK 0x00004000 502 503 /* Description HE_SIG_A_SU_INFO_0_SPATIAL_REUSE 504 505 Spatial reuse 506 507 508 509 For 20MHz one SR field corresponding to entire 20MHz 510 (other 3 fields indicate identical values) 511 512 For 40MHz two SR fields for each 20MHz (other 2 fields 513 indicate identical values) 514 515 For 80MHz four SR fields for each 20MHz 516 517 For 160MHz four SR fields for each 40MHz 518 519 <legal all> 520 */ 521 #define HE_SIG_A_SU_INFO_0_SPATIAL_REUSE_OFFSET 0x00000000 522 #define HE_SIG_A_SU_INFO_0_SPATIAL_REUSE_LSB 15 523 #define HE_SIG_A_SU_INFO_0_SPATIAL_REUSE_MASK 0x00078000 524 525 /* Description HE_SIG_A_SU_INFO_0_TRANSMIT_BW 526 527 Bandwidth of the PPDU. 528 529 530 531 For HE SU PPDU 532 533 534 <enum 0 HE_SIG_A_BW20> 20 Mhz 535 536 <enum 1 HE_SIG_A_BW40> 40 Mhz 537 538 <enum 2 HE_SIG_A_BW80> 80 Mhz 539 540 <enum 3 HE_SIG_A_BW160> 160 MHz or 80+80 MHz 541 542 543 544 For HE Extended Range SU PPDU 545 546 Set to 0 for 242-tone RU 547 Set to 1 for right 106-tone RU within the primary 20 MHz 548 549 550 551 On RX side, Field Used by MAC HW 552 553 <legal all> 554 */ 555 #define HE_SIG_A_SU_INFO_0_TRANSMIT_BW_OFFSET 0x00000000 556 #define HE_SIG_A_SU_INFO_0_TRANSMIT_BW_LSB 19 557 #define HE_SIG_A_SU_INFO_0_TRANSMIT_BW_MASK 0x00180000 558 559 /* Description HE_SIG_A_SU_INFO_0_CP_LTF_SIZE 560 561 Indicates the CP and HE-LTF type 562 563 564 565 <enum 0 OneX_LTF_0_8CP> 1xLTF + 0.8 us CP (See note for 566 proprietary mode) 567 568 <enum 1 TwoX_LTF_0_8CP> 2x LTF + 0.8 µs CP (See note 569 for proprietary mode) 570 571 <enum 2 TwoX_LTF_1_6CP> 2x LTF + 1.6 µs CP (See note 572 for proprietary mode) 573 574 575 576 <enum 3 FourX_LTF_0_8CP_3_2CP> 577 578 When DCM == 0 OR STBC == 0: 4x LTF + 3.2 µs CP 579 580 When DCM == 1 AND STBC == 1: 4x LTF + 0.8 µs CP. Note: 581 In this scenario, Neither DCM nor STBC is applied to HE data 582 field. 583 584 (See note for proprietary mode) 585 586 587 588 NOTE: 589 590 For QCA proprietary mode 591 592 If ( DCM == 1 ) and ( MCS > 0 ) and (STBC == 0) 593 594 0 = 1xLTF + 0.4 usec 595 596 1 = 2xLTF + 0.4 usec 597 598 2~3 = Reserved 599 600 601 602 <legal all> 603 */ 604 #define HE_SIG_A_SU_INFO_0_CP_LTF_SIZE_OFFSET 0x00000000 605 #define HE_SIG_A_SU_INFO_0_CP_LTF_SIZE_LSB 21 606 #define HE_SIG_A_SU_INFO_0_CP_LTF_SIZE_MASK 0x00600000 607 608 /* Description HE_SIG_A_SU_INFO_0_NSTS 609 610 611 612 613 For HE SU PPDU 614 615 616 617 For HE Extended Range PPDU 618 619 <legal all> 620 */ 621 #define HE_SIG_A_SU_INFO_0_NSTS_OFFSET 0x00000000 622 #define HE_SIG_A_SU_INFO_0_NSTS_LSB 23 623 #define HE_SIG_A_SU_INFO_0_NSTS_MASK 0x03800000 624 625 /* Description HE_SIG_A_SU_INFO_0_RESERVED_0B 626 627 <legal 0> 628 */ 629 #define HE_SIG_A_SU_INFO_0_RESERVED_0B_OFFSET 0x00000000 630 #define HE_SIG_A_SU_INFO_0_RESERVED_0B_LSB 26 631 #define HE_SIG_A_SU_INFO_0_RESERVED_0B_MASK 0xfc000000 632 633 /* Description HE_SIG_A_SU_INFO_1_TXOP_DURATION 634 635 Indicates the remaining time in the current TXOP 636 637 638 639 Field Used by MAC HW 640 641 <legal all> 642 */ 643 #define HE_SIG_A_SU_INFO_1_TXOP_DURATION_OFFSET 0x00000004 644 #define HE_SIG_A_SU_INFO_1_TXOP_DURATION_LSB 0 645 #define HE_SIG_A_SU_INFO_1_TXOP_DURATION_MASK 0x0000007f 646 647 /* Description HE_SIG_A_SU_INFO_1_CODING 648 649 Distinguishes between BCC and LDPC coding. 650 651 652 653 0: BCC 654 655 1: LDPC 656 657 <legal all> 658 */ 659 #define HE_SIG_A_SU_INFO_1_CODING_OFFSET 0x00000004 660 #define HE_SIG_A_SU_INFO_1_CODING_LSB 7 661 #define HE_SIG_A_SU_INFO_1_CODING_MASK 0x00000080 662 663 /* Description HE_SIG_A_SU_INFO_1_LDPC_EXTRA_SYMBOL 664 665 If LDPC, 666 667 0: LDPC extra symbol not present 668 669 1: LDPC extra symbol present 670 671 Else 672 673 Set to 1 674 675 <legal all> 676 */ 677 #define HE_SIG_A_SU_INFO_1_LDPC_EXTRA_SYMBOL_OFFSET 0x00000004 678 #define HE_SIG_A_SU_INFO_1_LDPC_EXTRA_SYMBOL_LSB 8 679 #define HE_SIG_A_SU_INFO_1_LDPC_EXTRA_SYMBOL_MASK 0x00000100 680 681 /* Description HE_SIG_A_SU_INFO_1_STBC 682 683 Indicates whether STBC is applied 684 685 0: No STBC 686 687 1: STBC 688 689 <legal all> 690 */ 691 #define HE_SIG_A_SU_INFO_1_STBC_OFFSET 0x00000004 692 #define HE_SIG_A_SU_INFO_1_STBC_LSB 9 693 #define HE_SIG_A_SU_INFO_1_STBC_MASK 0x00000200 694 695 /* Description HE_SIG_A_SU_INFO_1_TXBF 696 697 Indicates whether beamforming is applied 698 699 0: No beamforming 700 701 1: beamforming 702 703 <legal all> 704 */ 705 #define HE_SIG_A_SU_INFO_1_TXBF_OFFSET 0x00000004 706 #define HE_SIG_A_SU_INFO_1_TXBF_LSB 10 707 #define HE_SIG_A_SU_INFO_1_TXBF_MASK 0x00000400 708 709 /* Description HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_A_FACTOR 710 711 Common trigger info 712 713 714 715 the packet extension duration of the trigger-based PPDU 716 response with these two bits indicating the a-factor 717 718 719 720 <enum 0 a_factor_4> 721 722 <enum 1 a_factor_1> 723 724 <enum 2 a_factor_2> 725 726 <enum 3 a_factor_3> 727 728 729 730 <legal all> 731 */ 732 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_A_FACTOR_OFFSET 0x00000004 733 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_A_FACTOR_LSB 11 734 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_A_FACTOR_MASK 0x00001800 735 736 /* Description HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_PE_DISAMBIGUITY 737 738 Common trigger info 739 740 741 742 the packet extension duration of the trigger-based PPDU 743 response with this bit indicating the PE-Disambiguity 744 745 <legal all> 746 */ 747 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_PE_DISAMBIGUITY_OFFSET 0x00000004 748 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_PE_DISAMBIGUITY_LSB 13 749 #define HE_SIG_A_SU_INFO_1_PACKET_EXTENSION_PE_DISAMBIGUITY_MASK 0x00002000 750 751 /* Description HE_SIG_A_SU_INFO_1_RESERVED_1A 752 753 Note: per standard, set to 1 754 755 <legal 1> 756 */ 757 #define HE_SIG_A_SU_INFO_1_RESERVED_1A_OFFSET 0x00000004 758 #define HE_SIG_A_SU_INFO_1_RESERVED_1A_LSB 14 759 #define HE_SIG_A_SU_INFO_1_RESERVED_1A_MASK 0x00004000 760 761 /* Description HE_SIG_A_SU_INFO_1_DOPPLER_INDICATION 762 763 0: No Doppler support 764 765 1: Doppler support 766 767 <legal all> 768 */ 769 #define HE_SIG_A_SU_INFO_1_DOPPLER_INDICATION_OFFSET 0x00000004 770 #define HE_SIG_A_SU_INFO_1_DOPPLER_INDICATION_LSB 15 771 #define HE_SIG_A_SU_INFO_1_DOPPLER_INDICATION_MASK 0x00008000 772 773 /* Description HE_SIG_A_SU_INFO_1_CRC 774 775 CRC for HE-SIG-A contents. 776 777 <legal all> 778 */ 779 #define HE_SIG_A_SU_INFO_1_CRC_OFFSET 0x00000004 780 #define HE_SIG_A_SU_INFO_1_CRC_LSB 16 781 #define HE_SIG_A_SU_INFO_1_CRC_MASK 0x000f0000 782 783 /* Description HE_SIG_A_SU_INFO_1_TAIL 784 785 <legal 0> 786 */ 787 #define HE_SIG_A_SU_INFO_1_TAIL_OFFSET 0x00000004 788 #define HE_SIG_A_SU_INFO_1_TAIL_LSB 20 789 #define HE_SIG_A_SU_INFO_1_TAIL_MASK 0x03f00000 790 791 /* Description HE_SIG_A_SU_INFO_1_DOT11AX_SU_EXTENDED 792 793 TX side: 794 795 Set to 0 796 797 798 799 RX side: 800 801 On RX side, evaluated by MAC HW. This is the only way 802 for MAC RX to know that this was an HE_SIG_A_SU received in 803 'extended' format 804 805 806 807 808 <legal all> 809 */ 810 #define HE_SIG_A_SU_INFO_1_DOT11AX_SU_EXTENDED_OFFSET 0x00000004 811 #define HE_SIG_A_SU_INFO_1_DOT11AX_SU_EXTENDED_LSB 26 812 #define HE_SIG_A_SU_INFO_1_DOT11AX_SU_EXTENDED_MASK 0x04000000 813 814 /* Description HE_SIG_A_SU_INFO_1_DOT11AX_EXT_RU_SIZE 815 816 TX side: 817 818 Set to 0 819 820 821 822 RX side: 823 824 Field only contains valid info when dot11ax_su_extended 825 is set. 826 827 828 829 On RX side, evaluated by MAC HW. This is the only way 830 for MAC RX to know what the number of based RUs was in this 831 extended range reception. It is used by the MAC to determine 832 the RU size for the response... 833 834 <legal all> 835 */ 836 #define HE_SIG_A_SU_INFO_1_DOT11AX_EXT_RU_SIZE_OFFSET 0x00000004 837 #define HE_SIG_A_SU_INFO_1_DOT11AX_EXT_RU_SIZE_LSB 27 838 #define HE_SIG_A_SU_INFO_1_DOT11AX_EXT_RU_SIZE_MASK 0x78000000 839 840 /* Description HE_SIG_A_SU_INFO_1_RX_NDP 841 842 TX side: 843 844 Set to 0 845 846 847 848 RX side:Valid on RX side only, and looked at by MAC HW 849 850 851 852 When set, PHY has received (expected) NDP frame 853 854 <legal all> 855 */ 856 #define HE_SIG_A_SU_INFO_1_RX_NDP_OFFSET 0x00000004 857 #define HE_SIG_A_SU_INFO_1_RX_NDP_LSB 31 858 #define HE_SIG_A_SU_INFO_1_RX_NDP_MASK 0x80000000 859 860 861 #endif // _HE_SIG_A_SU_INFO_H_ 862