1 /* 2 * Copyright (c) 2020 The Linux Foundation. All rights reserved. 3 * 4 * Permission to use, copy, modify, and/or distribute this software for any 5 * purpose with or without fee is hereby granted, provided that the above 6 * copyright notice and this permission notice appear in all copies. 7 * 8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 15 */ 16 17 // $ATH_LICENSE_HW_HDR_C$ 18 // 19 // DO NOT EDIT! This file is automatically generated 20 // These definitions are tied to a particular hardware layout 21 22 23 #ifndef _RX_MPDU_START_H_ 24 #define _RX_MPDU_START_H_ 25 #if !defined(__ASSEMBLER__) 26 #endif 27 28 #include "rx_mpdu_info.h" 29 30 // ################ START SUMMARY ################# 31 // 32 // Dword Fields 33 // 0-22 struct rx_mpdu_info rx_mpdu_info_details; 34 // 23 raw_mpdu[0], reserved_23[31:1] 35 // 36 // ################ END SUMMARY ################# 37 38 #define NUM_OF_DWORDS_RX_MPDU_START 24 39 40 struct rx_mpdu_start { 41 struct rx_mpdu_info rx_mpdu_info_details; 42 uint32_t raw_mpdu : 1, //[0] 43 reserved_23 : 31; //[31:1] 44 }; 45 46 /* 47 48 struct rx_mpdu_info rx_mpdu_info_details 49 50 Structure containing all the MPDU header details that 51 might be needed for other modules further down the received 52 path 53 54 raw_mpdu 55 56 Set by OLE when it has not performed any .11 to .3 57 header conversion on this MPDU. 58 59 <legal all> 60 61 reserved_23 62 63 <legal 0> 64 */ 65 66 67 /* EXTERNAL REFERENCE : struct rx_mpdu_info rx_mpdu_info_details */ 68 69 70 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY 71 72 Field indicates what the reason was that this MPDU frame 73 was allowed to come into the receive path by RXPCU 74 75 <enum 0 rxpcu_filter_pass> This MPDU passed the normal 76 frame filter programming of rxpcu 77 78 <enum 1 rxpcu_monitor_client> This MPDU did NOT pass the 79 regular frame filter and would have been dropped, were it 80 not for the frame fitting into the 'monitor_client' 81 category. 82 83 <enum 2 rxpcu_monitor_other> This MPDU did NOT pass the 84 regular frame filter and also did not pass the 85 rxpcu_monitor_client filter. It would have been dropped 86 accept that it did pass the 'monitor_other' category. 87 88 89 90 Note: for ndp frame, if it was expected because the 91 preceding NDPA was filter_pass, the setting 92 rxpcu_filter_pass will be used. This setting will also be 93 used for every ndp frame in case Promiscuous mode is 94 enabled. 95 96 97 98 In case promiscuous is not enabled, and an NDP is not 99 preceded by a NPDA filter pass frame, the only other setting 100 that could appear here for the NDP is rxpcu_monitor_other. 101 102 (rxpcu has a configuration bit specifically for this 103 scenario) 104 105 106 107 Note: for 108 109 <legal 0-2> 110 */ 111 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_OFFSET 0x00000000 112 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_LSB 0 113 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RXPCU_MPDU_FILTER_IN_CATEGORY_MASK 0x00000003 114 115 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID 116 117 SW processes frames based on certain classifications. 118 This field indicates to what sw classification this MPDU is 119 mapped. 120 121 The classification is given in priority order 122 123 124 125 <enum 0 sw_frame_group_NDP_frame> Note: The 126 corresponding Rxpcu_Mpdu_filter_in_category can be 127 rxpcu_filter_pass or rxpcu_monitor_other 128 129 130 131 <enum 1 sw_frame_group_Multicast_data> 132 133 <enum 2 sw_frame_group_Unicast_data> 134 135 <enum 3 sw_frame_group_Null_data > This includes mpdus 136 of type Data Null as well as QoS Data Null 137 138 139 140 <enum 4 sw_frame_group_mgmt_0000 > 141 142 <enum 5 sw_frame_group_mgmt_0001 > 143 144 <enum 6 sw_frame_group_mgmt_0010 > 145 146 <enum 7 sw_frame_group_mgmt_0011 > 147 148 <enum 8 sw_frame_group_mgmt_0100 > 149 150 <enum 9 sw_frame_group_mgmt_0101 > 151 152 <enum 10 sw_frame_group_mgmt_0110 > 153 154 <enum 11 sw_frame_group_mgmt_0111 > 155 156 <enum 12 sw_frame_group_mgmt_1000 > 157 158 <enum 13 sw_frame_group_mgmt_1001 > 159 160 <enum 14 sw_frame_group_mgmt_1010 > 161 162 <enum 15 sw_frame_group_mgmt_1011 > 163 164 <enum 16 sw_frame_group_mgmt_1100 > 165 166 <enum 17 sw_frame_group_mgmt_1101 > 167 168 <enum 18 sw_frame_group_mgmt_1110 > 169 170 <enum 19 sw_frame_group_mgmt_1111 > 171 172 173 174 <enum 20 sw_frame_group_ctrl_0000 > 175 176 <enum 21 sw_frame_group_ctrl_0001 > 177 178 <enum 22 sw_frame_group_ctrl_0010 > 179 180 <enum 23 sw_frame_group_ctrl_0011 > 181 182 <enum 24 sw_frame_group_ctrl_0100 > 183 184 <enum 25 sw_frame_group_ctrl_0101 > 185 186 <enum 26 sw_frame_group_ctrl_0110 > 187 188 <enum 27 sw_frame_group_ctrl_0111 > 189 190 <enum 28 sw_frame_group_ctrl_1000 > 191 192 <enum 29 sw_frame_group_ctrl_1001 > 193 194 <enum 30 sw_frame_group_ctrl_1010 > 195 196 <enum 31 sw_frame_group_ctrl_1011 > 197 198 <enum 32 sw_frame_group_ctrl_1100 > 199 200 <enum 33 sw_frame_group_ctrl_1101 > 201 202 <enum 34 sw_frame_group_ctrl_1110 > 203 204 <enum 35 sw_frame_group_ctrl_1111 > 205 206 207 208 <enum 36 sw_frame_group_unsupported> This covers type 3 209 and protocol version != 0 210 211 Note: The corresponding Rxpcu_Mpdu_filter_in_category 212 can only be rxpcu_monitor_other 213 214 215 216 217 Note: The corresponding Rxpcu_Mpdu_filter_in_category 218 can be rxpcu_filter_pass 219 220 221 222 <legal 0-37> 223 */ 224 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_OFFSET 0x00000000 225 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_LSB 2 226 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_SW_FRAME_GROUP_ID_MASK 0x000001fc 227 228 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_NDP_FRAME 229 230 When set, the received frame was an NDP frame, and thus 231 there will be no MPDU data. 232 233 <legal all> 234 */ 235 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_NDP_FRAME_OFFSET 0x00000000 236 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_NDP_FRAME_LSB 9 237 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_NDP_FRAME_MASK 0x00000200 238 239 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR 240 241 When set, a PHY error was received before MAC received 242 any data, and thus there will be no MPDU data. 243 244 <legal all> 245 */ 246 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_OFFSET 0x00000000 247 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_LSB 10 248 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_MASK 0x00000400 249 250 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER 251 252 When set, a PHY error was received before MAC received 253 the complete MPDU header which was needed for proper 254 decoding 255 256 <legal all> 257 */ 258 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_OFFSET 0x00000000 259 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_LSB 11 260 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_ERR_DURING_MPDU_HEADER_MASK 0x00000800 261 262 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR 263 264 Set when RXPCU detected a version error in the Frame 265 control field 266 267 <legal all> 268 */ 269 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_OFFSET 0x00000000 270 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_LSB 12 271 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PROTOCOL_VERSION_ERR_MASK 0x00001000 272 273 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID 274 275 When set, AST based lookup for this frame has found a 276 valid result. 277 278 279 280 Note that for NDP frame this will never be set 281 282 <legal all> 283 */ 284 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_OFFSET 0x00000000 285 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_LSB 13 286 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_AST_BASED_LOOKUP_VALID_MASK 0x00002000 287 288 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RESERVED_0A 289 290 <legal 0> 291 */ 292 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RESERVED_0A_OFFSET 0x00000000 293 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RESERVED_0A_LSB 14 294 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_RESERVED_0A_MASK 0x0000c000 295 296 /* Description RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID 297 298 A ppdu counter value that PHY increments for every PPDU 299 received. The counter value wraps around 300 301 <legal all> 302 */ 303 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_OFFSET 0x00000000 304 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_LSB 16 305 #define RX_MPDU_START_0_RX_MPDU_INFO_DETAILS_PHY_PPDU_ID_MASK 0xffff0000 306 307 /* Description RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_AST_INDEX 308 309 This field indicates the index of the AST entry 310 corresponding to this MPDU. It is provided by the GSE module 311 instantiated in RXPCU. 312 313 A value of 0xFFFF indicates an invalid AST index, 314 meaning that No AST entry was found or NO AST search was 315 performed 316 317 318 319 In case of ndp or phy_err, this field will be set to 320 0xFFFF 321 322 <legal all> 323 */ 324 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_AST_INDEX_OFFSET 0x00000004 325 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_AST_INDEX_LSB 0 326 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_AST_INDEX_MASK 0x0000ffff 327 328 /* Description RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_SW_PEER_ID 329 330 In case of ndp or phy_err or AST_based_lookup_valid == 331 0, this field will be set to 0 332 333 334 335 This field indicates a unique peer identifier. It is set 336 equal to field 'sw_peer_id' from the AST entry 337 338 339 340 <legal all> 341 */ 342 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_SW_PEER_ID_OFFSET 0x00000004 343 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_SW_PEER_ID_LSB 16 344 #define RX_MPDU_START_1_RX_MPDU_INFO_DETAILS_SW_PEER_ID_MASK 0xffff0000 345 346 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID 347 348 When set, the field Mpdu_Frame_control_field has valid 349 information 350 351 352 353 354 <legal all> 355 */ 356 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_OFFSET 0x00000008 357 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_LSB 0 358 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_VALID_MASK 0x00000001 359 360 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID 361 362 When set, the field Mpdu_duration_field has valid 363 information 364 365 366 367 368 <legal all> 369 */ 370 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_OFFSET 0x00000008 371 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_LSB 1 372 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_DURATION_VALID_MASK 0x00000002 373 374 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID 375 376 When set, the fields mac_addr_ad1_..... have valid 377 information 378 379 380 381 382 <legal all> 383 */ 384 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_OFFSET 0x00000008 385 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_LSB 2 386 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_VALID_MASK 0x00000004 387 388 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID 389 390 When set, the fields mac_addr_ad2_..... have valid 391 information 392 393 394 395 396 397 398 399 <legal all> 400 */ 401 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_OFFSET 0x00000008 402 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_LSB 3 403 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_VALID_MASK 0x00000008 404 405 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID 406 407 When set, the fields mac_addr_ad3_..... have valid 408 information 409 410 411 412 413 414 415 416 <legal all> 417 */ 418 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_OFFSET 0x00000008 419 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_LSB 4 420 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_VALID_MASK 0x00000010 421 422 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID 423 424 When set, the fields mac_addr_ad4_..... have valid 425 information 426 427 428 429 430 431 432 433 <legal all> 434 */ 435 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_OFFSET 0x00000008 436 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_LSB 5 437 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_VALID_MASK 0x00000020 438 439 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID 440 441 When set, the fields mpdu_sequence_control_field and 442 mpdu_sequence_number have valid information as well as field 443 444 445 446 For MPDUs without a sequence control field, this field 447 will not be set. 448 449 450 451 452 <legal all> 453 */ 454 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_OFFSET 0x00000008 455 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_LSB 6 456 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_VALID_MASK 0x00000040 457 458 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID 459 460 When set, the field mpdu_qos_control_field has valid 461 information 462 463 464 465 For MPDUs without a QoS control field, this field will 466 not be set. 467 468 469 470 471 <legal all> 472 */ 473 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_OFFSET 0x00000008 474 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_LSB 7 475 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_VALID_MASK 0x00000080 476 477 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID 478 479 When set, the field mpdu_HT_control_field has valid 480 information 481 482 483 484 For MPDUs without a HT control field, this field will 485 not be set. 486 487 488 489 490 <legal all> 491 */ 492 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_OFFSET 0x00000008 493 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_LSB 8 494 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_VALID_MASK 0x00000100 495 496 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID 497 498 When set, the encryption related info fields, like IV 499 and PN are valid 500 501 502 503 For MPDUs that are not encrypted, this will not be set. 504 505 506 507 508 <legal all> 509 */ 510 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_OFFSET 0x00000008 511 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_LSB 9 512 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FRAME_ENCRYPTION_INFO_VALID_MASK 0x00000200 513 514 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER 515 516 Field only valid when Mpdu_sequence_control_valid is set 517 AND Fragment_flag is set 518 519 520 521 The fragment number from the 802.11 header. 522 523 <legal all> 524 */ 525 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_OFFSET 0x00000008 526 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_LSB 10 527 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_FRAGMENT_NUMBER_MASK 0x00003c00 528 529 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG 530 531 The More Fragment bit setting from the MPDU header of 532 the received frame 533 534 535 536 <legal all> 537 */ 538 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_OFFSET 0x00000008 539 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_LSB 14 540 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MORE_FRAGMENT_FLAG_MASK 0x00004000 541 542 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A 543 544 <legal 0> 545 */ 546 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_OFFSET 0x00000008 547 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_LSB 15 548 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_RESERVED_2A_MASK 0x00008000 549 550 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FR_DS 551 552 Field only valid when Mpdu_frame_control_valid is set 553 554 555 556 Set if the from DS bit is set in the frame control. 557 558 <legal all> 559 */ 560 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FR_DS_OFFSET 0x00000008 561 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FR_DS_LSB 16 562 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_FR_DS_MASK 0x00010000 563 564 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_TO_DS 565 566 Field only valid when Mpdu_frame_control_valid is set 567 568 569 570 Set if the to DS bit is set in the frame control. 571 572 <legal all> 573 */ 574 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_TO_DS_OFFSET 0x00000008 575 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_TO_DS_LSB 17 576 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_TO_DS_MASK 0x00020000 577 578 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_ENCRYPTED 579 580 Field only valid when Mpdu_frame_control_valid is set. 581 582 583 584 Protected bit from the frame control. 585 586 <legal all> 587 */ 588 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_ENCRYPTED_OFFSET 0x00000008 589 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_ENCRYPTED_LSB 18 590 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_ENCRYPTED_MASK 0x00040000 591 592 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_RETRY 593 594 Field only valid when Mpdu_frame_control_valid is set. 595 596 597 598 Retry bit from the frame control. Only valid when 599 first_msdu is set. 600 601 <legal all> 602 */ 603 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_RETRY_OFFSET 0x00000008 604 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_RETRY_LSB 19 605 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_RETRY_MASK 0x00080000 606 607 /* Description RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER 608 609 Field only valid when Mpdu_sequence_control_valid is 610 set. 611 612 613 614 The sequence number from the 802.11 header. 615 616 <legal all> 617 */ 618 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_OFFSET 0x00000008 619 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_LSB 20 620 #define RX_MPDU_START_2_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_NUMBER_MASK 0xfff00000 621 622 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_EPD_EN 623 624 Field only valid when AST_based_lookup_valid == 1. 625 626 627 628 629 630 In case of ndp or phy_err or AST_based_lookup_valid == 631 0, this field will be set to 0 632 633 634 635 If set to one use EPD instead of LPD 636 637 638 639 640 <legal all> 641 */ 642 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_EPD_EN_OFFSET 0x0000000c 643 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_EPD_EN_LSB 0 644 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_EPD_EN_MASK 0x00000001 645 646 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED 647 648 In case of ndp or phy_err or AST_based_lookup_valid == 649 0, this field will be set to 0 650 651 652 653 When set, all frames (data only ?) shall be encrypted. 654 If not, RX CRYPTO shall set an error flag. 655 656 <legal all> 657 */ 658 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_OFFSET 0x0000000c 659 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_LSB 1 660 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ALL_FRAMES_SHALL_BE_ENCRYPTED_MASK 0x00000002 661 662 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE 663 664 In case of ndp or phy_err or AST_based_lookup_valid == 665 0, this field will be set to 0 666 667 668 669 Indicates type of decrypt cipher used (as defined in the 670 peer entry) 671 672 673 674 <enum 0 wep_40> WEP 40-bit 675 676 <enum 1 wep_104> WEP 104-bit 677 678 <enum 2 tkip_no_mic> TKIP without MIC 679 680 <enum 3 wep_128> WEP 128-bit 681 682 <enum 4 tkip_with_mic> TKIP with MIC 683 684 <enum 5 wapi> WAPI 685 686 <enum 6 aes_ccmp_128> AES CCMP 128 687 688 <enum 7 no_cipher> No crypto 689 690 <enum 8 aes_ccmp_256> AES CCMP 256 691 692 <enum 9 aes_gcmp_128> AES CCMP 128 693 694 <enum 10 aes_gcmp_256> AES CCMP 256 695 696 <enum 11 wapi_gcm_sm4> WAPI GCM SM4 697 698 699 700 <enum 12 wep_varied_width> WEP encryption. As for WEP 701 per keyid the key bit width can vary, the key bit width for 702 this MPDU will be indicated in field 703 wep_key_width_for_variable key 704 705 <legal 0-12> 706 */ 707 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_OFFSET 0x0000000c 708 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_LSB 2 709 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_ENCRYPT_TYPE_MASK 0x0000003c 710 711 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY 712 713 Field only valid when key_type is set to 714 wep_varied_width. 715 716 717 718 This field indicates the size of the wep key for this 719 MPDU. 720 721 722 723 <enum 0 wep_varied_width_40> WEP 40-bit 724 725 <enum 1 wep_varied_width_104> WEP 104-bit 726 727 <enum 2 wep_varied_width_128> WEP 128-bit 728 729 730 731 <legal 0-2> 732 */ 733 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_OFFSET 0x0000000c 734 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_LSB 6 735 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_WEP_KEY_WIDTH_FOR_VARIABLE_KEY_MASK 0x000000c0 736 737 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_MESH_STA 738 739 In case of ndp or phy_err or AST_based_lookup_valid == 740 0, this field will be set to 0 741 742 743 744 When set, this is a Mesh (11s) STA 745 746 <legal all> 747 */ 748 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_MESH_STA_OFFSET 0x0000000c 749 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_MESH_STA_LSB 8 750 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_MESH_STA_MASK 0x00000100 751 752 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_HIT 753 754 In case of ndp or phy_err or AST_based_lookup_valid == 755 0, this field will be set to 0 756 757 758 759 When set, the BSSID of the incoming frame matched one of 760 the 8 BSSID register values 761 762 763 764 <legal all> 765 */ 766 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_HIT_OFFSET 0x0000000c 767 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_HIT_LSB 9 768 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_HIT_MASK 0x00000200 769 770 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_NUMBER 771 772 Field only valid when bssid_hit is set. 773 774 775 776 This number indicates which one out of the 8 BSSID 777 register values matched the incoming frame 778 779 <legal all> 780 */ 781 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_OFFSET 0x0000000c 782 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_LSB 10 783 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_BSSID_NUMBER_MASK 0x00003c00 784 785 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_TID 786 787 Field only valid when mpdu_qos_control_valid is set 788 789 790 791 The TID field in the QoS control field 792 793 <legal all> 794 */ 795 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_TID_OFFSET 0x0000000c 796 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_TID_LSB 14 797 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_TID_MASK 0x0003c000 798 799 /* Description RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_RESERVED_3A 800 801 <legal 0> 802 */ 803 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_RESERVED_3A_OFFSET 0x0000000c 804 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_RESERVED_3A_LSB 18 805 #define RX_MPDU_START_3_RX_MPDU_INFO_DETAILS_RESERVED_3A_MASK 0xfffc0000 806 807 /* Description RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_31_0 808 809 810 811 812 813 WEP: IV = {key_id_octet, pn2, pn1, pn0}. Only pn[23:0] 814 is valid. 815 816 TKIP: IV = {pn5, pn4, pn3, pn2, key_id_octet, pn0, 817 WEPSeed[1], pn1}. Only pn[47:0] is valid. 818 819 AES-CCM: IV = {pn5, pn4, pn3, pn2, key_id_octet, 0x0, 820 pn1, pn0}. Only pn[47:0] is valid. 821 822 WAPI: IV = {key_id_octet, 0x0, pn15, pn14, pn13, pn12, 823 pn11, pn10, pn9, pn8, pn7, pn6, pn5, pn4, pn3, pn2, pn1, 824 pn0}. pn[127:0] are valid. 825 826 827 828 */ 829 #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_31_0_OFFSET 0x00000010 830 #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_31_0_LSB 0 831 #define RX_MPDU_START_4_RX_MPDU_INFO_DETAILS_PN_31_0_MASK 0xffffffff 832 833 /* Description RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_63_32 834 835 836 837 838 Bits [63:32] of the PN number. See description for 839 pn_31_0. 840 841 842 843 */ 844 #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_63_32_OFFSET 0x00000014 845 #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_63_32_LSB 0 846 #define RX_MPDU_START_5_RX_MPDU_INFO_DETAILS_PN_63_32_MASK 0xffffffff 847 848 /* Description RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_95_64 849 850 851 852 853 Bits [95:64] of the PN number. See description for 854 pn_31_0. 855 856 857 858 */ 859 #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_95_64_OFFSET 0x00000018 860 #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_95_64_LSB 0 861 #define RX_MPDU_START_6_RX_MPDU_INFO_DETAILS_PN_95_64_MASK 0xffffffff 862 863 /* Description RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_PN_127_96 864 865 866 867 868 Bits [127:96] of the PN number. See description for 869 pn_31_0. 870 871 872 873 */ 874 #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_PN_127_96_OFFSET 0x0000001c 875 #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_PN_127_96_LSB 0 876 #define RX_MPDU_START_7_RX_MPDU_INFO_DETAILS_PN_127_96_MASK 0xffffffff 877 878 /* Description RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA 879 880 In case of ndp or phy_err or AST_based_lookup_valid == 881 0, this field will be set to 0 882 883 884 885 Meta data that SW has programmed in the Peer table entry 886 of the transmitting STA. 887 888 <legal all> 889 */ 890 #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_OFFSET 0x00000020 891 #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_LSB 0 892 #define RX_MPDU_START_8_RX_MPDU_INFO_DETAILS_PEER_META_DATA_MASK 0xffffffff 893 894 /* EXTERNAL REFERENCE : struct rxpt_classify_info rxpt_classify_info_details */ 895 896 897 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION 898 899 The ID of the REO exit ring where the MSDU frame shall 900 push after (MPDU level) reordering has finished. 901 902 903 904 <enum 0 reo_destination_tcl> Reo will push the frame 905 into the REO2TCL ring 906 907 <enum 1 reo_destination_sw1> Reo will push the frame 908 into the REO2SW1 ring 909 910 <enum 2 reo_destination_sw2> Reo will push the frame 911 into the REO2SW1 ring 912 913 <enum 3 reo_destination_sw3> Reo will push the frame 914 into the REO2SW1 ring 915 916 <enum 4 reo_destination_sw4> Reo will push the frame 917 into the REO2SW1 ring 918 919 <enum 5 reo_destination_release> Reo will push the frame 920 into the REO_release ring 921 922 <enum 6 reo_destination_fw> Reo will push the frame into 923 the REO2FW ring 924 925 <enum 7 reo_destination_7> REO remaps this 926 927 <enum 8 reo_destination_8> REO remaps this <enum 9 928 reo_destination_9> REO remaps this <enum 10 929 reo_destination_10> REO remaps this 930 931 <enum 11 reo_destination_11> REO remaps this 932 933 <enum 12 reo_destination_12> REO remaps this <enum 13 934 reo_destination_13> REO remaps this 935 936 <enum 14 reo_destination_14> REO remaps this 937 938 <enum 15 reo_destination_15> REO remaps this 939 940 <enum 16 reo_destination_16> REO remaps this 941 942 <enum 17 reo_destination_17> REO remaps this 943 944 <enum 18 reo_destination_18> REO remaps this 945 946 <enum 19 reo_destination_19> REO remaps this 947 948 <enum 20 reo_destination_20> REO remaps this 949 950 <enum 21 reo_destination_21> REO remaps this 951 952 <enum 22 reo_destination_22> REO remaps this 953 954 <enum 23 reo_destination_23> REO remaps this 955 956 <enum 24 reo_destination_24> REO remaps this 957 958 <enum 25 reo_destination_25> REO remaps this 959 960 <enum 26 reo_destination_26> REO remaps this 961 962 <enum 27 reo_destination_27> REO remaps this 963 964 <enum 28 reo_destination_28> REO remaps this 965 966 <enum 29 reo_destination_29> REO remaps this 967 968 <enum 30 reo_destination_30> REO remaps this 969 970 <enum 31 reo_destination_31> REO remaps this 971 972 973 974 <legal all> 975 */ 976 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_OFFSET 0x00000024 977 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_LSB 0 978 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_REO_DESTINATION_INDICATION_MASK 0x0000001f 979 980 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0A 981 982 <legal 0> 983 */ 984 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0A_OFFSET 0x00000024 985 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0A_LSB 5 986 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0A_MASK 0x00000060 987 988 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY 989 990 Field is used to enable classification based on the 991 chosen Toeplitz hash from Common Parser (without reference 992 to each hash type). 993 994 <legal all> 995 */ 996 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_OFFSET 0x00000024 997 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_LSB 7 998 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_USE_FLOW_ID_TOEPLITZ_CLFY_MASK 0x00000080 999 1000 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA 1001 1002 Filter pass ucast data frame routing selection. 1003 1004 1005 1006 1'b0: source and destination rings are selected from the 1007 RxOLE register settings for the packet type 1008 1009 1010 1011 1'b1: source ring and destination ring is selected from 1012 the rxdma0_source_ring_selection and 1013 rxdma0_destination_ring_selection fields in this STRUCT 1014 1015 <legal all> 1016 */ 1017 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_OFFSET 0x00000024 1018 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_LSB 8 1019 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_UCAST_DATA_MASK 0x00000100 1020 1021 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA 1022 1023 Filter pass multicase data frame routing selection. 1024 1025 1026 1027 1'b0: source and destination rings are selected from the 1028 RxOLE register settings for the packet type 1029 1030 1031 1032 1'b1: source ring and destination ring is selected from 1033 the rxdma0_source_ring_selection and 1034 rxdma0_destination_ring_selection fields in this STRUCT 1035 1036 <legal all> 1037 */ 1038 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_OFFSET 0x00000024 1039 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_LSB 9 1040 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_MCAST_DATA_MASK 0x00000200 1041 1042 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000 1043 1044 Filter pass control bar frame routing selection. 1045 1046 1047 1048 1'b0: source and destination rings are selected from the 1049 RxOLE register settings for the packet type 1050 1051 1052 1053 1'b1: source ring and destination ring is selected from 1054 the rxdma0_source_ring_selection and 1055 rxdma0_destination_ring_selection fields in this STRUCT 1056 1057 <legal all> 1058 */ 1059 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_OFFSET 0x00000024 1060 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_LSB 10 1061 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_PKT_SELECTION_FP_1000_MASK 0x00000400 1062 1063 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION 1064 1065 Field only valid when for the received frame type the 1066 corresponding pkt_selection_fp_... bit is set 1067 1068 1069 1070 <enum 0 wbm2rxdma_buf_source_ring> The data buffer for 1071 this frame shall be sourced by wbm2rxdma buffer source ring 1072 1073 <enum 1 fw2rxdma_buf_source_ring> The data buffer for 1074 this frame shall be sourced by fw2rxdma buffer source ring 1075 1076 <enum 2 sw2rxdma_buf_source_ring> The data buffer for 1077 this frame shall be sourced by sw2rxdma buffer source ring 1078 1079 <enum 3 no_buffer_ring> The frame shall not be written 1080 to any data buffer 1081 1082 <legal all> 1083 */ 1084 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_OFFSET 0x00000024 1085 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_LSB 11 1086 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_SOURCE_RING_SELECTION_MASK 0x00001800 1087 1088 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION 1089 1090 Field only valid when for the received frame type the 1091 corresponding pkt_selection_fp_... bit is set 1092 1093 1094 1095 <enum 0 rxdma_release_ring > RXDMA0 shall push the 1096 frame to the Release ring. Effectively this means the frame 1097 needs to be dropped. 1098 1099 1100 1101 <enum 1 rxdma2fw_ring > RXDMA0 shall push the frame to 1102 the FW ring 1103 1104 1105 1106 <enum 2 rxdma2sw_ring > RXDMA0 shall push the frame to 1107 the SW ring 1108 1109 1110 1111 <enum 3 rxdma2reo_ring > RXDMA0 shall push the frame 1112 to the REO entrance ring 1113 1114 <legal all> 1115 */ 1116 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_OFFSET 0x00000024 1117 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_LSB 13 1118 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RXDMA0_DESTINATION_RING_SELECTION_MASK 0x00006000 1119 1120 /* Description RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B 1121 1122 <legal 0> 1123 */ 1124 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_OFFSET 0x00000024 1125 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_LSB 15 1126 #define RX_MPDU_START_9_RX_MPDU_INFO_DETAILS_RXPT_CLASSIFY_INFO_DETAILS_RESERVED_0B_MASK 0xffff8000 1127 1128 /* Description RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0 1129 1130 In case of ndp or phy_err or AST_based_lookup_valid == 1131 0, this field will be set to 0 1132 1133 1134 1135 Address (lower 32 bits) of the REO queue descriptor. 1136 1137 1138 1139 If no Peer entry lookup happened for this frame, the 1140 value wil be set to 0, and the frame shall never be pushed 1141 to REO entrance ring. 1142 1143 <legal all> 1144 */ 1145 #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_OFFSET 0x00000028 1146 #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_LSB 0 1147 #define RX_MPDU_START_10_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_31_0_MASK 0xffffffff 1148 1149 /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32 1150 1151 In case of ndp or phy_err or AST_based_lookup_valid == 1152 0, this field will be set to 0 1153 1154 1155 1156 Address (upper 8 bits) of the REO queue descriptor. 1157 1158 1159 1160 If no Peer entry lookup happened for this frame, the 1161 value wil be set to 0, and the frame shall never be pushed 1162 to REO entrance ring. 1163 1164 <legal all> 1165 */ 1166 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_OFFSET 0x0000002c 1167 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_LSB 0 1168 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RX_REO_QUEUE_DESC_ADDR_39_32_MASK 0x000000ff 1169 1170 /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER 1171 1172 In case of ndp or phy_err or AST_based_lookup_valid == 1173 0, this field will be set to 0 1174 1175 1176 1177 Indicates the MPDU queue ID to which this MPDU link 1178 descriptor belongs 1179 1180 Used for tracking and debugging 1181 1182 <legal all> 1183 */ 1184 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_OFFSET 0x0000002c 1185 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_LSB 8 1186 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RECEIVE_QUEUE_NUMBER_MASK 0x00ffff00 1187 1188 /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING 1189 1190 Indicates that a delimiter FCS error was found in 1191 between the Previous MPDU and this MPDU. 1192 1193 1194 1195 Note that this is just a warning, and does not mean that 1196 this MPDU is corrupted in any way. If it is, there will be 1197 other errors indicated such as FCS or decrypt errors 1198 1199 1200 1201 In case of ndp or phy_err, this field will indicate at 1202 least one of delimiters located after the last MPDU in the 1203 previous PPDU has been corrupted. 1204 */ 1205 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_OFFSET 0x0000002c 1206 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_LSB 24 1207 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_PRE_DELIM_ERR_WARNING_MASK 0x01000000 1208 1209 /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR 1210 1211 Indicates that the first delimiter had a FCS failure. 1212 Only valid when first_mpdu and first_msdu are set. 1213 1214 1215 1216 */ 1217 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_OFFSET 0x0000002c 1218 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_LSB 25 1219 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_FIRST_DELIM_ERR_MASK 0x02000000 1220 1221 /* Description RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11 1222 1223 <legal 0> 1224 */ 1225 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11_OFFSET 0x0000002c 1226 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11_LSB 26 1227 #define RX_MPDU_START_11_RX_MPDU_INFO_DETAILS_RESERVED_11_MASK 0xfc000000 1228 1229 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET 1230 1231 1232 1233 1234 The key ID octet from the IV. 1235 1236 1237 1238 In case of ndp or phy_err or AST_based_lookup_valid == 1239 0, this field will be set to 0 1240 1241 <legal all> 1242 */ 1243 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_OFFSET 0x00000030 1244 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_LSB 0 1245 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_KEY_ID_OCTET_MASK 0x000000ff 1246 1247 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY 1248 1249 In case of ndp or phy_err or AST_based_lookup_valid == 1250 0, this field will be set to 0 1251 1252 1253 1254 Set if new RX_PEER_ENTRY TLV follows. If clear, 1255 RX_PEER_ENTRY doesn't follow so RX DECRYPTION module either 1256 uses old peer entry or not decrypt. 1257 1258 <legal all> 1259 */ 1260 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_OFFSET 0x00000030 1261 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_LSB 8 1262 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_NEW_PEER_ENTRY_MASK 0x00000100 1263 1264 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED 1265 1266 In case of ndp or phy_err or AST_based_lookup_valid == 1267 0, this field will be set to 0 1268 1269 1270 1271 Set if decryption is needed. 1272 1273 1274 1275 Note: 1276 1277 When RXPCU sets bit 'ast_index_not_found' and/or 1278 ast_index_timeout', RXPCU will also ensure that this bit is 1279 NOT set 1280 1281 CRYPTO for that reason only needs to evaluate this bit 1282 and non of the other ones. 1283 1284 <legal all> 1285 */ 1286 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_OFFSET 0x00000030 1287 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_LSB 9 1288 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECRYPT_NEEDED_MASK 0x00000200 1289 1290 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE 1291 1292 In case of ndp or phy_err or AST_based_lookup_valid == 1293 0, this field will be set to 0 1294 1295 1296 1297 Used by the OLE during decapsulation. 1298 1299 1300 1301 Indicates the decapsulation that HW will perform: 1302 1303 1304 1305 <enum 0 RAW> No encapsulation 1306 1307 <enum 1 Native_WiFi> 1308 1309 <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses 1310 SNAP/LLC) 1311 1312 <enum 3 802_3> Indicate Ethernet 1313 1314 1315 1316 <legal all> 1317 */ 1318 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_OFFSET 0x00000030 1319 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_LSB 10 1320 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_DECAP_TYPE_MASK 0x00000c00 1321 1322 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING 1323 1324 In case of ndp or phy_err or AST_based_lookup_valid == 1325 0, this field will be set to 0 1326 1327 1328 1329 Insert 4 byte of all zeros as VLAN tag if the rx payload 1330 does not have VLAN. Used during decapsulation. 1331 1332 <legal all> 1333 */ 1334 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_OFFSET 0x00000030 1335 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_LSB 12 1336 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_C_TAG_PADDING_MASK 0x00001000 1337 1338 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING 1339 1340 In case of ndp or phy_err or AST_based_lookup_valid == 1341 0, this field will be set to 0 1342 1343 1344 1345 Insert 4 byte of all zeros as double VLAN tag if the rx 1346 payload does not have VLAN. Used during 1347 1348 <legal all> 1349 */ 1350 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_OFFSET 0x00000030 1351 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_LSB 13 1352 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RX_INSERT_VLAN_S_TAG_PADDING_MASK 0x00002000 1353 1354 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP 1355 1356 In case of ndp or phy_err or AST_based_lookup_valid == 1357 0, this field will be set to 0 1358 1359 1360 1361 Strip the VLAN during decapsulation. Used by the OLE. 1362 1363 <legal all> 1364 */ 1365 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_OFFSET 0x00000030 1366 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_LSB 14 1367 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_C_TAG_DECAP_MASK 0x00004000 1368 1369 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP 1370 1371 In case of ndp or phy_err or AST_based_lookup_valid == 1372 0, this field will be set to 0 1373 1374 1375 1376 Strip the double VLAN during decapsulation. Used by 1377 the OLE. 1378 1379 <legal all> 1380 */ 1381 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_OFFSET 0x00000030 1382 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_LSB 15 1383 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_STRIP_VLAN_S_TAG_DECAP_MASK 0x00008000 1384 1385 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT 1386 1387 The number of delimiters before this MPDU. 1388 1389 1390 1391 Note that this number is cleared at PPDU start. 1392 1393 1394 1395 If this MPDU is the first received MPDU in the PPDU and 1396 this MPDU gets filtered-in, this field will indicate the 1397 number of delimiters located after the last MPDU in the 1398 previous PPDU. 1399 1400 1401 1402 If this MPDU is located after the first received MPDU in 1403 an PPDU, this field will indicate the number of delimiters 1404 located between the previous MPDU and this MPDU. 1405 1406 1407 1408 In case of ndp or phy_err, this field will indicate the 1409 number of delimiters located after the last MPDU in the 1410 previous PPDU. 1411 1412 <legal all> 1413 */ 1414 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_OFFSET 0x00000030 1415 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_LSB 16 1416 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_PRE_DELIM_COUNT_MASK 0x0fff0000 1417 1418 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG 1419 1420 When set, received frame was part of an A-MPDU. 1421 1422 1423 1424 1425 <legal all> 1426 */ 1427 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_OFFSET 0x00000030 1428 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_LSB 28 1429 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_AMPDU_FLAG_MASK 0x10000000 1430 1431 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME 1432 1433 In case of ndp or phy_err or AST_based_lookup_valid == 1434 0, this field will be set to 0 1435 1436 1437 1438 When set, received frame is a BAR frame 1439 1440 <legal all> 1441 */ 1442 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_OFFSET 0x00000030 1443 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_LSB 29 1444 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_BAR_FRAME_MASK 0x20000000 1445 1446 /* Description RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12 1447 1448 <legal 0>. 1449 */ 1450 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_OFFSET 0x00000030 1451 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_LSB 30 1452 #define RX_MPDU_START_12_RX_MPDU_INFO_DETAILS_RESERVED_12_MASK 0xc0000000 1453 1454 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH 1455 1456 In case of ndp or phy_err this field will be set to 0 1457 1458 1459 1460 MPDU length before decapsulation. 1461 1462 <legal all> 1463 */ 1464 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_OFFSET 0x00000034 1465 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_LSB 0 1466 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MPDU_LENGTH_MASK 0x00003fff 1467 1468 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU 1469 1470 See definition in RX attention descriptor 1471 1472 1473 1474 In case of ndp or phy_err, this field will be set. Note 1475 however that there will not actually be any data contents in 1476 the MPDU. 1477 1478 <legal all> 1479 */ 1480 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_OFFSET 0x00000034 1481 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_LSB 14 1482 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FIRST_MPDU_MASK 0x00004000 1483 1484 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST 1485 1486 In case of ndp or phy_err or Phy_err_during_mpdu_header 1487 this field will be set to 0 1488 1489 1490 1491 See definition in RX attention descriptor 1492 1493 <legal all> 1494 */ 1495 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_OFFSET 0x00000034 1496 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_LSB 15 1497 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MCAST_BCAST_MASK 0x00008000 1498 1499 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND 1500 1501 In case of ndp or phy_err or Phy_err_during_mpdu_header 1502 this field will be set to 0 1503 1504 1505 1506 See definition in RX attention descriptor 1507 1508 <legal all> 1509 */ 1510 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_OFFSET 0x00000034 1511 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_LSB 16 1512 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_NOT_FOUND_MASK 0x00010000 1513 1514 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT 1515 1516 In case of ndp or phy_err or Phy_err_during_mpdu_header 1517 this field will be set to 0 1518 1519 1520 1521 See definition in RX attention descriptor 1522 1523 <legal all> 1524 */ 1525 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_OFFSET 0x00000034 1526 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_LSB 17 1527 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_AST_INDEX_TIMEOUT_MASK 0x00020000 1528 1529 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT 1530 1531 In case of ndp or phy_err or Phy_err_during_mpdu_header 1532 this field will be set to 0 1533 1534 1535 1536 See definition in RX attention descriptor 1537 1538 <legal all> 1539 */ 1540 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_OFFSET 0x00000034 1541 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_LSB 18 1542 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_POWER_MGMT_MASK 0x00040000 1543 1544 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS 1545 1546 In case of ndp or phy_err or Phy_err_during_mpdu_header 1547 this field will be set to 1 1548 1549 1550 1551 See definition in RX attention descriptor 1552 1553 <legal all> 1554 */ 1555 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_OFFSET 0x00000034 1556 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_LSB 19 1557 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NON_QOS_MASK 0x00080000 1558 1559 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA 1560 1561 In case of ndp or phy_err or Phy_err_during_mpdu_header 1562 this field will be set to 0 1563 1564 1565 1566 See definition in RX attention descriptor 1567 1568 <legal all> 1569 */ 1570 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_OFFSET 0x00000034 1571 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_LSB 20 1572 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_NULL_DATA_MASK 0x00100000 1573 1574 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE 1575 1576 In case of ndp or phy_err or Phy_err_during_mpdu_header 1577 this field will be set to 0 1578 1579 1580 1581 See definition in RX attention descriptor 1582 1583 <legal all> 1584 */ 1585 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_OFFSET 0x00000034 1586 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_LSB 21 1587 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MGMT_TYPE_MASK 0x00200000 1588 1589 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE 1590 1591 In case of ndp or phy_err or Phy_err_during_mpdu_header 1592 this field will be set to 0 1593 1594 1595 1596 See definition in RX attention descriptor 1597 1598 <legal all> 1599 */ 1600 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_OFFSET 0x00000034 1601 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_LSB 22 1602 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_CTRL_TYPE_MASK 0x00400000 1603 1604 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA 1605 1606 In case of ndp or phy_err or Phy_err_during_mpdu_header 1607 this field will be set to 0 1608 1609 1610 1611 See definition in RX attention descriptor 1612 1613 <legal all> 1614 */ 1615 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_OFFSET 0x00000034 1616 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_LSB 23 1617 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_MORE_DATA_MASK 0x00800000 1618 1619 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP 1620 1621 In case of ndp or phy_err or Phy_err_during_mpdu_header 1622 this field will be set to 0 1623 1624 1625 1626 See definition in RX attention descriptor 1627 1628 <legal all> 1629 */ 1630 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_OFFSET 0x00000034 1631 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_LSB 24 1632 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_EOSP_MASK 0x01000000 1633 1634 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG 1635 1636 In case of ndp or phy_err or Phy_err_during_mpdu_header 1637 this field will be set to 0 1638 1639 1640 1641 See definition in RX attention descriptor 1642 1643 <legal all> 1644 */ 1645 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_OFFSET 0x00000034 1646 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_LSB 25 1647 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_FRAGMENT_FLAG_MASK 0x02000000 1648 1649 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER 1650 1651 In case of ndp or phy_err or Phy_err_during_mpdu_header 1652 this field will be set to 0 1653 1654 1655 1656 See definition in RX attention descriptor 1657 1658 1659 1660 <legal all> 1661 */ 1662 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_OFFSET 0x00000034 1663 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_LSB 26 1664 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ORDER_MASK 0x04000000 1665 1666 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER 1667 1668 In case of ndp or phy_err or Phy_err_during_mpdu_header 1669 this field will be set to 0 1670 1671 1672 1673 See definition in RX attention descriptor 1674 1675 <legal all> 1676 */ 1677 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_OFFSET 0x00000034 1678 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_LSB 27 1679 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_U_APSD_TRIGGER_MASK 0x08000000 1680 1681 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED 1682 1683 In case of ndp or phy_err or Phy_err_during_mpdu_header 1684 this field will be set to 0 1685 1686 1687 1688 See definition in RX attention descriptor 1689 1690 <legal all> 1691 */ 1692 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_OFFSET 0x00000034 1693 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_LSB 28 1694 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_ENCRYPT_REQUIRED_MASK 0x10000000 1695 1696 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED 1697 1698 In case of ndp or phy_err or Phy_err_during_mpdu_header 1699 this field will be set to 0 1700 1701 1702 1703 See definition in RX attention descriptor 1704 1705 <legal all> 1706 */ 1707 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_OFFSET 0x00000034 1708 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_LSB 29 1709 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_DIRECTED_MASK 0x20000000 1710 1711 /* Description RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13 1712 1713 <legal 0> 1714 */ 1715 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_OFFSET 0x00000034 1716 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_LSB 30 1717 #define RX_MPDU_START_13_RX_MPDU_INFO_DETAILS_RESERVED_13_MASK 0xc0000000 1718 1719 /* Description RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD 1720 1721 Field only valid when Mpdu_frame_control_valid is set 1722 1723 1724 1725 The frame control field of this received MPDU. 1726 1727 1728 1729 Field only valid when Ndp_frame and phy_err are NOT set 1730 1731 1732 1733 Bytes 0 + 1 of the received MPDU 1734 1735 <legal all> 1736 */ 1737 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_OFFSET 0x00000038 1738 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_LSB 0 1739 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_FRAME_CONTROL_FIELD_MASK 0x0000ffff 1740 1741 /* Description RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD 1742 1743 Field only valid when Mpdu_duration_valid is set 1744 1745 1746 1747 The duration field of this received MPDU. 1748 1749 <legal all> 1750 */ 1751 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_OFFSET 0x00000038 1752 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_LSB 16 1753 #define RX_MPDU_START_14_RX_MPDU_INFO_DETAILS_MPDU_DURATION_FIELD_MASK 0xffff0000 1754 1755 /* Description RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0 1756 1757 Field only valid when mac_addr_ad1_valid is set 1758 1759 1760 1761 The Least Significant 4 bytes of the Received Frames MAC 1762 Address AD1 1763 1764 <legal all> 1765 */ 1766 #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_OFFSET 0x0000003c 1767 #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_LSB 0 1768 #define RX_MPDU_START_15_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_31_0_MASK 0xffffffff 1769 1770 /* Description RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32 1771 1772 Field only valid when mac_addr_ad1_valid is set 1773 1774 1775 1776 The 2 most significant bytes of the Received Frames MAC 1777 Address AD1 1778 1779 <legal all> 1780 */ 1781 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_OFFSET 0x00000040 1782 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_LSB 0 1783 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD1_47_32_MASK 0x0000ffff 1784 1785 /* Description RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0 1786 1787 Field only valid when mac_addr_ad2_valid is set 1788 1789 1790 1791 The Least Significant 2 bytes of the Received Frames MAC 1792 Address AD2 1793 1794 <legal all> 1795 */ 1796 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_OFFSET 0x00000040 1797 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_LSB 16 1798 #define RX_MPDU_START_16_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_15_0_MASK 0xffff0000 1799 1800 /* Description RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16 1801 1802 Field only valid when mac_addr_ad2_valid is set 1803 1804 1805 1806 The 4 most significant bytes of the Received Frames MAC 1807 Address AD2 1808 1809 <legal all> 1810 */ 1811 #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_OFFSET 0x00000044 1812 #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_LSB 0 1813 #define RX_MPDU_START_17_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD2_47_16_MASK 0xffffffff 1814 1815 /* Description RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0 1816 1817 Field only valid when mac_addr_ad3_valid is set 1818 1819 1820 1821 The Least Significant 4 bytes of the Received Frames MAC 1822 Address AD3 1823 1824 <legal all> 1825 */ 1826 #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_OFFSET 0x00000048 1827 #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_LSB 0 1828 #define RX_MPDU_START_18_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_31_0_MASK 0xffffffff 1829 1830 /* Description RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32 1831 1832 Field only valid when mac_addr_ad3_valid is set 1833 1834 1835 1836 The 2 most significant bytes of the Received Frames MAC 1837 Address AD3 1838 1839 <legal all> 1840 */ 1841 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_OFFSET 0x0000004c 1842 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_LSB 0 1843 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD3_47_32_MASK 0x0000ffff 1844 1845 /* Description RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD 1846 1847 1848 1849 1850 The sequence control field of the MPDU 1851 1852 <legal all> 1853 */ 1854 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_OFFSET 0x0000004c 1855 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_LSB 16 1856 #define RX_MPDU_START_19_RX_MPDU_INFO_DETAILS_MPDU_SEQUENCE_CONTROL_FIELD_MASK 0xffff0000 1857 1858 /* Description RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0 1859 1860 Field only valid when mac_addr_ad4_valid is set 1861 1862 1863 1864 The Least Significant 4 bytes of the Received Frames MAC 1865 Address AD4 1866 1867 <legal all> 1868 */ 1869 #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_OFFSET 0x00000050 1870 #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_LSB 0 1871 #define RX_MPDU_START_20_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_31_0_MASK 0xffffffff 1872 1873 /* Description RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32 1874 1875 Field only valid when mac_addr_ad4_valid is set 1876 1877 1878 1879 The 2 most significant bytes of the Received Frames MAC 1880 Address AD4 1881 1882 <legal all> 1883 */ 1884 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_OFFSET 0x00000054 1885 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_LSB 0 1886 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MAC_ADDR_AD4_47_32_MASK 0x0000ffff 1887 1888 /* Description RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD 1889 1890 Field only valid when mpdu_qos_control_valid is set 1891 1892 1893 1894 The sequence control field of the MPDU 1895 1896 <legal all> 1897 */ 1898 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_OFFSET 0x00000054 1899 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_LSB 16 1900 #define RX_MPDU_START_21_RX_MPDU_INFO_DETAILS_MPDU_QOS_CONTROL_FIELD_MASK 0xffff0000 1901 1902 /* Description RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD 1903 1904 Field only valid when mpdu_qos_control_valid is set 1905 1906 1907 1908 The HT control field of the MPDU 1909 1910 <legal all> 1911 */ 1912 #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_OFFSET 0x00000058 1913 #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_LSB 0 1914 #define RX_MPDU_START_22_RX_MPDU_INFO_DETAILS_MPDU_HT_CONTROL_FIELD_MASK 0xffffffff 1915 1916 /* Description RX_MPDU_START_23_RAW_MPDU 1917 1918 Set by OLE when it has not performed any .11 to .3 1919 header conversion on this MPDU. 1920 1921 <legal all> 1922 */ 1923 #define RX_MPDU_START_23_RAW_MPDU_OFFSET 0x0000005c 1924 #define RX_MPDU_START_23_RAW_MPDU_LSB 0 1925 #define RX_MPDU_START_23_RAW_MPDU_MASK 0x00000001 1926 1927 /* Description RX_MPDU_START_23_RESERVED_23 1928 1929 <legal 0> 1930 */ 1931 #define RX_MPDU_START_23_RESERVED_23_OFFSET 0x0000005c 1932 #define RX_MPDU_START_23_RESERVED_23_LSB 1 1933 #define RX_MPDU_START_23_RESERVED_23_MASK 0xfffffffe 1934 1935 1936 #endif // _RX_MPDU_START_H_ 1937