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 #ifndef _RX_MSDU_DESC_INFO_H_ 20 #define _RX_MSDU_DESC_INFO_H_ 21 #if !defined(__ASSEMBLER__) 22 #endif 23 24 25 // ################ START SUMMARY ################# 26 // 27 // Dword Fields 28 // 0 first_msdu_in_mpdu_flag[0], last_msdu_in_mpdu_flag[1], msdu_continuation[2], msdu_length[16:3], reo_destination_indication[21:17], msdu_drop[22], sa_is_valid[23], sa_idx_timeout[24], da_is_valid[25], da_is_mcbc[26], da_idx_timeout[27], reserved_0a[31:28] 29 // 1 reserved_1a[31:0] 30 // 31 // ################ END SUMMARY ################# 32 33 #define NUM_OF_DWORDS_RX_MSDU_DESC_INFO 2 34 35 struct rx_msdu_desc_info { 36 uint32_t first_msdu_in_mpdu_flag : 1, //[0] 37 last_msdu_in_mpdu_flag : 1, //[1] 38 msdu_continuation : 1, //[2] 39 msdu_length : 14, //[16:3] 40 reo_destination_indication : 5, //[21:17] 41 msdu_drop : 1, //[22] 42 sa_is_valid : 1, //[23] 43 sa_idx_timeout : 1, //[24] 44 da_is_valid : 1, //[25] 45 da_is_mcbc : 1, //[26] 46 da_idx_timeout : 1, //[27] 47 reserved_0a : 4; //[31:28] 48 uint32_t reserved_1a : 32; //[31:0] 49 }; 50 51 /* 52 53 first_msdu_in_mpdu_flag 54 55 Parsed from RX_MSDU_END TLV . In the case MSDU spans 56 over multiple buffers, this field will be valid in the Last 57 buffer used by the MSDU 58 59 60 61 <enum 0 Not_first_msdu> This is not the first MSDU in 62 the MPDU. 63 64 <enum 1 first_msdu> This MSDU is the first one in the 65 MPDU. 66 67 68 69 <legal all> 70 71 last_msdu_in_mpdu_flag 72 73 Consumer: WBM/REO/SW/FW 74 75 Producer: RXDMA 76 77 78 79 Parsed from RX_MSDU_END TLV . In the case MSDU spans 80 over multiple buffers, this field will be valid in the Last 81 buffer used by the MSDU 82 83 84 85 <enum 0 Not_last_msdu> There are more MSDUs linked to 86 this MSDU that belongs to this MPDU 87 88 <enum 1 Last_msdu> this MSDU is the last one in the 89 MPDU. This setting is only allowed in combination with 90 'Msdu_continuation' set to 0. This implies that when an msdu 91 is spread out over multiple buffers and thus 92 msdu_continuation is set, only for the very last buffer of 93 the msdu, can the 'last_msdu_in_mpdu_flag' be set. 94 95 96 97 When both first_msdu_in_mpdu_flag and 98 last_msdu_in_mpdu_flag are set, the MPDU that this MSDU 99 belongs to only contains a single MSDU. 100 101 102 103 104 105 <legal all> 106 107 msdu_continuation 108 109 When set, this MSDU buffer was not able to hold the 110 entire MSDU. The next buffer will therefor contain 111 additional information related to this MSDU. 112 113 114 115 <legal all> 116 117 msdu_length 118 119 Parsed from RX_MSDU_START TLV . In the case MSDU spans 120 over multiple buffers, this field will be valid in the First 121 buffer used by MSDU. 122 123 124 125 Full MSDU length in bytes after decapsulation. 126 127 128 129 This field is still valid for MPDU frames without 130 A-MSDU. It still represents MSDU length after decapsulation 131 132 133 134 Or in case of RAW MPDUs, it indicates the length of the 135 entire MPDU (without FCS field) 136 137 <legal all> 138 139 reo_destination_indication 140 141 Parsed from RX_MSDU_END TLV . In the case MSDU spans 142 over multiple buffers, this field will be valid in the Last 143 buffer used by the MSDU 144 145 146 147 The ID of the REO exit ring where the MSDU frame shall 148 push after (MPDU level) reordering has finished. 149 150 151 152 <enum 0 reo_destination_tcl> Reo will push the frame 153 into the REO2TCL ring 154 155 <enum 1 reo_destination_sw1> Reo will push the frame 156 into the REO2SW1 ring 157 158 <enum 2 reo_destination_sw2> Reo will push the frame 159 into the REO2SW1 ring 160 161 <enum 3 reo_destination_sw3> Reo will push the frame 162 into the REO2SW1 ring 163 164 <enum 4 reo_destination_sw4> Reo will push the frame 165 into the REO2SW1 ring 166 167 <enum 5 reo_destination_release> Reo will push the frame 168 into the REO_release ring 169 170 <enum 6 reo_destination_fw> Reo will push the frame into 171 the REO2FW ring 172 173 <enum 7 reo_destination_7> REO remaps this 174 175 <enum 8 reo_destination_8> REO remaps this <enum 9 176 reo_destination_9> REO remaps this <enum 10 177 reo_destination_10> REO remaps this 178 179 <enum 11 reo_destination_11> REO remaps this 180 181 <enum 12 reo_destination_12> REO remaps this <enum 13 182 reo_destination_13> REO remaps this 183 184 <enum 14 reo_destination_14> REO remaps this 185 186 <enum 15 reo_destination_15> REO remaps this 187 188 <enum 16 reo_destination_16> REO remaps this 189 190 <enum 17 reo_destination_17> REO remaps this 191 192 <enum 18 reo_destination_18> REO remaps this 193 194 <enum 19 reo_destination_19> REO remaps this 195 196 <enum 20 reo_destination_20> REO remaps this 197 198 <enum 21 reo_destination_21> REO remaps this 199 200 <enum 22 reo_destination_22> REO remaps this 201 202 <enum 23 reo_destination_23> REO remaps this 203 204 <enum 24 reo_destination_24> REO remaps this 205 206 <enum 25 reo_destination_25> REO remaps this 207 208 <enum 26 reo_destination_26> REO remaps this 209 210 <enum 27 reo_destination_27> REO remaps this 211 212 <enum 28 reo_destination_28> REO remaps this 213 214 <enum 29 reo_destination_29> REO remaps this 215 216 <enum 30 reo_destination_30> REO remaps this 217 218 <enum 31 reo_destination_31> REO remaps this 219 220 221 222 <legal all> 223 224 msdu_drop 225 226 Parsed from RX_MSDU_END TLV . In the case MSDU spans 227 over multiple buffers, this field will be valid in the Last 228 buffer used by the MSDU 229 230 231 232 When set, REO shall drop this MSDU and not forward it to 233 any other ring... 234 235 <legal all> 236 237 sa_is_valid 238 239 Parsed from RX_MSDU_END TLV . In the case MSDU spans 240 over multiple buffers, this field will be valid in the Last 241 buffer used by the MSDU 242 243 244 245 Indicates that OLE found a valid SA entry for this MSDU 246 247 <legal all> 248 249 sa_idx_timeout 250 251 Parsed from RX_MSDU_END TLV . In the case MSDU spans 252 over multiple buffers, this field will be valid in the Last 253 buffer used by the MSDU 254 255 256 257 Indicates an unsuccessful MAC source address search due 258 to the expiring of the search timer for this MSDU 259 260 <legal all> 261 262 da_is_valid 263 264 Parsed from RX_MSDU_END TLV . In the case MSDU spans 265 over multiple buffers, this field will be valid in the Last 266 buffer used by the MSDU 267 268 269 270 Indicates that OLE found a valid DA entry for this MSDU 271 272 <legal all> 273 274 da_is_mcbc 275 276 Field Only valid if da_is_valid is set 277 278 279 280 Indicates the DA address was a Multicast of Broadcast 281 address for this MSDU 282 283 <legal all> 284 285 da_idx_timeout 286 287 Parsed from RX_MSDU_END TLV . In the case MSDU spans 288 over multiple buffers, this field will be valid in the Last 289 buffer used by the MSDU 290 291 292 293 Indicates an unsuccessful MAC destination address search 294 due to the expiring of the search timer for this MSDU 295 296 <legal all> 297 298 reserved_0a 299 300 <legal 0> 301 302 reserved_1a 303 304 <legal 0> 305 */ 306 307 308 /* Description RX_MSDU_DESC_INFO_0_FIRST_MSDU_IN_MPDU_FLAG 309 310 Parsed from RX_MSDU_END TLV . In the case MSDU spans 311 over multiple buffers, this field will be valid in the Last 312 buffer used by the MSDU 313 314 315 316 <enum 0 Not_first_msdu> This is not the first MSDU in 317 the MPDU. 318 319 <enum 1 first_msdu> This MSDU is the first one in the 320 MPDU. 321 322 323 324 <legal all> 325 */ 326 #define RX_MSDU_DESC_INFO_0_FIRST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000000 327 #define RX_MSDU_DESC_INFO_0_FIRST_MSDU_IN_MPDU_FLAG_LSB 0 328 #define RX_MSDU_DESC_INFO_0_FIRST_MSDU_IN_MPDU_FLAG_MASK 0x00000001 329 330 /* Description RX_MSDU_DESC_INFO_0_LAST_MSDU_IN_MPDU_FLAG 331 332 Consumer: WBM/REO/SW/FW 333 334 Producer: RXDMA 335 336 337 338 Parsed from RX_MSDU_END TLV . In the case MSDU spans 339 over multiple buffers, this field will be valid in the Last 340 buffer used by the MSDU 341 342 343 344 <enum 0 Not_last_msdu> There are more MSDUs linked to 345 this MSDU that belongs to this MPDU 346 347 <enum 1 Last_msdu> this MSDU is the last one in the 348 MPDU. This setting is only allowed in combination with 349 'Msdu_continuation' set to 0. This implies that when an msdu 350 is spread out over multiple buffers and thus 351 msdu_continuation is set, only for the very last buffer of 352 the msdu, can the 'last_msdu_in_mpdu_flag' be set. 353 354 355 356 When both first_msdu_in_mpdu_flag and 357 last_msdu_in_mpdu_flag are set, the MPDU that this MSDU 358 belongs to only contains a single MSDU. 359 360 361 362 363 364 <legal all> 365 */ 366 #define RX_MSDU_DESC_INFO_0_LAST_MSDU_IN_MPDU_FLAG_OFFSET 0x00000000 367 #define RX_MSDU_DESC_INFO_0_LAST_MSDU_IN_MPDU_FLAG_LSB 1 368 #define RX_MSDU_DESC_INFO_0_LAST_MSDU_IN_MPDU_FLAG_MASK 0x00000002 369 370 /* Description RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION 371 372 When set, this MSDU buffer was not able to hold the 373 entire MSDU. The next buffer will therefor contain 374 additional information related to this MSDU. 375 376 377 378 <legal all> 379 */ 380 #define RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION_OFFSET 0x00000000 381 #define RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION_LSB 2 382 #define RX_MSDU_DESC_INFO_0_MSDU_CONTINUATION_MASK 0x00000004 383 384 /* Description RX_MSDU_DESC_INFO_0_MSDU_LENGTH 385 386 Parsed from RX_MSDU_START TLV . In the case MSDU spans 387 over multiple buffers, this field will be valid in the First 388 buffer used by MSDU. 389 390 391 392 Full MSDU length in bytes after decapsulation. 393 394 395 396 This field is still valid for MPDU frames without 397 A-MSDU. It still represents MSDU length after decapsulation 398 399 400 401 Or in case of RAW MPDUs, it indicates the length of the 402 entire MPDU (without FCS field) 403 404 <legal all> 405 */ 406 #define RX_MSDU_DESC_INFO_0_MSDU_LENGTH_OFFSET 0x00000000 407 #define RX_MSDU_DESC_INFO_0_MSDU_LENGTH_LSB 3 408 #define RX_MSDU_DESC_INFO_0_MSDU_LENGTH_MASK 0x0001fff8 409 410 /* Description RX_MSDU_DESC_INFO_0_REO_DESTINATION_INDICATION 411 412 Parsed from RX_MSDU_END TLV . In the case MSDU spans 413 over multiple buffers, this field will be valid in the Last 414 buffer used by the MSDU 415 416 417 418 The ID of the REO exit ring where the MSDU frame shall 419 push after (MPDU level) reordering has finished. 420 421 422 423 <enum 0 reo_destination_tcl> Reo will push the frame 424 into the REO2TCL ring 425 426 <enum 1 reo_destination_sw1> Reo will push the frame 427 into the REO2SW1 ring 428 429 <enum 2 reo_destination_sw2> Reo will push the frame 430 into the REO2SW1 ring 431 432 <enum 3 reo_destination_sw3> Reo will push the frame 433 into the REO2SW1 ring 434 435 <enum 4 reo_destination_sw4> Reo will push the frame 436 into the REO2SW1 ring 437 438 <enum 5 reo_destination_release> Reo will push the frame 439 into the REO_release ring 440 441 <enum 6 reo_destination_fw> Reo will push the frame into 442 the REO2FW ring 443 444 <enum 7 reo_destination_7> REO remaps this 445 446 <enum 8 reo_destination_8> REO remaps this <enum 9 447 reo_destination_9> REO remaps this <enum 10 448 reo_destination_10> REO remaps this 449 450 <enum 11 reo_destination_11> REO remaps this 451 452 <enum 12 reo_destination_12> REO remaps this <enum 13 453 reo_destination_13> REO remaps this 454 455 <enum 14 reo_destination_14> REO remaps this 456 457 <enum 15 reo_destination_15> REO remaps this 458 459 <enum 16 reo_destination_16> REO remaps this 460 461 <enum 17 reo_destination_17> REO remaps this 462 463 <enum 18 reo_destination_18> REO remaps this 464 465 <enum 19 reo_destination_19> REO remaps this 466 467 <enum 20 reo_destination_20> REO remaps this 468 469 <enum 21 reo_destination_21> REO remaps this 470 471 <enum 22 reo_destination_22> REO remaps this 472 473 <enum 23 reo_destination_23> REO remaps this 474 475 <enum 24 reo_destination_24> REO remaps this 476 477 <enum 25 reo_destination_25> REO remaps this 478 479 <enum 26 reo_destination_26> REO remaps this 480 481 <enum 27 reo_destination_27> REO remaps this 482 483 <enum 28 reo_destination_28> REO remaps this 484 485 <enum 29 reo_destination_29> REO remaps this 486 487 <enum 30 reo_destination_30> REO remaps this 488 489 <enum 31 reo_destination_31> REO remaps this 490 491 492 493 <legal all> 494 */ 495 #define RX_MSDU_DESC_INFO_0_REO_DESTINATION_INDICATION_OFFSET 0x00000000 496 #define RX_MSDU_DESC_INFO_0_REO_DESTINATION_INDICATION_LSB 17 497 #define RX_MSDU_DESC_INFO_0_REO_DESTINATION_INDICATION_MASK 0x003e0000 498 499 /* Description RX_MSDU_DESC_INFO_0_MSDU_DROP 500 501 Parsed from RX_MSDU_END TLV . In the case MSDU spans 502 over multiple buffers, this field will be valid in the Last 503 buffer used by the MSDU 504 505 506 507 When set, REO shall drop this MSDU and not forward it to 508 any other ring... 509 510 <legal all> 511 */ 512 #define RX_MSDU_DESC_INFO_0_MSDU_DROP_OFFSET 0x00000000 513 #define RX_MSDU_DESC_INFO_0_MSDU_DROP_LSB 22 514 #define RX_MSDU_DESC_INFO_0_MSDU_DROP_MASK 0x00400000 515 516 /* Description RX_MSDU_DESC_INFO_0_SA_IS_VALID 517 518 Parsed from RX_MSDU_END TLV . In the case MSDU spans 519 over multiple buffers, this field will be valid in the Last 520 buffer used by the MSDU 521 522 523 524 Indicates that OLE found a valid SA entry for this MSDU 525 526 <legal all> 527 */ 528 #define RX_MSDU_DESC_INFO_0_SA_IS_VALID_OFFSET 0x00000000 529 #define RX_MSDU_DESC_INFO_0_SA_IS_VALID_LSB 23 530 #define RX_MSDU_DESC_INFO_0_SA_IS_VALID_MASK 0x00800000 531 532 /* Description RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT 533 534 Parsed from RX_MSDU_END TLV . In the case MSDU spans 535 over multiple buffers, this field will be valid in the Last 536 buffer used by the MSDU 537 538 539 540 Indicates an unsuccessful MAC source address search due 541 to the expiring of the search timer for this MSDU 542 543 <legal all> 544 */ 545 #define RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT_OFFSET 0x00000000 546 #define RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT_LSB 24 547 #define RX_MSDU_DESC_INFO_0_SA_IDX_TIMEOUT_MASK 0x01000000 548 549 /* Description RX_MSDU_DESC_INFO_0_DA_IS_VALID 550 551 Parsed from RX_MSDU_END TLV . In the case MSDU spans 552 over multiple buffers, this field will be valid in the Last 553 buffer used by the MSDU 554 555 556 557 Indicates that OLE found a valid DA entry for this MSDU 558 559 <legal all> 560 */ 561 #define RX_MSDU_DESC_INFO_0_DA_IS_VALID_OFFSET 0x00000000 562 #define RX_MSDU_DESC_INFO_0_DA_IS_VALID_LSB 25 563 #define RX_MSDU_DESC_INFO_0_DA_IS_VALID_MASK 0x02000000 564 565 /* Description RX_MSDU_DESC_INFO_0_DA_IS_MCBC 566 567 Field Only valid if da_is_valid is set 568 569 570 571 Indicates the DA address was a Multicast of Broadcast 572 address for this MSDU 573 574 <legal all> 575 */ 576 #define RX_MSDU_DESC_INFO_0_DA_IS_MCBC_OFFSET 0x00000000 577 #define RX_MSDU_DESC_INFO_0_DA_IS_MCBC_LSB 26 578 #define RX_MSDU_DESC_INFO_0_DA_IS_MCBC_MASK 0x04000000 579 580 /* Description RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT 581 582 Parsed from RX_MSDU_END TLV . In the case MSDU spans 583 over multiple buffers, this field will be valid in the Last 584 buffer used by the MSDU 585 586 587 588 Indicates an unsuccessful MAC destination address search 589 due to the expiring of the search timer for this MSDU 590 591 <legal all> 592 */ 593 #define RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT_OFFSET 0x00000000 594 #define RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT_LSB 27 595 #define RX_MSDU_DESC_INFO_0_DA_IDX_TIMEOUT_MASK 0x08000000 596 597 /* Description RX_MSDU_DESC_INFO_0_RESERVED_0A 598 599 <legal 0> 600 */ 601 #define RX_MSDU_DESC_INFO_0_RESERVED_0A_OFFSET 0x00000000 602 #define RX_MSDU_DESC_INFO_0_RESERVED_0A_LSB 28 603 #define RX_MSDU_DESC_INFO_0_RESERVED_0A_MASK 0xf0000000 604 605 /* Description RX_MSDU_DESC_INFO_1_RESERVED_1A 606 607 <legal 0> 608 */ 609 #define RX_MSDU_DESC_INFO_1_RESERVED_1A_OFFSET 0x00000004 610 #define RX_MSDU_DESC_INFO_1_RESERVED_1A_LSB 0 611 #define RX_MSDU_DESC_INFO_1_RESERVED_1A_MASK 0xffffffff 612 613 614 #endif // _RX_MSDU_DESC_INFO_H_ 615