tcl_data_cmd.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842
  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. // $ATH_LICENSE_HW_HDR_C$
  19. //
  20. // DO NOT EDIT! This file is automatically generated
  21. // These definitions are tied to a particular hardware layout
  22. #ifndef _TCL_DATA_CMD_H_
  23. #define _TCL_DATA_CMD_H_
  24. #if !defined(__ASSEMBLER__)
  25. #endif
  26. #include "buffer_addr_info.h"
  27. // ################ START SUMMARY #################
  28. //
  29. // Dword Fields
  30. // 0-1 struct buffer_addr_info buf_addr_info;
  31. // 2 buf_or_ext_desc_type[0], epd[1], encap_type[3:2], encrypt_type[7:4], src_buffer_swap[8], link_meta_swap[9], reserved[13:10], addrx_en[14], addry_en[15], tcl_cmd_number[31:16]
  32. // 3 data_length[15:0], ipv4_checksum_en[16], udp_over_ipv4_checksum_en[17], udp_over_ipv6_checksum_en[18], tcp_over_ipv4_checksum_en[19], tcp_over_ipv6_checksum_en[20], to_fw[21], dscp_to_tid_priority_table_id[22], packet_offset[31:23]
  33. // 4 buffer_timestamp[18:0], buffer_timestamp_valid[19], mesh_enable[20], hlos_tid_overwrite[21], hlos_tid[25:22], reserved_4[31:26]
  34. // 5 reserved_5[31:0]
  35. // 6 reserved_6a[19:0], ring_id[27:20], looping_count[31:28]
  36. //
  37. // ################ END SUMMARY #################
  38. #define NUM_OF_DWORDS_TCL_DATA_CMD 7
  39. struct tcl_data_cmd {
  40. struct buffer_addr_info buf_addr_info;
  41. uint32_t buf_or_ext_desc_type : 1, //[0]
  42. epd : 1, //[1]
  43. encap_type : 2, //[3:2]
  44. encrypt_type : 4, //[7:4]
  45. src_buffer_swap : 1, //[8]
  46. link_meta_swap : 1, //[9]
  47. reserved : 4, //[13:10]
  48. addrx_en : 1, //[14]
  49. addry_en : 1, //[15]
  50. tcl_cmd_number : 16; //[31:16]
  51. uint32_t data_length : 16, //[15:0]
  52. ipv4_checksum_en : 1, //[16]
  53. udp_over_ipv4_checksum_en : 1, //[17]
  54. udp_over_ipv6_checksum_en : 1, //[18]
  55. tcp_over_ipv4_checksum_en : 1, //[19]
  56. tcp_over_ipv6_checksum_en : 1, //[20]
  57. to_fw : 1, //[21]
  58. dscp_to_tid_priority_table_id : 1, //[22]
  59. packet_offset : 9; //[31:23]
  60. uint32_t buffer_timestamp : 19, //[18:0]
  61. buffer_timestamp_valid : 1, //[19]
  62. mesh_enable : 1, //[20]
  63. hlos_tid_overwrite : 1, //[21]
  64. hlos_tid : 4, //[25:22]
  65. reserved_4 : 6; //[31:26]
  66. uint32_t reserved_5 : 32; //[31:0]
  67. uint32_t reserved_6a : 20, //[19:0]
  68. ring_id : 8, //[27:20]
  69. looping_count : 4; //[31:28]
  70. };
  71. /*
  72. struct buffer_addr_info buf_addr_info
  73. Details of the physical address for a single buffer
  74. It also contains return ownership info as well as some
  75. meta data for SW related to this buffer.
  76. In case of Buf_or_ext_desc_type indicating
  77. 'MSDU_buffer', this address indicates the start of the meta
  78. data that is preceding the actual packet data.
  79. The start of the actual packet data is provided by
  80. field: Packet_offset
  81. buf_or_ext_desc_type
  82. <enum 0 MSDU_buffer> The address points to an MSDU
  83. buffer.
  84. <enum 1 extension_descriptor> The address points to an
  85. MSDU link extension descriptor
  86. < legal all>
  87. epd
  88. When this bit is set then input packet is an EPD type
  89. <legal all>
  90. encap_type
  91. Indicates the encapsulation that HW will perform:
  92. <enum 0 RAW> No encapsulation
  93. <enum 1 Native_WiFi>
  94. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  95. SNAP/LLC)
  96. <enum 3 802_3> DO NOT USE. Indicate Ethernet
  97. Used by the OLE during encapsulation.
  98. <legal all>
  99. encrypt_type
  100. Field only valid for encap_type: RAW
  101. Indicates type of decrypt cipher used (as defined in the
  102. peer entry)
  103. <enum 0 wep_40> WEP 40-bit
  104. <enum 1 wep_104> WEP 104-bit
  105. <enum 2 tkip_no_mic> TKIP without MIC
  106. <enum 3 wep_128> WEP 128-bit
  107. <enum 4 tkip_with_mic> TKIP with MIC
  108. <enum 5 wapi> WAPI
  109. <enum 6 aes_ccmp_128> AES CCMP 128
  110. <enum 7 no_cipher> No crypto
  111. <enum 8 aes_ccmp_256> AES CCMP 256
  112. <enum 9 aes_gcmp_128> AES CCMP 128
  113. <enum 10 aes_gcmp_256> AES CCMP 256
  114. <enum 11 wapi_gcm_sm4> WAPI GCM SM4
  115. <legal 0-11>
  116. src_buffer_swap
  117. Treats source memory (packet buffer) organization as
  118. big-endian. The packets are read and byte swapped.
  119. 1'b0: Source memory is little endian
  120. 1'b1: Source memory is big endian
  121. <legal all>
  122. link_meta_swap
  123. Treats link descriptor and Metadata as big-endian. The
  124. link descriptor/Metadata is read and byte swapped.
  125. 1'b0: Memory is little endian
  126. 1'b1: Memory is big endian
  127. <legal all>
  128. reserved
  129. <legal 0>
  130. addrx_en
  131. Address X search enable in ASE
  132. 1'b0: Search disable
  133. 1'b1: Search Enable
  134. <legal all>
  135. addry_en
  136. Address Y search enable in ASE
  137. 1'b0: Search disable
  138. 1'b1: Search Enable
  139. <legal all>
  140. tcl_cmd_number
  141. This number can be used by SW to track, identify and
  142. link the created commands with the command statuses
  143. Is set to the value 'TCL_CMD_Number' of the related
  144. TCL_DATA command
  145. <legal all>
  146. data_length
  147. Valid Data length in bytes.
  148. MSDU length in case of direct descriptor.
  149. Length of link extension descriptor in case of Link
  150. extension descriptor. This is used to know the size of
  151. Metadata.
  152. <legal all>
  153. ipv4_checksum_en
  154. OLE related control
  155. Enable IPv4 checksum replacement
  156. udp_over_ipv4_checksum_en
  157. OLE related control
  158. Enable UDP over IPv4 checksum replacement. UDP checksum
  159. over IPv4 is optional for TCP/IP stacks.
  160. udp_over_ipv6_checksum_en
  161. OLE related control
  162. Enable UDP over IPv6 checksum replacement. UDP checksum
  163. over IPv6 is mandatory for TCP/IP stacks.
  164. tcp_over_ipv4_checksum_en
  165. OLE related control
  166. Enable TCP checksum over IPv4 replacement
  167. tcp_over_ipv6_checksum_en
  168. OLE related control
  169. Enable TCP checksum over IPv6 replacement
  170. to_fw
  171. Forward packet to FW along with classification result.
  172. The packet will not be forward to TQM when this bit is set
  173. 1'b0: Use classification result to forward the packet.
  174. 1'b1: Override classification result and forward packet
  175. only to FW.
  176. dscp_to_tid_priority_table_id
  177. The DSCP to tid conversion table to be used for this
  178. frame
  179. <legal all>
  180. packet_offset
  181. Packet offset from Metadata in case of direct buffer
  182. descriptor. This field is valid when Buf_or_ext_desc_type is
  183. reset(= 0).
  184. <legal all>
  185. buffer_timestamp
  186. Field only valid when 'Buffer_timestamp_valid ' is set.
  187. Frame system entrance timestamp. The timestamp is
  188. related to the global system timer
  189. Generally the first module (SW, TCL or TQM). that sees
  190. this frame and this timestamp field is not valid, shall fill
  191. in this field.
  192. Timestamp in units of 1024 us
  193. buffer_timestamp_valid
  194. When set, the Buffer_timestamp field contains valid
  195. info.
  196. mesh_enable
  197. If set to 1:
  198. * For raw WiFi frames, this indicates transmission to a
  199. mesh STA, enabling the interpretation of the 'Mesh Control
  200. Present' bit (bit 8) of QoS Control (otherwise this bit is
  201. ignored),
  202. * For native WiFi frames, this indicates that a 'Mesh
  203. Control' field is present between the header and the LLC.
  204. hlos_tid_overwrite
  205. When set, TCL shall ignore the IP DSCP and VLAN PCP
  206. fields and use HLOS_TID as the final TID. Otherwise TCL
  207. shall consider the DSCP and PCP fields as well as HLOS_TID
  208. and choose a final TID based on the configured priority
  209. <legal all>
  210. hlos_tid
  211. HLOS MSDU priority
  212. Field is used when HLOS_TID_overwrite is set.
  213. Field is also used when HLOS_TID_overwrite is not set
  214. and DSCP/PCP is not available in the packet
  215. <legal all>
  216. reserved_4
  217. <legal 0>
  218. reserved_5
  219. <legal 0>
  220. reserved_6a
  221. <legal 0>
  222. ring_id
  223. The buffer pointer ring ID.
  224. 0 refers to the IDLE ring
  225. 1 - N refers to other rings
  226. Helps with debugging when dumping ring contents.
  227. <legal all>
  228. looping_count
  229. A count value that indicates the number of times the
  230. producer of entries into the Ring has looped around the
  231. ring.
  232. At initialization time, this value is set to 0. On the
  233. first loop, this value is set to 1. After the max value is
  234. reached allowed by the number of bits for this field, the
  235. count value continues with 0 again.
  236. In case SW is the consumer of the ring entries, it can
  237. use this field to figure out up to where the producer of
  238. entries has created new entries. This eliminates the need to
  239. check where the head pointer' of the ring is located once
  240. the SW starts processing an interrupt indicating that new
  241. entries have been put into this ring...
  242. Also note that SW if it wants only needs to look at the
  243. LSB bit of this count value.
  244. <legal all>
  245. */
  246. #define TCL_DATA_CMD_0_BUFFER_ADDR_INFO_BUF_ADDR_INFO_OFFSET 0x00000000
  247. #define TCL_DATA_CMD_0_BUFFER_ADDR_INFO_BUF_ADDR_INFO_LSB 28
  248. #define TCL_DATA_CMD_0_BUFFER_ADDR_INFO_BUF_ADDR_INFO_MASK 0xffffffff
  249. #define TCL_DATA_CMD_1_BUFFER_ADDR_INFO_BUF_ADDR_INFO_OFFSET 0x00000004
  250. #define TCL_DATA_CMD_1_BUFFER_ADDR_INFO_BUF_ADDR_INFO_LSB 28
  251. #define TCL_DATA_CMD_1_BUFFER_ADDR_INFO_BUF_ADDR_INFO_MASK 0xffffffff
  252. /* Description TCL_DATA_CMD_2_BUF_OR_EXT_DESC_TYPE
  253. <enum 0 MSDU_buffer> The address points to an MSDU
  254. buffer.
  255. <enum 1 extension_descriptor> The address points to an
  256. MSDU link extension descriptor
  257. < legal all>
  258. */
  259. #define TCL_DATA_CMD_2_BUF_OR_EXT_DESC_TYPE_OFFSET 0x00000008
  260. #define TCL_DATA_CMD_2_BUF_OR_EXT_DESC_TYPE_LSB 0
  261. #define TCL_DATA_CMD_2_BUF_OR_EXT_DESC_TYPE_MASK 0x00000001
  262. /* Description TCL_DATA_CMD_2_EPD
  263. When this bit is set then input packet is an EPD type
  264. <legal all>
  265. */
  266. #define TCL_DATA_CMD_2_EPD_OFFSET 0x00000008
  267. #define TCL_DATA_CMD_2_EPD_LSB 1
  268. #define TCL_DATA_CMD_2_EPD_MASK 0x00000002
  269. /* Description TCL_DATA_CMD_2_ENCAP_TYPE
  270. Indicates the encapsulation that HW will perform:
  271. <enum 0 RAW> No encapsulation
  272. <enum 1 Native_WiFi>
  273. <enum 2 Ethernet> Ethernet 2 (DIX) or 802.3 (uses
  274. SNAP/LLC)
  275. <enum 3 802_3> DO NOT USE. Indicate Ethernet
  276. Used by the OLE during encapsulation.
  277. <legal all>
  278. */
  279. #define TCL_DATA_CMD_2_ENCAP_TYPE_OFFSET 0x00000008
  280. #define TCL_DATA_CMD_2_ENCAP_TYPE_LSB 2
  281. #define TCL_DATA_CMD_2_ENCAP_TYPE_MASK 0x0000000c
  282. /* Description TCL_DATA_CMD_2_ENCRYPT_TYPE
  283. Field only valid for encap_type: RAW
  284. Indicates type of decrypt cipher used (as defined in the
  285. peer entry)
  286. <enum 0 wep_40> WEP 40-bit
  287. <enum 1 wep_104> WEP 104-bit
  288. <enum 2 tkip_no_mic> TKIP without MIC
  289. <enum 3 wep_128> WEP 128-bit
  290. <enum 4 tkip_with_mic> TKIP with MIC
  291. <enum 5 wapi> WAPI
  292. <enum 6 aes_ccmp_128> AES CCMP 128
  293. <enum 7 no_cipher> No crypto
  294. <enum 8 aes_ccmp_256> AES CCMP 256
  295. <enum 9 aes_gcmp_128> AES CCMP 128
  296. <enum 10 aes_gcmp_256> AES CCMP 256
  297. <enum 11 wapi_gcm_sm4> WAPI GCM SM4
  298. <legal 0-11>
  299. */
  300. #define TCL_DATA_CMD_2_ENCRYPT_TYPE_OFFSET 0x00000008
  301. #define TCL_DATA_CMD_2_ENCRYPT_TYPE_LSB 4
  302. #define TCL_DATA_CMD_2_ENCRYPT_TYPE_MASK 0x000000f0
  303. /* Description TCL_DATA_CMD_2_SRC_BUFFER_SWAP
  304. Treats source memory (packet buffer) organization as
  305. big-endian. The packets are read and byte swapped.
  306. 1'b0: Source memory is little endian
  307. 1'b1: Source memory is big endian
  308. <legal all>
  309. */
  310. #define TCL_DATA_CMD_2_SRC_BUFFER_SWAP_OFFSET 0x00000008
  311. #define TCL_DATA_CMD_2_SRC_BUFFER_SWAP_LSB 8
  312. #define TCL_DATA_CMD_2_SRC_BUFFER_SWAP_MASK 0x00000100
  313. /* Description TCL_DATA_CMD_2_LINK_META_SWAP
  314. Treats link descriptor and Metadata as big-endian. The
  315. link descriptor/Metadata is read and byte swapped.
  316. 1'b0: Memory is little endian
  317. 1'b1: Memory is big endian
  318. <legal all>
  319. */
  320. #define TCL_DATA_CMD_2_LINK_META_SWAP_OFFSET 0x00000008
  321. #define TCL_DATA_CMD_2_LINK_META_SWAP_LSB 9
  322. #define TCL_DATA_CMD_2_LINK_META_SWAP_MASK 0x00000200
  323. /* Description TCL_DATA_CMD_2_RESERVED
  324. <legal 0>
  325. */
  326. #define TCL_DATA_CMD_2_RESERVED_OFFSET 0x00000008
  327. #define TCL_DATA_CMD_2_RESERVED_LSB 10
  328. #define TCL_DATA_CMD_2_RESERVED_MASK 0x00003c00
  329. /* Description TCL_DATA_CMD_2_ADDRX_EN
  330. Address X search enable in ASE
  331. 1'b0: Search disable
  332. 1'b1: Search Enable
  333. <legal all>
  334. */
  335. #define TCL_DATA_CMD_2_ADDRX_EN_OFFSET 0x00000008
  336. #define TCL_DATA_CMD_2_ADDRX_EN_LSB 14
  337. #define TCL_DATA_CMD_2_ADDRX_EN_MASK 0x00004000
  338. /* Description TCL_DATA_CMD_2_ADDRY_EN
  339. Address Y search enable in ASE
  340. 1'b0: Search disable
  341. 1'b1: Search Enable
  342. <legal all>
  343. */
  344. #define TCL_DATA_CMD_2_ADDRY_EN_OFFSET 0x00000008
  345. #define TCL_DATA_CMD_2_ADDRY_EN_LSB 15
  346. #define TCL_DATA_CMD_2_ADDRY_EN_MASK 0x00008000
  347. /* Description TCL_DATA_CMD_2_TCL_CMD_NUMBER
  348. This number can be used by SW to track, identify and
  349. link the created commands with the command statuses
  350. Is set to the value 'TCL_CMD_Number' of the related
  351. TCL_DATA command
  352. <legal all>
  353. */
  354. #define TCL_DATA_CMD_2_TCL_CMD_NUMBER_OFFSET 0x00000008
  355. #define TCL_DATA_CMD_2_TCL_CMD_NUMBER_LSB 16
  356. #define TCL_DATA_CMD_2_TCL_CMD_NUMBER_MASK 0xffff0000
  357. /* Description TCL_DATA_CMD_3_DATA_LENGTH
  358. Valid Data length in bytes.
  359. MSDU length in case of direct descriptor.
  360. Length of link extension descriptor in case of Link
  361. extension descriptor. This is used to know the size of
  362. Metadata.
  363. <legal all>
  364. */
  365. #define TCL_DATA_CMD_3_DATA_LENGTH_OFFSET 0x0000000c
  366. #define TCL_DATA_CMD_3_DATA_LENGTH_LSB 0
  367. #define TCL_DATA_CMD_3_DATA_LENGTH_MASK 0x0000ffff
  368. /* Description TCL_DATA_CMD_3_IPV4_CHECKSUM_EN
  369. OLE related control
  370. Enable IPv4 checksum replacement
  371. */
  372. #define TCL_DATA_CMD_3_IPV4_CHECKSUM_EN_OFFSET 0x0000000c
  373. #define TCL_DATA_CMD_3_IPV4_CHECKSUM_EN_LSB 16
  374. #define TCL_DATA_CMD_3_IPV4_CHECKSUM_EN_MASK 0x00010000
  375. /* Description TCL_DATA_CMD_3_UDP_OVER_IPV4_CHECKSUM_EN
  376. OLE related control
  377. Enable UDP over IPv4 checksum replacement. UDP checksum
  378. over IPv4 is optional for TCP/IP stacks.
  379. */
  380. #define TCL_DATA_CMD_3_UDP_OVER_IPV4_CHECKSUM_EN_OFFSET 0x0000000c
  381. #define TCL_DATA_CMD_3_UDP_OVER_IPV4_CHECKSUM_EN_LSB 17
  382. #define TCL_DATA_CMD_3_UDP_OVER_IPV4_CHECKSUM_EN_MASK 0x00020000
  383. /* Description TCL_DATA_CMD_3_UDP_OVER_IPV6_CHECKSUM_EN
  384. OLE related control
  385. Enable UDP over IPv6 checksum replacement. UDP checksum
  386. over IPv6 is mandatory for TCP/IP stacks.
  387. */
  388. #define TCL_DATA_CMD_3_UDP_OVER_IPV6_CHECKSUM_EN_OFFSET 0x0000000c
  389. #define TCL_DATA_CMD_3_UDP_OVER_IPV6_CHECKSUM_EN_LSB 18
  390. #define TCL_DATA_CMD_3_UDP_OVER_IPV6_CHECKSUM_EN_MASK 0x00040000
  391. /* Description TCL_DATA_CMD_3_TCP_OVER_IPV4_CHECKSUM_EN
  392. OLE related control
  393. Enable TCP checksum over IPv4 replacement
  394. */
  395. #define TCL_DATA_CMD_3_TCP_OVER_IPV4_CHECKSUM_EN_OFFSET 0x0000000c
  396. #define TCL_DATA_CMD_3_TCP_OVER_IPV4_CHECKSUM_EN_LSB 19
  397. #define TCL_DATA_CMD_3_TCP_OVER_IPV4_CHECKSUM_EN_MASK 0x00080000
  398. /* Description TCL_DATA_CMD_3_TCP_OVER_IPV6_CHECKSUM_EN
  399. OLE related control
  400. Enable TCP checksum over IPv6 replacement
  401. */
  402. #define TCL_DATA_CMD_3_TCP_OVER_IPV6_CHECKSUM_EN_OFFSET 0x0000000c
  403. #define TCL_DATA_CMD_3_TCP_OVER_IPV6_CHECKSUM_EN_LSB 20
  404. #define TCL_DATA_CMD_3_TCP_OVER_IPV6_CHECKSUM_EN_MASK 0x00100000
  405. /* Description TCL_DATA_CMD_3_TO_FW
  406. Forward packet to FW along with classification result.
  407. The packet will not be forward to TQM when this bit is set
  408. 1'b0: Use classification result to forward the packet.
  409. 1'b1: Override classification result and forward packet
  410. only to FW.
  411. */
  412. #define TCL_DATA_CMD_3_TO_FW_OFFSET 0x0000000c
  413. #define TCL_DATA_CMD_3_TO_FW_LSB 21
  414. #define TCL_DATA_CMD_3_TO_FW_MASK 0x00200000
  415. /* Description TCL_DATA_CMD_3_DSCP_TO_TID_PRIORITY_TABLE_ID
  416. The DSCP to tid conversion table to be used for this
  417. frame
  418. <legal all>
  419. */
  420. #define TCL_DATA_CMD_3_DSCP_TO_TID_PRIORITY_TABLE_ID_OFFSET 0x0000000c
  421. #define TCL_DATA_CMD_3_DSCP_TO_TID_PRIORITY_TABLE_ID_LSB 22
  422. #define TCL_DATA_CMD_3_DSCP_TO_TID_PRIORITY_TABLE_ID_MASK 0x00400000
  423. /* Description TCL_DATA_CMD_3_PACKET_OFFSET
  424. Packet offset from Metadata in case of direct buffer
  425. descriptor. This field is valid when Buf_or_ext_desc_type is
  426. reset(= 0).
  427. <legal all>
  428. */
  429. #define TCL_DATA_CMD_3_PACKET_OFFSET_OFFSET 0x0000000c
  430. #define TCL_DATA_CMD_3_PACKET_OFFSET_LSB 23
  431. #define TCL_DATA_CMD_3_PACKET_OFFSET_MASK 0xff800000
  432. /* Description TCL_DATA_CMD_4_BUFFER_TIMESTAMP
  433. Field only valid when 'Buffer_timestamp_valid ' is set.
  434. Frame system entrance timestamp. The timestamp is
  435. related to the global system timer
  436. Generally the first module (SW, TCL or TQM). that sees
  437. this frame and this timestamp field is not valid, shall fill
  438. in this field.
  439. Timestamp in units of 1024 us
  440. */
  441. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_OFFSET 0x00000010
  442. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_LSB 0
  443. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_MASK 0x0007ffff
  444. /* Description TCL_DATA_CMD_4_BUFFER_TIMESTAMP_VALID
  445. When set, the Buffer_timestamp field contains valid
  446. info.
  447. */
  448. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_VALID_OFFSET 0x00000010
  449. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_VALID_LSB 19
  450. #define TCL_DATA_CMD_4_BUFFER_TIMESTAMP_VALID_MASK 0x00080000
  451. /* Description TCL_DATA_CMD_4_MESH_ENABLE
  452. If set to 1:
  453. * For raw WiFi frames, this indicates transmission to a
  454. mesh STA, enabling the interpretation of the 'Mesh Control
  455. Present' bit (bit 8) of QoS Control (otherwise this bit is
  456. ignored),
  457. * For native WiFi frames, this indicates that a 'Mesh
  458. Control' field is present between the header and the LLC.
  459. */
  460. #define TCL_DATA_CMD_4_MESH_ENABLE_OFFSET 0x00000010
  461. #define TCL_DATA_CMD_4_MESH_ENABLE_LSB 20
  462. #define TCL_DATA_CMD_4_MESH_ENABLE_MASK 0x00100000
  463. /* Description TCL_DATA_CMD_4_HLOS_TID_OVERWRITE
  464. When set, TCL shall ignore the IP DSCP and VLAN PCP
  465. fields and use HLOS_TID as the final TID. Otherwise TCL
  466. shall consider the DSCP and PCP fields as well as HLOS_TID
  467. and choose a final TID based on the configured priority
  468. <legal all>
  469. */
  470. #define TCL_DATA_CMD_4_HLOS_TID_OVERWRITE_OFFSET 0x00000010
  471. #define TCL_DATA_CMD_4_HLOS_TID_OVERWRITE_LSB 21
  472. #define TCL_DATA_CMD_4_HLOS_TID_OVERWRITE_MASK 0x00200000
  473. /* Description TCL_DATA_CMD_4_HLOS_TID
  474. HLOS MSDU priority
  475. Field is used when HLOS_TID_overwrite is set.
  476. Field is also used when HLOS_TID_overwrite is not set
  477. and DSCP/PCP is not available in the packet
  478. <legal all>
  479. */
  480. #define TCL_DATA_CMD_4_HLOS_TID_OFFSET 0x00000010
  481. #define TCL_DATA_CMD_4_HLOS_TID_LSB 22
  482. #define TCL_DATA_CMD_4_HLOS_TID_MASK 0x03c00000
  483. /* Description TCL_DATA_CMD_4_RESERVED_4
  484. <legal 0>
  485. */
  486. #define TCL_DATA_CMD_4_RESERVED_4_OFFSET 0x00000010
  487. #define TCL_DATA_CMD_4_RESERVED_4_LSB 26
  488. #define TCL_DATA_CMD_4_RESERVED_4_MASK 0xfc000000
  489. /* Description TCL_DATA_CMD_5_RESERVED_5
  490. <legal 0>
  491. */
  492. #define TCL_DATA_CMD_5_RESERVED_5_OFFSET 0x00000014
  493. #define TCL_DATA_CMD_5_RESERVED_5_LSB 0
  494. #define TCL_DATA_CMD_5_RESERVED_5_MASK 0xffffffff
  495. /* Description TCL_DATA_CMD_6_RESERVED_6A
  496. <legal 0>
  497. */
  498. #define TCL_DATA_CMD_6_RESERVED_6A_OFFSET 0x00000018
  499. #define TCL_DATA_CMD_6_RESERVED_6A_LSB 0
  500. #define TCL_DATA_CMD_6_RESERVED_6A_MASK 0x000fffff
  501. /* Description TCL_DATA_CMD_6_RING_ID
  502. The buffer pointer ring ID.
  503. 0 refers to the IDLE ring
  504. 1 - N refers to other rings
  505. Helps with debugging when dumping ring contents.
  506. <legal all>
  507. */
  508. #define TCL_DATA_CMD_6_RING_ID_OFFSET 0x00000018
  509. #define TCL_DATA_CMD_6_RING_ID_LSB 20
  510. #define TCL_DATA_CMD_6_RING_ID_MASK 0x0ff00000
  511. /* Description TCL_DATA_CMD_6_LOOPING_COUNT
  512. A count value that indicates the number of times the
  513. producer of entries into the Ring has looped around the
  514. ring.
  515. At initialization time, this value is set to 0. On the
  516. first loop, this value is set to 1. After the max value is
  517. reached allowed by the number of bits for this field, the
  518. count value continues with 0 again.
  519. In case SW is the consumer of the ring entries, it can
  520. use this field to figure out up to where the producer of
  521. entries has created new entries. This eliminates the need to
  522. check where the head pointer' of the ring is located once
  523. the SW starts processing an interrupt indicating that new
  524. entries have been put into this ring...
  525. Also note that SW if it wants only needs to look at the
  526. LSB bit of this count value.
  527. <legal all>
  528. */
  529. #define TCL_DATA_CMD_6_LOOPING_COUNT_OFFSET 0x00000018
  530. #define TCL_DATA_CMD_6_LOOPING_COUNT_LSB 28
  531. #define TCL_DATA_CMD_6_LOOPING_COUNT_MASK 0xf0000000
  532. #endif // _TCL_DATA_CMD_H_