txrx.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433
  1. /* SPDX-License-Identifier: GPL-2.0 OR BSD-3-Clause */
  2. /* Copyright(c) 2020 Realtek Corporation
  3. */
  4. #ifndef __RTW89_TXRX_H__
  5. #define __RTW89_TXRX_H__
  6. #include "debug.h"
  7. #define DATA_RATE_MODE_CTRL_MASK GENMASK(8, 7)
  8. #define DATA_RATE_NOT_HT_IDX_MASK GENMASK(3, 0)
  9. #define DATA_RATE_MODE_NON_HT 0x0
  10. #define DATA_RATE_HT_IDX_MASK GENMASK(4, 0)
  11. #define DATA_RATE_MODE_HT 0x1
  12. #define DATA_RATE_VHT_HE_NSS_MASK GENMASK(6, 4)
  13. #define DATA_RATE_VHT_HE_IDX_MASK GENMASK(3, 0)
  14. #define DATA_RATE_MODE_VHT 0x2
  15. #define DATA_RATE_MODE_HE 0x3
  16. #define GET_DATA_RATE_MODE(r) FIELD_GET(DATA_RATE_MODE_CTRL_MASK, r)
  17. #define GET_DATA_RATE_NOT_HT_IDX(r) FIELD_GET(DATA_RATE_NOT_HT_IDX_MASK, r)
  18. #define GET_DATA_RATE_HT_IDX(r) FIELD_GET(DATA_RATE_HT_IDX_MASK, r)
  19. #define GET_DATA_RATE_VHT_HE_IDX(r) FIELD_GET(DATA_RATE_VHT_HE_IDX_MASK, r)
  20. #define GET_DATA_RATE_NSS(r) FIELD_GET(DATA_RATE_VHT_HE_NSS_MASK, r)
  21. /* TX WD BODY DWORD 0 */
  22. #define RTW89_TXWD_BODY0_WP_OFFSET GENMASK(31, 24)
  23. #define RTW89_TXWD_BODY0_WP_OFFSET_V1 GENMASK(28, 24)
  24. #define RTW89_TXWD_BODY0_MORE_DATA BIT(23)
  25. #define RTW89_TXWD_BODY0_WD_INFO_EN BIT(22)
  26. #define RTW89_TXWD_BODY0_FW_DL BIT(20)
  27. #define RTW89_TXWD_BODY0_CHANNEL_DMA GENMASK(19, 16)
  28. #define RTW89_TXWD_BODY0_HDR_LLC_LEN GENMASK(15, 11)
  29. #define RTW89_TXWD_BODY0_WD_PAGE BIT(7)
  30. #define RTW89_TXWD_BODY0_HW_AMSDU BIT(5)
  31. #define RTW89_TXWD_BODY0_HW_SSN_SEL GENMASK(3, 2)
  32. #define RTW89_TXWD_BODY0_HW_SSN_MODE GENMASK(1, 0)
  33. /* TX WD BODY DWORD 1 */
  34. #define RTW89_TXWD_BODY1_ADDR_INFO_NUM GENMASK(31, 26)
  35. #define RTW89_TXWD_BODY1_PAYLOAD_ID GENMASK(31, 16)
  36. #define RTW89_TXWD_BODY1_SEC_KEYID GENMASK(5, 4)
  37. #define RTW89_TXWD_BODY1_SEC_TYPE GENMASK(3, 0)
  38. /* TX WD BODY DWORD 2 */
  39. #define RTW89_TXWD_BODY2_MACID GENMASK(30, 24)
  40. #define RTW89_TXWD_BODY2_TID_INDICATE BIT(23)
  41. #define RTW89_TXWD_BODY2_QSEL GENMASK(22, 17)
  42. #define RTW89_TXWD_BODY2_TXPKT_SIZE GENMASK(13, 0)
  43. /* TX WD BODY DWORD 3 */
  44. #define RTW89_TXWD_BODY3_BK BIT(13)
  45. #define RTW89_TXWD_BODY3_AGG_EN BIT(12)
  46. #define RTW89_TXWD_BODY3_SW_SEQ GENMASK(11, 0)
  47. /* TX WD BODY DWORD 4 */
  48. #define RTW89_TXWD_BODY4_SEC_IV_L1 GENMASK(31, 24)
  49. #define RTW89_TXWD_BODY4_SEC_IV_L0 GENMASK(23, 16)
  50. /* TX WD BODY DWORD 5 */
  51. #define RTW89_TXWD_BODY5_SEC_IV_H5 GENMASK(31, 24)
  52. #define RTW89_TXWD_BODY5_SEC_IV_H4 GENMASK(23, 16)
  53. #define RTW89_TXWD_BODY5_SEC_IV_H3 GENMASK(15, 8)
  54. #define RTW89_TXWD_BODY5_SEC_IV_H2 GENMASK(7, 0)
  55. /* TX WD BODY DWORD 6 (V1) */
  56. /* TX WD BODY DWORD 7 (V1) */
  57. #define RTW89_TXWD_BODY7_USE_RATE_V1 BIT(31)
  58. #define RTW89_TXWD_BODY7_DATA_BW GENMASK(29, 28)
  59. #define RTW89_TXWD_BODY7_GI_LTF GENMASK(27, 25)
  60. #define RTW89_TXWD_BODY7_DATA_RATE GENMASK(24, 16)
  61. /* TX WD INFO DWORD 0 */
  62. #define RTW89_TXWD_INFO0_USE_RATE BIT(30)
  63. #define RTW89_TXWD_INFO0_DATA_BW GENMASK(29, 28)
  64. #define RTW89_TXWD_INFO0_GI_LTF GENMASK(27, 25)
  65. #define RTW89_TXWD_INFO0_DATA_RATE GENMASK(24, 16)
  66. #define RTW89_TXWD_INFO0_DISDATAFB BIT(10)
  67. #define RTW89_TXWD_INFO0_MULTIPORT_ID GENMASK(6, 4)
  68. /* TX WD INFO DWORD 1 */
  69. #define RTW89_TXWD_INFO1_DATA_RTY_LOWEST_RATE GENMASK(24, 16)
  70. #define RTW89_TXWD_INFO1_A_CTRL_BSR BIT(14)
  71. #define RTW89_TXWD_INFO1_MAX_AGGNUM GENMASK(7, 0)
  72. /* TX WD INFO DWORD 2 */
  73. #define RTW89_TXWD_INFO2_AMPDU_DENSITY GENMASK(20, 18)
  74. #define RTW89_TXWD_INFO2_SEC_TYPE GENMASK(12, 9)
  75. #define RTW89_TXWD_INFO2_SEC_HW_ENC BIT(8)
  76. #define RTW89_TXWD_INFO2_FORCE_KEY_EN BIT(8)
  77. #define RTW89_TXWD_INFO2_SEC_CAM_IDX GENMASK(7, 0)
  78. /* TX WD INFO DWORD 3 */
  79. /* TX WD INFO DWORD 4 */
  80. #define RTW89_TXWD_INFO4_RTS_EN BIT(27)
  81. #define RTW89_TXWD_INFO4_HW_RTS_EN BIT(31)
  82. /* TX WD INFO DWORD 5 */
  83. /* RX WD dword0 */
  84. #define AX_RXD_RPKT_LEN_MASK GENMASK(13, 0)
  85. #define AX_RXD_SHIFT_MASK GENMASK(15, 14)
  86. #define AX_RXD_WL_HD_IV_LEN_MASK GENMASK(21, 16)
  87. #define AX_RXD_BB_SEL BIT(22)
  88. #define AX_RXD_MAC_INFO_VLD BIT(23)
  89. #define AX_RXD_RPKT_TYPE_MASK GENMASK(27, 24)
  90. #define AX_RXD_DRV_INFO_SIZE_MASK GENMASK(30, 28)
  91. #define AX_RXD_LONG_RXD BIT(31)
  92. /* RX WD dword1 */
  93. #define AX_RXD_PPDU_TYPE_MASK GENMASK(3, 0)
  94. #define AX_RXD_PPDU_CNT_MASK GENMASK(6, 4)
  95. #define AX_RXD_SR_EN BIT(7)
  96. #define AX_RXD_USER_ID_MASK GENMASK(15, 8)
  97. #define AX_RXD_USER_ID_v1_MASK GENMASK(13, 8)
  98. #define AX_RXD_RX_DATARATE_MASK GENMASK(24, 16)
  99. #define AX_RXD_RX_GI_LTF_MASK GENMASK(27, 25)
  100. #define AX_RXD_NON_SRG_PPDU BIT(28)
  101. #define AX_RXD_INTER_PPDU BIT(29)
  102. #define AX_RXD_NON_SRG_PPDU_v1 BIT(14)
  103. #define AX_RXD_INTER_PPDU_v1 BIT(15)
  104. #define AX_RXD_BW_MASK GENMASK(31, 30)
  105. #define AX_RXD_BW_v1_MASK GENMASK(31, 29)
  106. /* RX WD dword2 */
  107. #define AX_RXD_FREERUN_CNT_MASK GENMASK(31, 0)
  108. /* RX WD dword3 */
  109. #define AX_RXD_A1_MATCH BIT(0)
  110. #define AX_RXD_SW_DEC BIT(1)
  111. #define AX_RXD_HW_DEC BIT(2)
  112. #define AX_RXD_AMPDU BIT(3)
  113. #define AX_RXD_AMPDU_END_PKT BIT(4)
  114. #define AX_RXD_AMSDU BIT(5)
  115. #define AX_RXD_AMSDU_CUT BIT(6)
  116. #define AX_RXD_LAST_MSDU BIT(7)
  117. #define AX_RXD_BYPASS BIT(8)
  118. #define AX_RXD_CRC32_ERR BIT(9)
  119. #define AX_RXD_ICV_ERR BIT(10)
  120. #define AX_RXD_MAGIC_WAKE BIT(11)
  121. #define AX_RXD_UNICAST_WAKE BIT(12)
  122. #define AX_RXD_PATTERN_WAKE BIT(13)
  123. #define AX_RXD_GET_CH_INFO_MASK GENMASK(15, 14)
  124. #define AX_RXD_PATTERN_IDX_MASK GENMASK(20, 16)
  125. #define AX_RXD_TARGET_IDC_MASK GENMASK(23, 21)
  126. #define AX_RXD_CHKSUM_OFFLOAD_EN BIT(24)
  127. #define AX_RXD_WITH_LLC BIT(25)
  128. #define AX_RXD_RX_STATISTICS BIT(26)
  129. /* RX WD dword4 */
  130. #define AX_RXD_TYPE_MASK GENMASK(1, 0)
  131. #define AX_RXD_MC BIT(2)
  132. #define AX_RXD_BC BIT(3)
  133. #define AX_RXD_MD BIT(4)
  134. #define AX_RXD_MF BIT(5)
  135. #define AX_RXD_PWR BIT(6)
  136. #define AX_RXD_QOS BIT(7)
  137. #define AX_RXD_TID_MASK GENMASK(11, 8)
  138. #define AX_RXD_EOSP BIT(12)
  139. #define AX_RXD_HTC BIT(13)
  140. #define AX_RXD_QNULL BIT(14)
  141. #define AX_RXD_SEQ_MASK GENMASK(27, 16)
  142. #define AX_RXD_FRAG_MASK GENMASK(31, 28)
  143. /* RX WD dword5 */
  144. #define AX_RXD_SEC_CAM_IDX_MASK GENMASK(7, 0)
  145. #define AX_RXD_ADDR_CAM_MASK GENMASK(15, 8)
  146. #define AX_RXD_MAC_ID_MASK GENMASK(23, 16)
  147. #define AX_RXD_RX_PL_ID_MASK GENMASK(27, 24)
  148. #define AX_RXD_ADDR_CAM_VLD BIT(28)
  149. #define AX_RXD_ADDR_FWD_EN BIT(29)
  150. #define AX_RXD_RX_PL_MATCH BIT(30)
  151. /* RX WD dword6 */
  152. #define AX_RXD_MAC_ADDR_MASK GENMASK(31, 0)
  153. /* RX WD dword7 */
  154. #define AX_RXD_MAC_ADDR_H_MASK GENMASK(15, 0)
  155. #define AX_RXD_SMART_ANT BIT(16)
  156. #define AX_RXD_SEC_TYPE_MASK GENMASK(20, 17)
  157. #define AX_RXD_HDR_CNV BIT(21)
  158. #define AX_RXD_HDR_OFFSET_MASK GENMASK(26, 22)
  159. #define AX_RXD_BIP_KEYID BIT(27)
  160. #define AX_RXD_BIP_ENC BIT(28)
  161. /* RX DESC helpers */
  162. /* Short Descriptor */
  163. #define RTW89_GET_RXWD_LONG_RXD(rxdesc) \
  164. le32_get_bits((rxdesc)->dword0, BIT(31))
  165. #define RTW89_GET_RXWD_DRV_INFO_SIZE(rxdesc) \
  166. le32_get_bits((rxdesc)->dword0, GENMASK(30, 28))
  167. #define RTW89_GET_RXWD_RPKT_TYPE(rxdesc) \
  168. le32_get_bits((rxdesc)->dword0, GENMASK(27, 24))
  169. #define RTW89_GET_RXWD_MAC_INFO_VALID(rxdesc) \
  170. le32_get_bits((rxdesc)->dword0, BIT(23))
  171. #define RTW89_GET_RXWD_BB_SEL(rxdesc) \
  172. le32_get_bits((rxdesc)->dword0, BIT(22))
  173. #define RTW89_GET_RXWD_HD_IV_LEN(rxdesc) \
  174. le32_get_bits((rxdesc)->dword0, GENMASK(21, 16))
  175. #define RTW89_GET_RXWD_SHIFT(rxdesc) \
  176. le32_get_bits((rxdesc)->dword0, GENMASK(15, 14))
  177. #define RTW89_GET_RXWD_PKT_SIZE(rxdesc) \
  178. le32_get_bits((rxdesc)->dword0, GENMASK(13, 0))
  179. #define RTW89_GET_RXWD_BW(rxdesc) \
  180. le32_get_bits((rxdesc)->dword1, GENMASK(31, 30))
  181. #define RTW89_GET_RXWD_BW_V1(rxdesc) \
  182. le32_get_bits((rxdesc)->dword1, GENMASK(31, 29))
  183. #define RTW89_GET_RXWD_GI_LTF(rxdesc) \
  184. le32_get_bits((rxdesc)->dword1, GENMASK(27, 25))
  185. #define RTW89_GET_RXWD_DATA_RATE(rxdesc) \
  186. le32_get_bits((rxdesc)->dword1, GENMASK(24, 16))
  187. #define RTW89_GET_RXWD_USER_ID(rxdesc) \
  188. le32_get_bits((rxdesc)->dword1, GENMASK(15, 8))
  189. #define RTW89_GET_RXWD_SR_EN(rxdesc) \
  190. le32_get_bits((rxdesc)->dword1, BIT(7))
  191. #define RTW89_GET_RXWD_PPDU_CNT(rxdesc) \
  192. le32_get_bits((rxdesc)->dword1, GENMASK(6, 4))
  193. #define RTW89_GET_RXWD_PPDU_TYPE(rxdesc) \
  194. le32_get_bits((rxdesc)->dword1, GENMASK(3, 0))
  195. #define RTW89_GET_RXWD_FREE_RUN_CNT(rxdesc) \
  196. le32_get_bits((rxdesc)->dword2, GENMASK(31, 0))
  197. #define RTW89_GET_RXWD_ICV_ERR(rxdesc) \
  198. le32_get_bits((rxdesc)->dword3, BIT(10))
  199. #define RTW89_GET_RXWD_CRC32_ERR(rxdesc) \
  200. le32_get_bits((rxdesc)->dword3, BIT(9))
  201. #define RTW89_GET_RXWD_HW_DEC(rxdesc) \
  202. le32_get_bits((rxdesc)->dword3, BIT(2))
  203. #define RTW89_GET_RXWD_SW_DEC(rxdesc) \
  204. le32_get_bits((rxdesc)->dword3, BIT(1))
  205. #define RTW89_GET_RXWD_A1_MATCH(rxdesc) \
  206. le32_get_bits((rxdesc)->dword3, BIT(0))
  207. /* Long Descriptor */
  208. #define RTW89_GET_RXWD_FRAG(rxdesc) \
  209. le32_get_bits((rxdesc)->dword4, GENMASK(31, 28))
  210. #define RTW89_GET_RXWD_SEQ(rxdesc) \
  211. le32_get_bits((rxdesc)->dword4, GENMASK(27, 16))
  212. #define RTW89_GET_RXWD_TYPE(rxdesc) \
  213. le32_get_bits((rxdesc)->dword4, GENMASK(1, 0))
  214. #define RTW89_GET_RXWD_ADDR_CAM_VLD(rxdesc) \
  215. le32_get_bits((rxdesc)->dword5, BIT(28))
  216. #define RTW89_GET_RXWD_RX_PL_ID(rxdesc) \
  217. le32_get_bits((rxdesc)->dword5, GENMASK(27, 24))
  218. #define RTW89_GET_RXWD_MAC_ID(rxdesc) \
  219. le32_get_bits((rxdesc)->dword5, GENMASK(23, 16))
  220. #define RTW89_GET_RXWD_ADDR_CAM_ID(rxdesc) \
  221. le32_get_bits((rxdesc)->dword5, GENMASK(15, 8))
  222. #define RTW89_GET_RXWD_SEC_CAM_ID(rxdesc) \
  223. le32_get_bits((rxdesc)->dword5, GENMASK(7, 0))
  224. #define RTW89_GET_RXINFO_USR_NUM(rpt) \
  225. le32_get_bits(*((const __le32 *)rpt), GENMASK(3, 0))
  226. #define RTW89_GET_RXINFO_FW_DEFINE(rpt) \
  227. le32_get_bits(*((const __le32 *)rpt), GENMASK(15, 8))
  228. #define RTW89_GET_RXINFO_LSIG_LEN(rpt) \
  229. le32_get_bits(*((const __le32 *)rpt), GENMASK(27, 16))
  230. #define RTW89_GET_RXINFO_IS_TO_SELF(rpt) \
  231. le32_get_bits(*((const __le32 *)rpt), BIT(28))
  232. #define RTW89_GET_RXINFO_RX_CNT_VLD(rpt) \
  233. le32_get_bits(*((const __le32 *)rpt), BIT(29))
  234. #define RTW89_GET_RXINFO_LONG_RXD(rpt) \
  235. le32_get_bits(*((const __le32 *)rpt), GENMASK(31, 30))
  236. #define RTW89_GET_RXINFO_SERVICE(rpt) \
  237. le32_get_bits(*((const __le32 *)(rpt) + 1), GENMASK(15, 0))
  238. #define RTW89_GET_RXINFO_PLCP_LEN(rpt) \
  239. le32_get_bits(*((const __le32 *)(rpt) + 1), GENMASK(23, 16))
  240. #define RTW89_GET_RXINFO_MAC_ID_VALID(rpt, usr) \
  241. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), BIT(0))
  242. #define RTW89_GET_RXINFO_DATA(rpt, usr) \
  243. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), BIT(1))
  244. #define RTW89_GET_RXINFO_CTRL(rpt, usr) \
  245. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), BIT(2))
  246. #define RTW89_GET_RXINFO_MGMT(rpt, usr) \
  247. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), BIT(3))
  248. #define RTW89_GET_RXINFO_BCM(rpt, usr) \
  249. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), BIT(4))
  250. #define RTW89_GET_RXINFO_MACID(rpt, usr) \
  251. le32_get_bits(*((const __le32 *)(rpt) + (usr) + 2), GENMASK(15, 8))
  252. #define RTW89_GET_PHY_STS_IE_MAP(sts) \
  253. le32_get_bits(*((const __le32 *)(sts)), GENMASK(4, 0))
  254. #define RTW89_GET_PHY_STS_RSSI_A(sts) \
  255. le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(7, 0))
  256. #define RTW89_GET_PHY_STS_RSSI_B(sts) \
  257. le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(15, 8))
  258. #define RTW89_GET_PHY_STS_RSSI_C(sts) \
  259. le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(23, 16))
  260. #define RTW89_GET_PHY_STS_RSSI_D(sts) \
  261. le32_get_bits(*((const __le32 *)(sts) + 1), GENMASK(31, 24))
  262. #define RTW89_GET_PHY_STS_LEN(sts) \
  263. le32_get_bits(*((const __le32 *)sts), GENMASK(15, 8))
  264. #define RTW89_GET_PHY_STS_RSSI_AVG(sts) \
  265. le32_get_bits(*((const __le32 *)sts), GENMASK(31, 24))
  266. #define RTW89_GET_PHY_STS_IE_TYPE(ie) \
  267. le32_get_bits(*((const __le32 *)ie), GENMASK(4, 0))
  268. #define RTW89_GET_PHY_STS_IE_LEN(ie) \
  269. le32_get_bits(*((const __le32 *)ie), GENMASK(11, 5))
  270. #define RTW89_GET_PHY_STS_IE01_CH_IDX(ie) \
  271. le32_get_bits(*((const __le32 *)ie), GENMASK(23, 16))
  272. #define RTW89_GET_PHY_STS_IE01_CFO(ie) \
  273. le32_get_bits(*((const __le32 *)(ie) + 1), GENMASK(31, 20))
  274. enum rtw89_tx_channel {
  275. RTW89_TXCH_ACH0 = 0,
  276. RTW89_TXCH_ACH1 = 1,
  277. RTW89_TXCH_ACH2 = 2,
  278. RTW89_TXCH_ACH3 = 3,
  279. RTW89_TXCH_ACH4 = 4,
  280. RTW89_TXCH_ACH5 = 5,
  281. RTW89_TXCH_ACH6 = 6,
  282. RTW89_TXCH_ACH7 = 7,
  283. RTW89_TXCH_CH8 = 8, /* MGMT Band 0 */
  284. RTW89_TXCH_CH9 = 9, /* HI Band 0 */
  285. RTW89_TXCH_CH10 = 10, /* MGMT Band 1 */
  286. RTW89_TXCH_CH11 = 11, /* HI Band 1 */
  287. RTW89_TXCH_CH12 = 12, /* FW CMD */
  288. /* keep last */
  289. RTW89_TXCH_NUM,
  290. RTW89_TXCH_MAX = RTW89_TXCH_NUM - 1
  291. };
  292. enum rtw89_rx_channel {
  293. RTW89_RXCH_RXQ = 0,
  294. RTW89_RXCH_RPQ = 1,
  295. /* keep last */
  296. RTW89_RXCH_NUM,
  297. RTW89_RXCH_MAX = RTW89_RXCH_NUM - 1
  298. };
  299. enum rtw89_tx_qsel {
  300. RTW89_TX_QSEL_BE_0 = 0x00,
  301. RTW89_TX_QSEL_BK_0 = 0x01,
  302. RTW89_TX_QSEL_VI_0 = 0x02,
  303. RTW89_TX_QSEL_VO_0 = 0x03,
  304. RTW89_TX_QSEL_BE_1 = 0x04,
  305. RTW89_TX_QSEL_BK_1 = 0x05,
  306. RTW89_TX_QSEL_VI_1 = 0x06,
  307. RTW89_TX_QSEL_VO_1 = 0x07,
  308. RTW89_TX_QSEL_BE_2 = 0x08,
  309. RTW89_TX_QSEL_BK_2 = 0x09,
  310. RTW89_TX_QSEL_VI_2 = 0x0a,
  311. RTW89_TX_QSEL_VO_2 = 0x0b,
  312. RTW89_TX_QSEL_BE_3 = 0x0c,
  313. RTW89_TX_QSEL_BK_3 = 0x0d,
  314. RTW89_TX_QSEL_VI_3 = 0x0e,
  315. RTW89_TX_QSEL_VO_3 = 0x0f,
  316. RTW89_TX_QSEL_B0_BCN = 0x10,
  317. RTW89_TX_QSEL_B0_HI = 0x11,
  318. RTW89_TX_QSEL_B0_MGMT = 0x12,
  319. RTW89_TX_QSEL_B0_NOPS = 0x13,
  320. RTW89_TX_QSEL_B0_MGMT_FAST = 0x14,
  321. /* reserved */
  322. /* reserved */
  323. /* reserved */
  324. RTW89_TX_QSEL_B1_BCN = 0x18,
  325. RTW89_TX_QSEL_B1_HI = 0x19,
  326. RTW89_TX_QSEL_B1_MGMT = 0x1a,
  327. RTW89_TX_QSEL_B1_NOPS = 0x1b,
  328. RTW89_TX_QSEL_B1_MGMT_FAST = 0x1c,
  329. /* reserved */
  330. /* reserved */
  331. /* reserved */
  332. };
  333. static inline u8 rtw89_core_get_qsel(struct rtw89_dev *rtwdev, u8 tid)
  334. {
  335. switch (tid) {
  336. default:
  337. rtw89_warn(rtwdev, "Should use tag 1d: %d\n", tid);
  338. fallthrough;
  339. case 0:
  340. case 3:
  341. return RTW89_TX_QSEL_BE_0;
  342. case 1:
  343. case 2:
  344. return RTW89_TX_QSEL_BK_0;
  345. case 4:
  346. case 5:
  347. return RTW89_TX_QSEL_VI_0;
  348. case 6:
  349. case 7:
  350. return RTW89_TX_QSEL_VO_0;
  351. }
  352. }
  353. static inline u8 rtw89_core_get_ch_dma(struct rtw89_dev *rtwdev, u8 qsel)
  354. {
  355. switch (qsel) {
  356. default:
  357. rtw89_warn(rtwdev, "Cannot map qsel to dma: %d\n", qsel);
  358. fallthrough;
  359. case RTW89_TX_QSEL_BE_0:
  360. return RTW89_TXCH_ACH0;
  361. case RTW89_TX_QSEL_BK_0:
  362. return RTW89_TXCH_ACH1;
  363. case RTW89_TX_QSEL_VI_0:
  364. return RTW89_TXCH_ACH2;
  365. case RTW89_TX_QSEL_VO_0:
  366. return RTW89_TXCH_ACH3;
  367. case RTW89_TX_QSEL_B0_MGMT:
  368. return RTW89_TXCH_CH8;
  369. case RTW89_TX_QSEL_B0_HI:
  370. return RTW89_TXCH_CH9;
  371. case RTW89_TX_QSEL_B1_MGMT:
  372. return RTW89_TXCH_CH10;
  373. case RTW89_TX_QSEL_B1_HI:
  374. return RTW89_TXCH_CH11;
  375. }
  376. }
  377. static inline u8 rtw89_core_get_tid_indicate(struct rtw89_dev *rtwdev, u8 tid)
  378. {
  379. switch (tid) {
  380. case 3:
  381. case 2:
  382. case 5:
  383. case 7:
  384. return 1;
  385. default:
  386. rtw89_warn(rtwdev, "Should use tag 1d: %d\n", tid);
  387. fallthrough;
  388. case 0:
  389. case 1:
  390. case 4:
  391. case 6:
  392. return 0;
  393. }
  394. }
  395. #endif