ipahal.h 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655
  1. /* SPDX-License-Identifier: GPL-2.0-only */
  2. /*
  3. * Copyright (c) 2016-2019, The Linux Foundation. All rights reserved.
  4. */
  5. #ifndef _IPAHAL_H_
  6. #define _IPAHAL_H_
  7. #include "../ipa_defs.h"
  8. #include "../../ipa_common_i.h"
  9. /*
  10. * Immediate command names
  11. *
  12. * NOTE:: Any change to this enum, need to change to ipahal_imm_cmd_name_to_str
  13. * array as well.
  14. */
  15. enum ipahal_imm_cmd_name {
  16. IPA_IMM_CMD_IP_V4_FILTER_INIT,
  17. IPA_IMM_CMD_IP_V6_FILTER_INIT,
  18. IPA_IMM_CMD_IP_V4_NAT_INIT,
  19. IPA_IMM_CMD_IP_V4_ROUTING_INIT,
  20. IPA_IMM_CMD_IP_V6_ROUTING_INIT,
  21. IPA_IMM_CMD_HDR_INIT_LOCAL,
  22. IPA_IMM_CMD_HDR_INIT_SYSTEM,
  23. IPA_IMM_CMD_REGISTER_WRITE,
  24. IPA_IMM_CMD_NAT_DMA,
  25. IPA_IMM_CMD_IP_PACKET_INIT,
  26. IPA_IMM_CMD_DMA_SHARED_MEM,
  27. IPA_IMM_CMD_IP_PACKET_TAG_STATUS,
  28. IPA_IMM_CMD_DMA_TASK_32B_ADDR,
  29. IPA_IMM_CMD_TABLE_DMA,
  30. IPA_IMM_CMD_IP_V6_CT_INIT,
  31. IPA_IMM_CMD_MAX,
  32. };
  33. /* Immediate commands abstracted structures */
  34. /*
  35. * struct ipahal_imm_cmd_ip_v4_filter_init - IP_V4_FILTER_INIT cmd payload
  36. * Inits IPv4 filter block.
  37. * @hash_rules_addr: Addr in sys mem where ipv4 hashable flt tbl starts
  38. * @nhash_rules_addr: Addr in sys mem where ipv4 non-hashable flt tbl starts
  39. * @hash_rules_size: Size in bytes of the hashable tbl to cpy to local mem
  40. * @hash_local_addr: Addr in shared mem where ipv4 hashable flt tbl should
  41. * be copied to
  42. * @nhash_rules_size: Size in bytes of the non-hashable tbl to cpy to local mem
  43. * @nhash_local_addr: Addr in shared mem where ipv4 non-hashable flt tbl should
  44. * be copied to
  45. */
  46. struct ipahal_imm_cmd_ip_v4_filter_init {
  47. u64 hash_rules_addr;
  48. u64 nhash_rules_addr;
  49. u32 hash_rules_size;
  50. u32 hash_local_addr;
  51. u32 nhash_rules_size;
  52. u32 nhash_local_addr;
  53. };
  54. /*
  55. * struct ipahal_imm_cmd_ip_v6_filter_init - IP_V6_FILTER_INIT cmd payload
  56. * Inits IPv6 filter block.
  57. * @hash_rules_addr: Addr in sys mem where ipv6 hashable flt tbl starts
  58. * @nhash_rules_addr: Addr in sys mem where ipv6 non-hashable flt tbl starts
  59. * @hash_rules_size: Size in bytes of the hashable tbl to cpy to local mem
  60. * @hash_local_addr: Addr in shared mem where ipv6 hashable flt tbl should
  61. * be copied to
  62. * @nhash_rules_size: Size in bytes of the non-hashable tbl to cpy to local mem
  63. * @nhash_local_addr: Addr in shared mem where ipv6 non-hashable flt tbl should
  64. * be copied to
  65. */
  66. struct ipahal_imm_cmd_ip_v6_filter_init {
  67. u64 hash_rules_addr;
  68. u64 nhash_rules_addr;
  69. u32 hash_rules_size;
  70. u32 hash_local_addr;
  71. u32 nhash_rules_size;
  72. u32 nhash_local_addr;
  73. };
  74. /*
  75. * struct ipahal_imm_cmd_nat_ipv6ct_init_common - NAT/IPv6CT table init command
  76. * common part
  77. * @base_table_addr: Address in sys/shared mem where base table start
  78. * @expansion_table_addr: Address in sys/shared mem where expansion table
  79. * starts. Entries that result in hash collision are located in this table.
  80. * @base_table_addr_shared: base_table_addr in shared mem (if not, then sys)
  81. * @expansion_table_addr_shared: expansion_rules_addr in
  82. * shared mem (if not, then sys)
  83. * @size_base_table: Num of entries in the base table
  84. * @size_expansion_table: Num of entries in the expansion table
  85. * @table_index: For future support of multiple tables
  86. */
  87. struct ipahal_imm_cmd_nat_ipv6ct_init_common {
  88. u64 base_table_addr;
  89. u64 expansion_table_addr;
  90. bool base_table_addr_shared;
  91. bool expansion_table_addr_shared;
  92. u16 size_base_table;
  93. u16 size_expansion_table;
  94. u8 table_index;
  95. };
  96. /*
  97. * struct ipahal_imm_cmd_ip_v4_nat_init - IP_V4_NAT_INIT cmd payload
  98. * Inits IPv4 NAT block. Initiate NAT table with it dimensions, location
  99. * cache address and other related parameters.
  100. * @table_init: table initialization parameters
  101. * @index_table_addr: Addr in sys/shared mem where index table, which points
  102. * to NAT table starts
  103. * @index_table_expansion_addr: Addr in sys/shared mem where expansion index
  104. * table starts
  105. * @index_table_addr_shared: index_table_addr in shared mem (if not, then sys)
  106. * @index_table_expansion_addr_shared: index_table_expansion_addr in
  107. * shared mem (if not, then sys)
  108. * @public_addr_info: Public IP addresses info suitable to the IPA H/W version
  109. * IPA H/W >= 4.0 - PDN config table offset in SMEM
  110. * IPA H/W < 4.0 - The public IP address
  111. */
  112. struct ipahal_imm_cmd_ip_v4_nat_init {
  113. struct ipahal_imm_cmd_nat_ipv6ct_init_common table_init;
  114. u64 index_table_addr;
  115. u64 index_table_expansion_addr;
  116. bool index_table_addr_shared;
  117. bool index_table_expansion_addr_shared;
  118. u32 public_addr_info;
  119. };
  120. /*
  121. * struct ipahal_imm_cmd_ip_v6_ct_init - IP_V6_CONN_TRACK_INIT cmd payload
  122. * Inits IPv6CT block. Initiate IPv6CT table with it dimensions, location
  123. * cache address and other related parameters.
  124. * @table_init: table initialization parameters
  125. */
  126. struct ipahal_imm_cmd_ip_v6_ct_init {
  127. struct ipahal_imm_cmd_nat_ipv6ct_init_common table_init;
  128. };
  129. /*
  130. * struct ipahal_imm_cmd_ip_v4_routing_init - IP_V4_ROUTING_INIT cmd payload
  131. * Inits IPv4 routing table/structure - with the rules and other related params
  132. * @hash_rules_addr: Addr in sys mem where ipv4 hashable rt tbl starts
  133. * @nhash_rules_addr: Addr in sys mem where ipv4 non-hashable rt tbl starts
  134. * @hash_rules_size: Size in bytes of the hashable tbl to cpy to local mem
  135. * @hash_local_addr: Addr in shared mem where ipv4 hashable rt tbl should
  136. * be copied to
  137. * @nhash_rules_size: Size in bytes of the non-hashable tbl to cpy to local mem
  138. * @nhash_local_addr: Addr in shared mem where ipv4 non-hashable rt tbl should
  139. * be copied to
  140. */
  141. struct ipahal_imm_cmd_ip_v4_routing_init {
  142. u64 hash_rules_addr;
  143. u64 nhash_rules_addr;
  144. u32 hash_rules_size;
  145. u32 hash_local_addr;
  146. u32 nhash_rules_size;
  147. u32 nhash_local_addr;
  148. };
  149. /*
  150. * struct ipahal_imm_cmd_ip_v6_routing_init - IP_V6_ROUTING_INIT cmd payload
  151. * Inits IPv6 routing table/structure - with the rules and other related params
  152. * @hash_rules_addr: Addr in sys mem where ipv6 hashable rt tbl starts
  153. * @nhash_rules_addr: Addr in sys mem where ipv6 non-hashable rt tbl starts
  154. * @hash_rules_size: Size in bytes of the hashable tbl to cpy to local mem
  155. * @hash_local_addr: Addr in shared mem where ipv6 hashable rt tbl should
  156. * be copied to
  157. * @nhash_rules_size: Size in bytes of the non-hashable tbl to cpy to local mem
  158. * @nhash_local_addr: Addr in shared mem where ipv6 non-hashable rt tbl should
  159. * be copied to
  160. */
  161. struct ipahal_imm_cmd_ip_v6_routing_init {
  162. u64 hash_rules_addr;
  163. u64 nhash_rules_addr;
  164. u32 hash_rules_size;
  165. u32 hash_local_addr;
  166. u32 nhash_rules_size;
  167. u32 nhash_local_addr;
  168. };
  169. /*
  170. * struct ipahal_imm_cmd_hdr_init_local - HDR_INIT_LOCAL cmd payload
  171. * Inits hdr table within local mem with the hdrs and their length.
  172. * @hdr_table_addr: Word address in sys mem where the table starts (SRC)
  173. * @size_hdr_table: Size of the above (in bytes)
  174. * @hdr_addr: header address in IPA sram (used as DST for memory copy)
  175. * @rsvd: reserved
  176. */
  177. struct ipahal_imm_cmd_hdr_init_local {
  178. u64 hdr_table_addr;
  179. u32 size_hdr_table;
  180. u32 hdr_addr;
  181. };
  182. /*
  183. * struct ipahal_imm_cmd_hdr_init_system - HDR_INIT_SYSTEM cmd payload
  184. * Inits hdr table within sys mem with the hdrs and their length.
  185. * @hdr_table_addr: Word address in system memory where the hdrs tbl starts.
  186. */
  187. struct ipahal_imm_cmd_hdr_init_system {
  188. u64 hdr_table_addr;
  189. };
  190. /*
  191. * struct ipahal_imm_cmd_table_dma - TABLE_DMA cmd payload
  192. * Perform DMA operation on NAT and IPV6 connection tracking related mem
  193. * addresses. Copy data into different locations within IPv6CT and NAT
  194. * associated tbls. (For add/remove NAT rules)
  195. * @offset: offset in bytes from base addr to write 'data' to
  196. * @data: data to be written
  197. * @table_index: NAT tbl index. Defines the tbl on which to perform DMA op.
  198. * @base_addr: Base addr to which the DMA operation should be performed.
  199. */
  200. struct ipahal_imm_cmd_table_dma {
  201. u32 offset;
  202. u16 data;
  203. u8 table_index;
  204. u8 base_addr;
  205. };
  206. /*
  207. * struct ipahal_imm_cmd_ip_packet_init - IP_PACKET_INIT cmd payload
  208. * Configuration for specific IP pkt. Shall be called prior to an IP pkt
  209. * data. Pkt will not go through IP pkt processing.
  210. * @destination_pipe_index: Destination pipe index (in case routing
  211. * is enabled, this field will overwrite the rt rule)
  212. */
  213. struct ipahal_imm_cmd_ip_packet_init {
  214. u32 destination_pipe_index;
  215. };
  216. /*
  217. * enum ipa_pipeline_clear_option - Values for pipeline clear waiting options
  218. * @IPAHAL_HPS_CLEAR: Wait for HPS clear. All queues except high priority queue
  219. * shall not be serviced until HPS is clear of packets or immediate commands.
  220. * The high priority Rx queue / Q6ZIP group shall still be serviced normally.
  221. *
  222. * @IPAHAL_SRC_GRP_CLEAR: Wait for originating source group to be clear
  223. * (for no packet contexts allocated to the originating source group).
  224. * The source group / Rx queue shall not be serviced until all previously
  225. * allocated packet contexts are released. All other source groups/queues shall
  226. * be serviced normally.
  227. *
  228. * @IPAHAL_FULL_PIPELINE_CLEAR: Wait for full pipeline to be clear.
  229. * All groups / Rx queues shall not be serviced until IPA pipeline is fully
  230. * clear. This should be used for debug only.
  231. */
  232. enum ipahal_pipeline_clear_option {
  233. IPAHAL_HPS_CLEAR,
  234. IPAHAL_SRC_GRP_CLEAR,
  235. IPAHAL_FULL_PIPELINE_CLEAR
  236. };
  237. /*
  238. * struct ipahal_imm_cmd_register_write - REGISTER_WRITE cmd payload
  239. * Write value to register. Allows reg changes to be synced with data packet
  240. * and other immediate commands. Can be used to access the sram
  241. * @offset: offset from IPA base address - Lower 16bit of the IPA reg addr
  242. * @value: value to write to register
  243. * @value_mask: mask specifying which value bits to write to the register
  244. * @skip_pipeline_clear: if to skip pipeline clear waiting (don't wait)
  245. * @pipeline_clear_option: options for pipeline clear waiting
  246. */
  247. struct ipahal_imm_cmd_register_write {
  248. u32 offset;
  249. u32 value;
  250. u32 value_mask;
  251. bool skip_pipeline_clear;
  252. enum ipahal_pipeline_clear_option pipeline_clear_options;
  253. };
  254. /*
  255. * struct ipahal_imm_cmd_dma_shared_mem - DMA_SHARED_MEM cmd payload
  256. * Perform mem copy into or out of the SW area of IPA local mem
  257. * @system_addr: Address in system memory
  258. * @size: Size in bytes of data to copy. Expected size is up to 2K bytes
  259. * @local_addr: Address in IPA local memory
  260. * @clear_after_read: Clear local memory at the end of a read operation allows
  261. * atomic read and clear if HPS is clear. Ignore for writes.
  262. * @is_read: Read operation from local memory? If not, then write.
  263. * @skip_pipeline_clear: if to skip pipeline clear waiting (don't wait)
  264. * @pipeline_clear_option: options for pipeline clear waiting
  265. */
  266. struct ipahal_imm_cmd_dma_shared_mem {
  267. u64 system_addr;
  268. u32 size;
  269. u32 local_addr;
  270. bool clear_after_read;
  271. bool is_read;
  272. bool skip_pipeline_clear;
  273. enum ipahal_pipeline_clear_option pipeline_clear_options;
  274. };
  275. /*
  276. * struct ipahal_imm_cmd_ip_packet_tag_status - IP_PACKET_TAG_STATUS cmd payload
  277. * This cmd is used for to allow SW to track HW processing by setting a TAG
  278. * value that is passed back to SW inside Packet Status information.
  279. * TAG info will be provided as part of Packet Status info generated for
  280. * the next pkt transferred over the pipe.
  281. * This immediate command must be followed by a packet in the same transfer.
  282. * @tag: Tag that is provided back to SW
  283. */
  284. struct ipahal_imm_cmd_ip_packet_tag_status {
  285. u64 tag;
  286. };
  287. /*
  288. * struct ipahal_imm_cmd_dma_task_32b_addr - IPA_DMA_TASK_32B_ADDR cmd payload
  289. * Used by clients using 32bit addresses. Used to perform DMA operation on
  290. * multiple descriptors.
  291. * The Opcode is dynamic, where it holds the number of buffer to process
  292. * @cmplt: Complete flag: If true, IPA interrupt SW when the entire
  293. * DMA related data was completely xfered to its destination.
  294. * @eof: Enf Of Frame flag: If true, IPA assert the EOT to the
  295. * dest client. This is used used for aggr sequence
  296. * @flsh: Flush flag: If true pkt will go through the IPA blocks but
  297. * will not be xfered to dest client but rather will be discarded
  298. * @lock: Lock pipe flag: If true, IPA will stop processing descriptors
  299. * from other EPs in the same src grp (RX queue)
  300. * @unlock: Unlock pipe flag: If true, IPA will stop exclusively
  301. * servicing current EP out of the src EPs of the grp (RX queue)
  302. * @size1: Size of buffer1 data
  303. * @addr1: Pointer to buffer1 data
  304. * @packet_size: Total packet size. If a pkt send using multiple DMA_TASKs,
  305. * only the first one needs to have this field set. It will be ignored
  306. * in subsequent DMA_TASKs until the packet ends (EOT). First DMA_TASK
  307. * must contain this field (2 or more buffers) or EOT.
  308. */
  309. struct ipahal_imm_cmd_dma_task_32b_addr {
  310. bool cmplt;
  311. bool eof;
  312. bool flsh;
  313. bool lock;
  314. bool unlock;
  315. u32 size1;
  316. u32 addr1;
  317. u32 packet_size;
  318. };
  319. /*
  320. * struct ipahal_imm_cmd_pyld - Immediate cmd payload information
  321. * @len: length of the buffer
  322. * @opcode: opcode of the immediate command
  323. * @data: buffer contains the immediate command payload. Buffer goes
  324. * back to back with this structure
  325. */
  326. struct ipahal_imm_cmd_pyld {
  327. u16 len;
  328. u16 opcode;
  329. u8 data[0];
  330. };
  331. /* Immediate command Function APIs */
  332. /*
  333. * ipahal_imm_cmd_name_str() - returns string that represent the imm cmd
  334. * @cmd_name: [in] Immediate command name
  335. */
  336. const char *ipahal_imm_cmd_name_str(enum ipahal_imm_cmd_name cmd_name);
  337. /*
  338. * ipahal_construct_imm_cmd() - Construct immdiate command
  339. * This function builds imm cmd bulk that can be be sent to IPA
  340. * The command will be allocated dynamically.
  341. * After done using it, call ipahal_destroy_imm_cmd() to release it
  342. */
  343. struct ipahal_imm_cmd_pyld *ipahal_construct_imm_cmd(
  344. enum ipahal_imm_cmd_name cmd, const void *params, bool is_atomic_ctx);
  345. /*
  346. * ipahal_construct_nop_imm_cmd() - Construct immediate comamnd for NO-Op
  347. * Core driver may want functionality to inject NOP commands to IPA
  348. * to ensure e.g., PIPLINE clear before someother operation.
  349. * The functionality given by this function can be reached by
  350. * ipahal_construct_imm_cmd(). This function is helper to the core driver
  351. * to reach this NOP functionlity easily.
  352. * @skip_pipline_clear: if to skip pipeline clear waiting (don't wait)
  353. * @pipline_clr_opt: options for pipeline clear waiting
  354. * @is_atomic_ctx: is called in atomic context or can sleep?
  355. */
  356. struct ipahal_imm_cmd_pyld *ipahal_construct_nop_imm_cmd(
  357. bool skip_pipline_clear,
  358. enum ipahal_pipeline_clear_option pipline_clr_opt,
  359. bool is_atomic_ctx);
  360. /*
  361. * ipahal_destroy_imm_cmd() - Destroy/Release bulk that was built
  362. * by the construction functions
  363. */
  364. static inline void ipahal_destroy_imm_cmd(struct ipahal_imm_cmd_pyld *pyld)
  365. {
  366. kfree(pyld);
  367. }
  368. /* IPA Status packet Structures and Function APIs */
  369. /*
  370. * enum ipahal_pkt_status_opcode - Packet Status Opcode
  371. * @IPAHAL_STATUS_OPCODE_PACKET_2ND_PASS: Packet Status generated as part of
  372. * IPA second processing pass for a packet (i.e. IPA XLAT processing for
  373. * the translated packet).
  374. */
  375. enum ipahal_pkt_status_opcode {
  376. IPAHAL_PKT_STATUS_OPCODE_PACKET = 0,
  377. IPAHAL_PKT_STATUS_OPCODE_NEW_FRAG_RULE,
  378. IPAHAL_PKT_STATUS_OPCODE_DROPPED_PACKET,
  379. IPAHAL_PKT_STATUS_OPCODE_SUSPENDED_PACKET,
  380. IPAHAL_PKT_STATUS_OPCODE_LOG,
  381. IPAHAL_PKT_STATUS_OPCODE_DCMP,
  382. IPAHAL_PKT_STATUS_OPCODE_PACKET_2ND_PASS,
  383. };
  384. /*
  385. * enum ipahal_pkt_status_exception - Packet Status exception type
  386. * @IPAHAL_PKT_STATUS_EXCEPTION_PACKET_LENGTH: formerly IHL exception.
  387. *
  388. * Note: IPTYPE, PACKET_LENGTH and PACKET_THRESHOLD exceptions means that
  389. * partial / no IP processing took place and corresponding Status Mask
  390. * fields should be ignored. Flt and rt info is not valid.
  391. *
  392. * NOTE:: Any change to this enum, need to change to
  393. * ipahal_pkt_status_exception_to_str array as well.
  394. */
  395. enum ipahal_pkt_status_exception {
  396. IPAHAL_PKT_STATUS_EXCEPTION_NONE = 0,
  397. IPAHAL_PKT_STATUS_EXCEPTION_DEAGGR,
  398. IPAHAL_PKT_STATUS_EXCEPTION_IPTYPE,
  399. IPAHAL_PKT_STATUS_EXCEPTION_PACKET_LENGTH,
  400. IPAHAL_PKT_STATUS_EXCEPTION_PACKET_THRESHOLD,
  401. IPAHAL_PKT_STATUS_EXCEPTION_FRAG_RULE_MISS,
  402. IPAHAL_PKT_STATUS_EXCEPTION_SW_FILT,
  403. /*
  404. * NAT and IPv6CT have the same value at HW.
  405. * NAT for IPv4 and IPv6CT for IPv6 exceptions
  406. */
  407. IPAHAL_PKT_STATUS_EXCEPTION_NAT,
  408. IPAHAL_PKT_STATUS_EXCEPTION_IPV6CT,
  409. IPAHAL_PKT_STATUS_EXCEPTION_CSUM,
  410. IPAHAL_PKT_STATUS_EXCEPTION_MAX,
  411. };
  412. /*
  413. * enum ipahal_pkt_status_mask - Packet Status bitmask shift values of
  414. * the contained flags. This bitmask indicates flags on the properties of
  415. * the packet as well as IPA processing it may had.
  416. * @FRAG_PROCESS: Frag block processing flag: Was pkt processed by frag block?
  417. * Also means the frag info is valid unless exception or first frag
  418. * @FILT_PROCESS: Flt block processing flag: Was pkt processed by flt block?
  419. * Also means that flt info is valid.
  420. * @NAT_PROCESS: NAT block processing flag: Was pkt processed by NAT block?
  421. * Also means that NAT info is valid, unless exception.
  422. * @ROUTE_PROCESS: Rt block processing flag: Was pkt processed by rt block?
  423. * Also means that rt info is valid, unless exception.
  424. * @TAG_VALID: Flag specifying if TAG and TAG info valid?
  425. * @FRAGMENT: Flag specifying if pkt is IP fragment.
  426. * @FIRST_FRAGMENT: Flag specifying if pkt is first fragment. In this case, frag
  427. * info is invalid
  428. * @V4: Flag specifying pkt is IPv4 or IPv6
  429. * @CKSUM_PROCESS: CSUM block processing flag: Was pkt processed by csum block?
  430. * If so, csum trailer exists
  431. * @AGGR_PROCESS: Aggr block processing flag: Was pkt processed by aggr block?
  432. * @DEST_EOT: Flag specifying if EOT was asserted for the pkt on dest endp
  433. * @DEAGGR_PROCESS: Deaggr block processing flag: Was pkt processed by deaggr
  434. * block?
  435. * @DEAGG_FIRST: Flag specifying if this is the first pkt in deaggr frame
  436. * @SRC_EOT: Flag specifying if EOT asserted by src endp when sending the buffer
  437. * @PREV_EOT: Flag specifying if EOT was sent just before the pkt as part of
  438. * aggr hard-byte-limit
  439. * @BYTE_LIMIT: Flag specifying if pkt is over a configured byte limit.
  440. */
  441. enum ipahal_pkt_status_mask {
  442. IPAHAL_PKT_STATUS_MASK_FRAG_PROCESS_SHFT = 0,
  443. IPAHAL_PKT_STATUS_MASK_FILT_PROCESS_SHFT,
  444. IPAHAL_PKT_STATUS_MASK_NAT_PROCESS_SHFT,
  445. IPAHAL_PKT_STATUS_MASK_ROUTE_PROCESS_SHFT,
  446. IPAHAL_PKT_STATUS_MASK_TAG_VALID_SHFT,
  447. IPAHAL_PKT_STATUS_MASK_FRAGMENT_SHFT,
  448. IPAHAL_PKT_STATUS_MASK_FIRST_FRAGMENT_SHFT,
  449. IPAHAL_PKT_STATUS_MASK_V4_SHFT,
  450. IPAHAL_PKT_STATUS_MASK_CKSUM_PROCESS_SHFT,
  451. IPAHAL_PKT_STATUS_MASK_AGGR_PROCESS_SHFT,
  452. IPAHAL_PKT_STATUS_MASK_DEST_EOT_SHFT,
  453. IPAHAL_PKT_STATUS_MASK_DEAGGR_PROCESS_SHFT,
  454. IPAHAL_PKT_STATUS_MASK_DEAGG_FIRST_SHFT,
  455. IPAHAL_PKT_STATUS_MASK_SRC_EOT_SHFT,
  456. IPAHAL_PKT_STATUS_MASK_PREV_EOT_SHFT,
  457. IPAHAL_PKT_STATUS_MASK_BYTE_LIMIT_SHFT,
  458. };
  459. /*
  460. * Returns boolean value representing a property of the a packet.
  461. * @__flag_shft: The shift value of the flag of the status bitmask of
  462. * @__status: Pointer to abstracrted status structure
  463. * the needed property. See enum ipahal_pkt_status_mask
  464. */
  465. #define IPAHAL_PKT_STATUS_MASK_FLAG_VAL(__flag_shft, __status) \
  466. (((__status)->status_mask) & ((u32)0x1<<(__flag_shft)) ? true : false)
  467. /*
  468. * enum ipahal_pkt_status_nat_type - Type of NAT
  469. */
  470. enum ipahal_pkt_status_nat_type {
  471. IPAHAL_PKT_STATUS_NAT_NONE,
  472. IPAHAL_PKT_STATUS_NAT_SRC,
  473. IPAHAL_PKT_STATUS_NAT_DST,
  474. };
  475. /*
  476. * struct ipahal_pkt_status - IPA status packet abstracted payload.
  477. * This structure describes the status packet fields for the
  478. * following statuses: IPA_STATUS_PACKET, IPA_STATUS_DROPPED_PACKET,
  479. * IPA_STATUS_SUSPENDED_PACKET.
  480. * Other statuses types has different status packet structure.
  481. * @tag_info: S/W defined value provided via immediate command
  482. * @status_opcode: The Type of the status (Opcode).
  483. * @exception: The first exception that took place.
  484. * In case of exception, src endp and pkt len are always valid.
  485. * @status_mask: Bit mask for flags on several properties on the packet
  486. * and processing it may passed at IPA. See enum ipahal_pkt_status_mask
  487. * @pkt_len: Pkt pyld len including hdr and retained hdr if used. Does
  488. * not include padding or checksum trailer len.
  489. * @metadata: meta data value used by packet
  490. * @flt_local: Filter table location flag: Does matching flt rule belongs to
  491. * flt tbl that resides in lcl memory? (if not, then system mem)
  492. * @flt_hash: Filter hash hit flag: Does matching flt rule was in hash tbl?
  493. * @flt_global: Global filter rule flag: Does matching flt rule belongs to
  494. * the global flt tbl? (if not, then the per endp tables)
  495. * @flt_ret_hdr: Retain header in filter rule flag: Does matching flt rule
  496. * specifies to retain header?
  497. * Starting IPA4.5, this will be true only if packet has L2 header.
  498. * @flt_miss: Filtering miss flag: Was their a filtering rule miss?
  499. * In case of miss, all flt info to be ignored
  500. * @rt_local: Route table location flag: Does matching rt rule belongs to
  501. * rt tbl that resides in lcl memory? (if not, then system mem)
  502. * @rt_hash: Route hash hit flag: Does matching rt rule was in hash tbl?
  503. * @ucp: UC Processing flag
  504. * @rt_miss: Routing miss flag: Was their a routing rule miss?
  505. * @nat_hit: NAT hit flag: Was their NAT hit?
  506. * @nat_type: Defines the type of the NAT operation:
  507. * @time_of_day_ctr: running counter from IPA clock
  508. * @hdr_local: Header table location flag: In header insertion, was the header
  509. * taken from the table resides in local memory? (If no, then system mem)
  510. * @frag_hit: Frag hit flag: Was their frag rule hit in H/W frag table?
  511. * @flt_rule_id: The ID of the matching filter rule (if no miss).
  512. * This info can be combined with endp_src_idx to locate the exact rule.
  513. * @rt_rule_id: The ID of the matching rt rule. (if no miss). This info
  514. * can be combined with rt_tbl_idx to locate the exact rule.
  515. * @nat_entry_idx: Index of the NAT entry used of NAT processing
  516. * @hdr_offset: Offset of used header in the header table
  517. * @endp_src_idx: Source end point index.
  518. * @endp_dest_idx: Destination end point index.
  519. * Not valid in case of exception
  520. * @rt_tbl_idx: Index of rt tbl that contains the rule on which was a match
  521. * @seq_num: Per source endp unique packet sequence number
  522. * @frag_rule: Frag rule index in H/W frag table in case of frag hit
  523. */
  524. struct ipahal_pkt_status {
  525. u64 tag_info;
  526. enum ipahal_pkt_status_opcode status_opcode;
  527. enum ipahal_pkt_status_exception exception;
  528. u32 status_mask;
  529. u32 pkt_len;
  530. u32 metadata;
  531. bool flt_local;
  532. bool flt_hash;
  533. bool flt_global;
  534. bool flt_ret_hdr;
  535. bool flt_miss;
  536. bool rt_local;
  537. bool rt_hash;
  538. bool ucp;
  539. bool rt_miss;
  540. bool nat_hit;
  541. enum ipahal_pkt_status_nat_type nat_type;
  542. u32 time_of_day_ctr;
  543. bool hdr_local;
  544. bool frag_hit;
  545. u16 flt_rule_id;
  546. u16 rt_rule_id;
  547. u16 nat_entry_idx;
  548. u16 hdr_offset;
  549. u8 endp_src_idx;
  550. u8 endp_dest_idx;
  551. u8 rt_tbl_idx;
  552. u8 seq_num;
  553. u8 frag_rule;
  554. };
  555. /*
  556. * ipahal_pkt_status_get_size() - Get H/W size of packet status
  557. */
  558. u32 ipahal_pkt_status_get_size(void);
  559. /*
  560. * ipahal_pkt_status_parse() - Parse Packet Status payload to abstracted form
  561. * @unparsed_status: Pointer to H/W format of the packet status as read from H/W
  562. * @status: Pointer to pre-allocated buffer where the parsed info will be stored
  563. */
  564. void ipahal_pkt_status_parse(const void *unparsed_status,
  565. struct ipahal_pkt_status *status);
  566. /*
  567. * ipahal_pkt_status_exception_str() - returns string represents exception type
  568. * @exception: [in] The exception type
  569. */
  570. const char *ipahal_pkt_status_exception_str(
  571. enum ipahal_pkt_status_exception exception);
  572. /*
  573. * ipahal_cp_hdr_to_hw_buff() - copy header to hardware buffer according to
  574. * base address and offset given.
  575. * @base: dma base address
  576. * @offset: offset from base address where the data will be copied
  577. * @hdr: the header to be copied
  578. * @hdr_len: the length of the header
  579. */
  580. void ipahal_cp_hdr_to_hw_buff(void *base, u32 offset, u8 *hdr, u32 hdr_len);
  581. /*
  582. * ipahal_cp_proc_ctx_to_hw_buff() - copy processing context to
  583. * base address and offset given.
  584. * @type: type of header processing context
  585. * @base: dma base address
  586. * @offset: offset from base address where the data will be copied
  587. * @hdr_len: the length of the header
  588. * @is_hdr_proc_ctx: header is located in phys_base (true) or hdr_base_addr
  589. * @phys_base: memory location in DDR
  590. * @hdr_base_addr: base address in table
  591. * @offset_entry: offset from hdr_base_addr in table
  592. * @l2tp_params: l2tp parameters
  593. * @is_64: Indicates whether header base address/dma base address is 64 bit.
  594. */
  595. int ipahal_cp_proc_ctx_to_hw_buff(enum ipa_hdr_proc_type type,
  596. void *base, u32 offset, u32 hdr_len,
  597. bool is_hdr_proc_ctx, dma_addr_t phys_base,
  598. u64 hdr_base_addr,
  599. struct ipa_hdr_offset_entry *offset_entry,
  600. struct ipa_l2tp_hdr_proc_ctx_params l2tp_params, bool is_64);
  601. /*
  602. * ipahal_get_proc_ctx_needed_len() - calculates the needed length for addition
  603. * of header processing context according to the type of processing context
  604. * @type: header processing context type (no processing context,
  605. * IPA_HDR_PROC_ETHII_TO_ETHII etc.)
  606. */
  607. int ipahal_get_proc_ctx_needed_len(enum ipa_hdr_proc_type type);
  608. int ipahal_init(enum ipa_hw_type ipa_hw_type, void __iomem *base,
  609. struct device *ipa_pdev);
  610. void ipahal_destroy(void);
  611. void ipahal_free_dma_mem(struct ipa_mem_buffer *mem);
  612. #endif /* _IPAHAL_H_ */