regtable_ce.h 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260
  1. /*
  2. * Copyright (c) 2015 The Linux Foundation. All rights reserved.
  3. *
  4. * Previously licensed under the ISC license by Qualcomm Atheros, Inc.
  5. *
  6. *
  7. * Permission to use, copy, modify, and/or distribute this software for
  8. * any purpose with or without fee is hereby granted, provided that the
  9. * above copyright notice and this permission notice appear in all
  10. * copies.
  11. *
  12. * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL
  13. * WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED
  14. * WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE
  15. * AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL
  16. * DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR
  17. * PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER
  18. * TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
  19. * PERFORMANCE OF THIS SOFTWARE.
  20. */
  21. /*
  22. * This file was originally distributed by Qualcomm Atheros, Inc.
  23. * under proprietary terms before Copyright ownership was assigned
  24. * to the Linux Foundation.
  25. */
  26. #ifndef _REGTABLE_CE_H_
  27. #define _REGTABLE_CE_H_
  28. /*
  29. * @d_DST_WR_INDEX_ADDRESS: Destination ring write index
  30. *
  31. * @d_SRC_WATERMARK_ADDRESS: Source ring watermark
  32. *
  33. * @d_SRC_WATERMARK_LOW_MASK: Bits indicating low watermark from Source ring
  34. * watermark
  35. *
  36. * @d_SRC_WATERMARK_HIGH_MASK: Bits indicating high watermark from Source ring
  37. * watermark
  38. *
  39. * @d_DST_WATERMARK_LOW_MASK: Bits indicating low watermark from Destination
  40. * ring watermark
  41. *
  42. * @d_DST_WATERMARK_HIGH_MASK: Bits indicating high watermark from Destination
  43. * ring watermark
  44. *
  45. * @d_CURRENT_SRRI_ADDRESS: Current source ring read index.The Start Offset
  46. * will be reflected after a CE transfer is completed.
  47. *
  48. * @d_CURRENT_DRRI_ADDRESS: Current Destination ring read index. The Start
  49. * Offset will be reflected after a CE transfer
  50. * is completed.
  51. *
  52. * @d_HOST_IS_SRC_RING_HIGH_WATERMARK_MASK: Source ring high watermark
  53. * Interrupt Status
  54. *
  55. * @d_HOST_IS_SRC_RING_LOW_WATERMARK_MASK: Source ring low watermark
  56. * Interrupt Status
  57. *
  58. * @d_HOST_IS_DST_RING_HIGH_WATERMARK_MASK: Destination ring high watermark
  59. * Interrupt Status
  60. *
  61. * @d_HOST_IS_DST_RING_LOW_WATERMARK_MASK: Source ring low watermark
  62. * Interrupt Status
  63. *
  64. * @d_HOST_IS_ADDRESS: Host Interrupt Status Register
  65. *
  66. * @d_MISC_IS_ADDRESS: Miscellaneous Interrupt Status Register
  67. *
  68. * @d_HOST_IS_COPY_COMPLETE_MASK: Bits indicating Copy complete interrupt
  69. * status from the Host Interrupt Status
  70. * register
  71. *
  72. * @d_CE_WRAPPER_BASE_ADDRESS: Copy Engine Wrapper Base Address
  73. *
  74. * @d_CE_WRAPPER_INTERRUPT_SUMMARY_ADDRESS: CE Wrapper summary for interrupts
  75. * to host
  76. *
  77. * @d_CE_WRAPPER_INDEX_BASE_LOW: The LSB Base address to which source and
  78. * destination read indices are written
  79. *
  80. * @d_CE_WRAPPER_INDEX_BASE_HIGH: The MSB Base address to which source and
  81. * destination read indices are written
  82. *
  83. * @d_HOST_IE_ADDRESS: Host Line Interrupt Enable Register
  84. *
  85. * @d_HOST_IE_COPY_COMPLETE_MASK: Bits indicating Copy complete interrupt
  86. * enable from the IE register
  87. *
  88. * @d_SR_BA_ADDRESS: LSB of Source Ring Base Address
  89. *
  90. * @d_SR_BA_ADDRESS_HIGH: MSB of Source Ring Base Address
  91. *
  92. * @d_SR_SIZE_ADDRESS: Source Ring size - number of entries and Start Offset
  93. *
  94. * @d_CE_CTRL1_ADDRESS: CE Control register
  95. *
  96. * @d_CE_CTRL1_DMAX_LENGTH_MASK: Destination buffer Max Length used for error
  97. * check
  98. *
  99. * @d_DR_BA_ADDRESS: Destination Ring Base Address Low
  100. *
  101. * @d_DR_BA_ADDRESS_HIGH: Destination Ring Base Address High
  102. *
  103. * @d_DR_SIZE_ADDRESS: Destination Ring size - number of entries Start Offset
  104. *
  105. * @d_CE_CMD_REGISTER: Implements commands to all CE Halt Flush
  106. *
  107. * @d_CE_MSI_ADDRESS: CE MSI LOW Address register
  108. *
  109. * @d_CE_MSI_ADDRESS_HIGH: CE MSI High Address register
  110. *
  111. * @d_CE_MSI_DATA: CE MSI Data Register
  112. *
  113. * @d_CE_MSI_ENABLE_BIT: Bit in CTRL1 register indication the MSI enable
  114. *
  115. * @d_MISC_IE_ADDRESS: Miscellaneous Interrupt Enable Register
  116. *
  117. * @d_MISC_IS_AXI_ERR_MASK: Bit in Misc IS indicating AXI Timeout Interrupt
  118. * status
  119. *
  120. * @d_MISC_IS_DST_ADDR_ERR_MASK: Bit in Misc IS indicating Destination Address
  121. * Error
  122. *
  123. * @d_MISC_IS_SRC_LEN_ERR_MASK: Bit in Misc IS indicating Source Zero Length
  124. * Error Interrupt status
  125. *
  126. * @d_MISC_IS_DST_MAX_LEN_VIO_MASK: Bit in Misc IS indicating Destination Max
  127. * Length Violated Interrupt status
  128. *
  129. * @d_MISC_IS_DST_RING_OVERFLOW_MASK: Bit in Misc IS indicating Destination
  130. * Ring Overflow Interrupt status
  131. *
  132. * @d_MISC_IS_SRC_RING_OVERFLOW_MASK: Bit in Misc IS indicating Source Ring
  133. * Overflow Interrupt status
  134. *
  135. * @d_SRC_WATERMARK_LOW_LSB: Source Ring Low Watermark LSB
  136. *
  137. * @d_SRC_WATERMARK_HIGH_LSB: Source Ring Low Watermark MSB
  138. *
  139. * @d_DST_WATERMARK_LOW_LSB: Destination Ring Low Watermark LSB
  140. *
  141. * @d_DST_WATERMARK_HIGH_LSB: Destination Ring High Watermark LSB
  142. *
  143. *
  144. * @d_CE_WRAPPER_INTERRUPT_SUMMARY_HOST_MSI_MASK: Bits in
  145. * d_CE_WRAPPER_INTERRUPT_SUMMARY_ADDR
  146. * indicating Copy engine
  147. * miscellaneous interrupt summary
  148. *
  149. * @d_CE_WRAPPER_INTERRUPT_SUMMARY_HOST_MSI_LSB:Bits in
  150. * d_CE_WRAPPER_INTERRUPT_SUMMARY_ADDR
  151. * indicating Host interrupts summary
  152. *
  153. * @d_CE_CTRL1_DMAX_LENGTH_LSB: LSB of Destination buffer Max Length used for
  154. * error check
  155. *
  156. * @d_CE_CTRL1_SRC_RING_BYTE_SWAP_EN_MASK: Bits indicating Source ring Byte Swap
  157. * enable. Treats source ring memory
  158. * organisation as big-endian
  159. *
  160. * @d_CE_CTRL1_DST_RING_BYTE_SWAP_EN_MASK: Bits indicating Destination ring
  161. * byte swap enable. Treats destination
  162. * ring memory organisation as big-endian
  163. *
  164. * @d_CE_CTRL1_SRC_RING_BYTE_SWAP_EN_LSB: LSB of Source ring Byte Swap enable
  165. *
  166. * @d_CE_CTRL1_DST_RING_BYTE_SWAP_EN_LSB: LSB of Destination ring Byte Swap enable
  167. *
  168. * @d_CE_WRAPPER_DEBUG_OFFSET: Offset of CE OBS BUS Select register
  169. *
  170. * @d_CE_WRAPPER_DEBUG_SEL_MSB: MSB of Control register selecting inputs for
  171. * trace/debug
  172. *
  173. * @d_CE_WRAPPER_DEBUG_SEL_LSB: LSB of Control register selecting inputs for
  174. * trace/debug
  175. *
  176. * @d_CE_WRAPPER_DEBUG_SEL_MASK: Bits indicating Control register selecting
  177. * inputs for trace/debug
  178. *
  179. * @d_CE_DEBUG_OFFSET: Offset of Copy Engine FSM Debug Status
  180. *
  181. * @d_CE_DEBUG_SEL_MSB: MSB of Copy Engine FSM Debug Status
  182. *
  183. * @d_CE_DEBUG_SEL_LSB: LSB of Copy Engine FSM Debug Status
  184. *
  185. * @d_CE_DEBUG_SEL_MASK: Bits indicating Copy Engine FSM Debug Status
  186. *
  187. */
  188. struct ce_reg_def {
  189. /* copy_engine.c */
  190. uint32_t d_DST_WR_INDEX_ADDRESS;
  191. uint32_t d_SRC_WATERMARK_ADDRESS;
  192. uint32_t d_SRC_WATERMARK_LOW_MASK;
  193. uint32_t d_SRC_WATERMARK_HIGH_MASK;
  194. uint32_t d_DST_WATERMARK_LOW_MASK;
  195. uint32_t d_DST_WATERMARK_HIGH_MASK;
  196. uint32_t d_CURRENT_SRRI_ADDRESS;
  197. uint32_t d_CURRENT_DRRI_ADDRESS;
  198. uint32_t d_HOST_IS_SRC_RING_HIGH_WATERMARK_MASK;
  199. uint32_t d_HOST_IS_SRC_RING_LOW_WATERMARK_MASK;
  200. uint32_t d_HOST_IS_DST_RING_HIGH_WATERMARK_MASK;
  201. uint32_t d_HOST_IS_DST_RING_LOW_WATERMARK_MASK;
  202. uint32_t d_HOST_IS_ADDRESS;
  203. uint32_t d_MISC_IS_ADDRESS;
  204. uint32_t d_HOST_IS_COPY_COMPLETE_MASK;
  205. uint32_t d_CE_WRAPPER_BASE_ADDRESS;
  206. uint32_t d_CE_WRAPPER_INTERRUPT_SUMMARY_ADDRESS;
  207. uint32_t d_CE_DDR_ADDRESS_FOR_RRI_LOW;
  208. uint32_t d_CE_DDR_ADDRESS_FOR_RRI_HIGH;
  209. uint32_t d_HOST_IE_ADDRESS;
  210. uint32_t d_HOST_IE_COPY_COMPLETE_MASK;
  211. uint32_t d_SR_BA_ADDRESS;
  212. uint32_t d_SR_BA_ADDRESS_HIGH;
  213. uint32_t d_SR_SIZE_ADDRESS;
  214. uint32_t d_CE_CTRL1_ADDRESS;
  215. uint32_t d_CE_CTRL1_DMAX_LENGTH_MASK;
  216. uint32_t d_DR_BA_ADDRESS;
  217. uint32_t d_DR_BA_ADDRESS_HIGH;
  218. uint32_t d_DR_SIZE_ADDRESS;
  219. uint32_t d_CE_CMD_REGISTER;
  220. uint32_t d_CE_MSI_ADDRESS;
  221. uint32_t d_CE_MSI_ADDRESS_HIGH;
  222. uint32_t d_CE_MSI_DATA;
  223. uint32_t d_CE_MSI_ENABLE_BIT;
  224. uint32_t d_MISC_IE_ADDRESS;
  225. uint32_t d_MISC_IS_AXI_ERR_MASK;
  226. uint32_t d_MISC_IS_DST_ADDR_ERR_MASK;
  227. uint32_t d_MISC_IS_SRC_LEN_ERR_MASK;
  228. uint32_t d_MISC_IS_DST_MAX_LEN_VIO_MASK;
  229. uint32_t d_MISC_IS_DST_RING_OVERFLOW_MASK;
  230. uint32_t d_MISC_IS_SRC_RING_OVERFLOW_MASK;
  231. uint32_t d_SRC_WATERMARK_LOW_LSB;
  232. uint32_t d_SRC_WATERMARK_HIGH_LSB;
  233. uint32_t d_DST_WATERMARK_LOW_LSB;
  234. uint32_t d_DST_WATERMARK_HIGH_LSB;
  235. uint32_t d_CE_WRAPPER_INTERRUPT_SUMMARY_HOST_MSI_MASK;
  236. uint32_t d_CE_WRAPPER_INTERRUPT_SUMMARY_HOST_MSI_LSB;
  237. uint32_t d_CE_CTRL1_DMAX_LENGTH_LSB;
  238. uint32_t d_CE_CTRL1_SRC_RING_BYTE_SWAP_EN_MASK;
  239. uint32_t d_CE_CTRL1_DST_RING_BYTE_SWAP_EN_MASK;
  240. uint32_t d_CE_CTRL1_SRC_RING_BYTE_SWAP_EN_LSB;
  241. uint32_t d_CE_CTRL1_DST_RING_BYTE_SWAP_EN_LSB;
  242. uint32_t d_CE_CTRL1_IDX_UPD_EN_MASK;
  243. uint32_t d_CE_WRAPPER_DEBUG_OFFSET;
  244. uint32_t d_CE_WRAPPER_DEBUG_SEL_MSB;
  245. uint32_t d_CE_WRAPPER_DEBUG_SEL_LSB;
  246. uint32_t d_CE_WRAPPER_DEBUG_SEL_MASK;
  247. uint32_t d_CE_DEBUG_OFFSET;
  248. uint32_t d_CE_DEBUG_SEL_MSB;
  249. uint32_t d_CE_DEBUG_SEL_LSB;
  250. uint32_t d_CE_DEBUG_SEL_MASK;
  251. uint32_t d_CE0_BASE_ADDRESS;
  252. uint32_t d_CE1_BASE_ADDRESS;
  253. uint32_t d_A_WIFI_APB_3_A_WCMN_APPS_CE_INTR_ENABLES;
  254. uint32_t d_A_WIFI_APB_3_A_WCMN_APPS_CE_INTR_STATUS;
  255. };
  256. #endif /* _REGTABLE_CE_H_ */