tx_fes_status_start_ppdu.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237
  1. /*
  2. * Copyright (c) 2024, Qualcomm Innovation Center, Inc. All rights reserved.
  3. * SPDX-License-Identifier: ISC
  4. */
  5. #ifndef _TX_FES_STATUS_START_PPDU_H_
  6. #define _TX_FES_STATUS_START_PPDU_H_
  7. #if !defined(__ASSEMBLER__)
  8. #endif
  9. #define NUM_OF_DWORDS_TX_FES_STATUS_START_PPDU 4
  10. #define NUM_OF_QWORDS_TX_FES_STATUS_START_PPDU 2
  11. struct tx_fes_status_start_ppdu {
  12. #ifndef WIFI_BIT_ORDER_BIG_ENDIAN
  13. uint32_t ppdu_timestamp_lower_32 : 32;
  14. uint32_t ppdu_timestamp_upper_32 : 32;
  15. uint32_t subband_mask : 16,
  16. ndp_frame : 2,
  17. reserved_2b : 2,
  18. coex_based_tx_bw : 3,
  19. coex_based_ant_mask : 8,
  20. reserved_2c : 1;
  21. uint32_t coex_based_tx_pwr_shared_ant : 8,
  22. coex_based_tx_pwr_ant : 8,
  23. concurrent_bt_tx : 1,
  24. concurrent_wlan_tx : 1,
  25. concurrent_wan_tx : 1,
  26. concurrent_wan_rx : 1,
  27. coex_pwr_reduction_bt : 1,
  28. coex_pwr_reduction_wlan : 1,
  29. coex_pwr_reduction_wan : 1,
  30. coex_result_alt_based : 1,
  31. request_packet_bw : 3,
  32. response_type : 5;
  33. #else
  34. uint32_t ppdu_timestamp_lower_32 : 32;
  35. uint32_t ppdu_timestamp_upper_32 : 32;
  36. uint32_t reserved_2c : 1,
  37. coex_based_ant_mask : 8,
  38. coex_based_tx_bw : 3,
  39. reserved_2b : 2,
  40. ndp_frame : 2,
  41. subband_mask : 16;
  42. uint32_t response_type : 5,
  43. request_packet_bw : 3,
  44. coex_result_alt_based : 1,
  45. coex_pwr_reduction_wan : 1,
  46. coex_pwr_reduction_wlan : 1,
  47. coex_pwr_reduction_bt : 1,
  48. concurrent_wan_rx : 1,
  49. concurrent_wan_tx : 1,
  50. concurrent_wlan_tx : 1,
  51. concurrent_bt_tx : 1,
  52. coex_based_tx_pwr_ant : 8,
  53. coex_based_tx_pwr_shared_ant : 8;
  54. #endif
  55. };
  56. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_LOWER_32_OFFSET 0x0000000000000000
  57. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_LOWER_32_LSB 0
  58. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_LOWER_32_MSB 31
  59. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_LOWER_32_MASK 0x00000000ffffffff
  60. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_UPPER_32_OFFSET 0x0000000000000000
  61. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_UPPER_32_LSB 32
  62. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_UPPER_32_MSB 63
  63. #define TX_FES_STATUS_START_PPDU_PPDU_TIMESTAMP_UPPER_32_MASK 0xffffffff00000000
  64. #define TX_FES_STATUS_START_PPDU_SUBBAND_MASK_OFFSET 0x0000000000000008
  65. #define TX_FES_STATUS_START_PPDU_SUBBAND_MASK_LSB 0
  66. #define TX_FES_STATUS_START_PPDU_SUBBAND_MASK_MSB 15
  67. #define TX_FES_STATUS_START_PPDU_SUBBAND_MASK_MASK 0x000000000000ffff
  68. #define TX_FES_STATUS_START_PPDU_NDP_FRAME_OFFSET 0x0000000000000008
  69. #define TX_FES_STATUS_START_PPDU_NDP_FRAME_LSB 16
  70. #define TX_FES_STATUS_START_PPDU_NDP_FRAME_MSB 17
  71. #define TX_FES_STATUS_START_PPDU_NDP_FRAME_MASK 0x0000000000030000
  72. #define TX_FES_STATUS_START_PPDU_RESERVED_2B_OFFSET 0x0000000000000008
  73. #define TX_FES_STATUS_START_PPDU_RESERVED_2B_LSB 18
  74. #define TX_FES_STATUS_START_PPDU_RESERVED_2B_MSB 19
  75. #define TX_FES_STATUS_START_PPDU_RESERVED_2B_MASK 0x00000000000c0000
  76. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_BW_OFFSET 0x0000000000000008
  77. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_BW_LSB 20
  78. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_BW_MSB 22
  79. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_BW_MASK 0x0000000000700000
  80. #define TX_FES_STATUS_START_PPDU_COEX_BASED_ANT_MASK_OFFSET 0x0000000000000008
  81. #define TX_FES_STATUS_START_PPDU_COEX_BASED_ANT_MASK_LSB 23
  82. #define TX_FES_STATUS_START_PPDU_COEX_BASED_ANT_MASK_MSB 30
  83. #define TX_FES_STATUS_START_PPDU_COEX_BASED_ANT_MASK_MASK 0x000000007f800000
  84. #define TX_FES_STATUS_START_PPDU_RESERVED_2C_OFFSET 0x0000000000000008
  85. #define TX_FES_STATUS_START_PPDU_RESERVED_2C_LSB 31
  86. #define TX_FES_STATUS_START_PPDU_RESERVED_2C_MSB 31
  87. #define TX_FES_STATUS_START_PPDU_RESERVED_2C_MASK 0x0000000080000000
  88. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_SHARED_ANT_OFFSET 0x0000000000000008
  89. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_SHARED_ANT_LSB 32
  90. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_SHARED_ANT_MSB 39
  91. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_SHARED_ANT_MASK 0x000000ff00000000
  92. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_ANT_OFFSET 0x0000000000000008
  93. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_ANT_LSB 40
  94. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_ANT_MSB 47
  95. #define TX_FES_STATUS_START_PPDU_COEX_BASED_TX_PWR_ANT_MASK 0x0000ff0000000000
  96. #define TX_FES_STATUS_START_PPDU_CONCURRENT_BT_TX_OFFSET 0x0000000000000008
  97. #define TX_FES_STATUS_START_PPDU_CONCURRENT_BT_TX_LSB 48
  98. #define TX_FES_STATUS_START_PPDU_CONCURRENT_BT_TX_MSB 48
  99. #define TX_FES_STATUS_START_PPDU_CONCURRENT_BT_TX_MASK 0x0001000000000000
  100. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WLAN_TX_OFFSET 0x0000000000000008
  101. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WLAN_TX_LSB 49
  102. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WLAN_TX_MSB 49
  103. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WLAN_TX_MASK 0x0002000000000000
  104. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_TX_OFFSET 0x0000000000000008
  105. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_TX_LSB 50
  106. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_TX_MSB 50
  107. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_TX_MASK 0x0004000000000000
  108. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_RX_OFFSET 0x0000000000000008
  109. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_RX_LSB 51
  110. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_RX_MSB 51
  111. #define TX_FES_STATUS_START_PPDU_CONCURRENT_WAN_RX_MASK 0x0008000000000000
  112. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_BT_OFFSET 0x0000000000000008
  113. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_BT_LSB 52
  114. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_BT_MSB 52
  115. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_BT_MASK 0x0010000000000000
  116. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WLAN_OFFSET 0x0000000000000008
  117. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WLAN_LSB 53
  118. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WLAN_MSB 53
  119. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WLAN_MASK 0x0020000000000000
  120. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WAN_OFFSET 0x0000000000000008
  121. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WAN_LSB 54
  122. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WAN_MSB 54
  123. #define TX_FES_STATUS_START_PPDU_COEX_PWR_REDUCTION_WAN_MASK 0x0040000000000000
  124. #define TX_FES_STATUS_START_PPDU_COEX_RESULT_ALT_BASED_OFFSET 0x0000000000000008
  125. #define TX_FES_STATUS_START_PPDU_COEX_RESULT_ALT_BASED_LSB 55
  126. #define TX_FES_STATUS_START_PPDU_COEX_RESULT_ALT_BASED_MSB 55
  127. #define TX_FES_STATUS_START_PPDU_COEX_RESULT_ALT_BASED_MASK 0x0080000000000000
  128. #define TX_FES_STATUS_START_PPDU_REQUEST_PACKET_BW_OFFSET 0x0000000000000008
  129. #define TX_FES_STATUS_START_PPDU_REQUEST_PACKET_BW_LSB 56
  130. #define TX_FES_STATUS_START_PPDU_REQUEST_PACKET_BW_MSB 58
  131. #define TX_FES_STATUS_START_PPDU_REQUEST_PACKET_BW_MASK 0x0700000000000000
  132. #define TX_FES_STATUS_START_PPDU_RESPONSE_TYPE_OFFSET 0x0000000000000008
  133. #define TX_FES_STATUS_START_PPDU_RESPONSE_TYPE_LSB 59
  134. #define TX_FES_STATUS_START_PPDU_RESPONSE_TYPE_MSB 63
  135. #define TX_FES_STATUS_START_PPDU_RESPONSE_TYPE_MASK 0xf800000000000000
  136. #endif