ack_report.h 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. /*
  2. * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved.
  3. * SPDX-License-Identifier: ISC
  4. */
  5. #ifndef _ACK_REPORT_H_
  6. #define _ACK_REPORT_H_
  7. #if !defined(__ASSEMBLER__)
  8. #endif
  9. #define NUM_OF_DWORDS_ACK_REPORT 1
  10. struct ack_report {
  11. #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
  12. uint32_t selfgen_response_reason : 4,
  13. ax_trigger_type : 4,
  14. sr_ppdu : 1,
  15. reserved : 7,
  16. frame_control : 16;
  17. #else
  18. uint32_t frame_control : 16,
  19. reserved : 7,
  20. sr_ppdu : 1,
  21. ax_trigger_type : 4,
  22. selfgen_response_reason : 4;
  23. #endif
  24. };
  25. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_OFFSET 0x00000000
  26. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_LSB 0
  27. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MSB 3
  28. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MASK 0x0000000f
  29. #define ACK_REPORT_AX_TRIGGER_TYPE_OFFSET 0x00000000
  30. #define ACK_REPORT_AX_TRIGGER_TYPE_LSB 4
  31. #define ACK_REPORT_AX_TRIGGER_TYPE_MSB 7
  32. #define ACK_REPORT_AX_TRIGGER_TYPE_MASK 0x000000f0
  33. #define ACK_REPORT_SR_PPDU_OFFSET 0x00000000
  34. #define ACK_REPORT_SR_PPDU_LSB 8
  35. #define ACK_REPORT_SR_PPDU_MSB 8
  36. #define ACK_REPORT_SR_PPDU_MASK 0x00000100
  37. #define ACK_REPORT_RESERVED_OFFSET 0x00000000
  38. #define ACK_REPORT_RESERVED_LSB 9
  39. #define ACK_REPORT_RESERVED_MSB 15
  40. #define ACK_REPORT_RESERVED_MASK 0x0000fe00
  41. #define ACK_REPORT_FRAME_CONTROL_OFFSET 0x00000000
  42. #define ACK_REPORT_FRAME_CONTROL_LSB 16
  43. #define ACK_REPORT_FRAME_CONTROL_MSB 31
  44. #define ACK_REPORT_FRAME_CONTROL_MASK 0xffff0000
  45. #endif