ack_report.h 3.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * Copyright (c) 2022, Qualcomm Innovation Center, Inc. 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. #ifndef _ACK_REPORT_H_
  17. #define _ACK_REPORT_H_
  18. #if !defined(__ASSEMBLER__)
  19. #endif
  20. #define NUM_OF_DWORDS_ACK_REPORT 1
  21. struct ack_report {
  22. #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
  23. uint32_t selfgen_response_reason : 4, // [3:0]
  24. ax_trigger_type : 4, // [7:4]
  25. sr_ppdu : 1, // [8:8]
  26. reserved : 7, // [15:9]
  27. frame_control : 16; // [31:16]
  28. #else
  29. uint32_t frame_control : 16, // [31:16]
  30. reserved : 7, // [15:9]
  31. sr_ppdu : 1, // [8:8]
  32. ax_trigger_type : 4, // [7:4]
  33. selfgen_response_reason : 4; // [3:0]
  34. #endif
  35. };
  36. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_OFFSET 0x00000000
  37. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_LSB 0
  38. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MSB 3
  39. #define ACK_REPORT_SELFGEN_RESPONSE_REASON_MASK 0x0000000f
  40. #define ACK_REPORT_AX_TRIGGER_TYPE_OFFSET 0x00000000
  41. #define ACK_REPORT_AX_TRIGGER_TYPE_LSB 4
  42. #define ACK_REPORT_AX_TRIGGER_TYPE_MSB 7
  43. #define ACK_REPORT_AX_TRIGGER_TYPE_MASK 0x000000f0
  44. #define ACK_REPORT_SR_PPDU_OFFSET 0x00000000
  45. #define ACK_REPORT_SR_PPDU_LSB 8
  46. #define ACK_REPORT_SR_PPDU_MSB 8
  47. #define ACK_REPORT_SR_PPDU_MASK 0x00000100
  48. #define ACK_REPORT_RESERVED_OFFSET 0x00000000
  49. #define ACK_REPORT_RESERVED_LSB 9
  50. #define ACK_REPORT_RESERVED_MSB 15
  51. #define ACK_REPORT_RESERVED_MASK 0x0000fe00
  52. #define ACK_REPORT_FRAME_CONTROL_OFFSET 0x00000000
  53. #define ACK_REPORT_FRAME_CONTROL_LSB 16
  54. #define ACK_REPORT_FRAME_CONTROL_MSB 31
  55. #define ACK_REPORT_FRAME_CONTROL_MASK 0xffff0000
  56. #endif