tcl_data_cmd.h 25 KB

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