regs-apbh.h 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587
  1. /*
  2. * Freescale i.MX28 APBH Register Definitions
  3. *
  4. * Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
  5. * on behalf of DENX Software Engineering GmbH
  6. *
  7. * Based on code from LTIB:
  8. * Copyright 2008-2010 Freescale Semiconductor, Inc. All Rights Reserved.
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of the GNU General Public License as published by
  12. * the Free Software Foundation; either version 2 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU General Public License
  21. * along with this program; if not, write to the Free Software
  22. * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
  23. *
  24. */
  25. #ifndef __REGS_APBH_H__
  26. #define __REGS_APBH_H__
  27. #include <asm/imx-common/regs-common.h>
  28. #ifndef __ASSEMBLY__
  29. #if defined(CONFIG_MX23)
  30. struct mxs_apbh_regs {
  31. mxs_reg_32(hw_apbh_ctrl0)
  32. mxs_reg_32(hw_apbh_ctrl1)
  33. mxs_reg_32(hw_apbh_ctrl2)
  34. mxs_reg_32(hw_apbh_channel_ctrl)
  35. union {
  36. struct {
  37. mxs_reg_32(hw_apbh_ch_curcmdar)
  38. mxs_reg_32(hw_apbh_ch_nxtcmdar)
  39. mxs_reg_32(hw_apbh_ch_cmd)
  40. mxs_reg_32(hw_apbh_ch_bar)
  41. mxs_reg_32(hw_apbh_ch_sema)
  42. mxs_reg_32(hw_apbh_ch_debug1)
  43. mxs_reg_32(hw_apbh_ch_debug2)
  44. } ch[8];
  45. struct {
  46. mxs_reg_32(hw_apbh_ch0_curcmdar)
  47. mxs_reg_32(hw_apbh_ch0_nxtcmdar)
  48. mxs_reg_32(hw_apbh_ch0_cmd)
  49. mxs_reg_32(hw_apbh_ch0_bar)
  50. mxs_reg_32(hw_apbh_ch0_sema)
  51. mxs_reg_32(hw_apbh_ch0_debug1)
  52. mxs_reg_32(hw_apbh_ch0_debug2)
  53. mxs_reg_32(hw_apbh_ch1_curcmdar)
  54. mxs_reg_32(hw_apbh_ch1_nxtcmdar)
  55. mxs_reg_32(hw_apbh_ch1_cmd)
  56. mxs_reg_32(hw_apbh_ch1_bar)
  57. mxs_reg_32(hw_apbh_ch1_sema)
  58. mxs_reg_32(hw_apbh_ch1_debug1)
  59. mxs_reg_32(hw_apbh_ch1_debug2)
  60. mxs_reg_32(hw_apbh_ch2_curcmdar)
  61. mxs_reg_32(hw_apbh_ch2_nxtcmdar)
  62. mxs_reg_32(hw_apbh_ch2_cmd)
  63. mxs_reg_32(hw_apbh_ch2_bar)
  64. mxs_reg_32(hw_apbh_ch2_sema)
  65. mxs_reg_32(hw_apbh_ch2_debug1)
  66. mxs_reg_32(hw_apbh_ch2_debug2)
  67. mxs_reg_32(hw_apbh_ch3_curcmdar)
  68. mxs_reg_32(hw_apbh_ch3_nxtcmdar)
  69. mxs_reg_32(hw_apbh_ch3_cmd)
  70. mxs_reg_32(hw_apbh_ch3_bar)
  71. mxs_reg_32(hw_apbh_ch3_sema)
  72. mxs_reg_32(hw_apbh_ch3_debug1)
  73. mxs_reg_32(hw_apbh_ch3_debug2)
  74. mxs_reg_32(hw_apbh_ch4_curcmdar)
  75. mxs_reg_32(hw_apbh_ch4_nxtcmdar)
  76. mxs_reg_32(hw_apbh_ch4_cmd)
  77. mxs_reg_32(hw_apbh_ch4_bar)
  78. mxs_reg_32(hw_apbh_ch4_sema)
  79. mxs_reg_32(hw_apbh_ch4_debug1)
  80. mxs_reg_32(hw_apbh_ch4_debug2)
  81. mxs_reg_32(hw_apbh_ch5_curcmdar)
  82. mxs_reg_32(hw_apbh_ch5_nxtcmdar)
  83. mxs_reg_32(hw_apbh_ch5_cmd)
  84. mxs_reg_32(hw_apbh_ch5_bar)
  85. mxs_reg_32(hw_apbh_ch5_sema)
  86. mxs_reg_32(hw_apbh_ch5_debug1)
  87. mxs_reg_32(hw_apbh_ch5_debug2)
  88. mxs_reg_32(hw_apbh_ch6_curcmdar)
  89. mxs_reg_32(hw_apbh_ch6_nxtcmdar)
  90. mxs_reg_32(hw_apbh_ch6_cmd)
  91. mxs_reg_32(hw_apbh_ch6_bar)
  92. mxs_reg_32(hw_apbh_ch6_sema)
  93. mxs_reg_32(hw_apbh_ch6_debug1)
  94. mxs_reg_32(hw_apbh_ch6_debug2)
  95. mxs_reg_32(hw_apbh_ch7_curcmdar)
  96. mxs_reg_32(hw_apbh_ch7_nxtcmdar)
  97. mxs_reg_32(hw_apbh_ch7_cmd)
  98. mxs_reg_32(hw_apbh_ch7_bar)
  99. mxs_reg_32(hw_apbh_ch7_sema)
  100. mxs_reg_32(hw_apbh_ch7_debug1)
  101. mxs_reg_32(hw_apbh_ch7_debug2)
  102. };
  103. };
  104. mxs_reg_32(hw_apbh_version)
  105. };
  106. #elif defined(CONFIG_MX28)
  107. struct mxs_apbh_regs {
  108. mxs_reg_32(hw_apbh_ctrl0)
  109. mxs_reg_32(hw_apbh_ctrl1)
  110. mxs_reg_32(hw_apbh_ctrl2)
  111. mxs_reg_32(hw_apbh_channel_ctrl)
  112. mxs_reg_32(hw_apbh_devsel)
  113. mxs_reg_32(hw_apbh_dma_burst_size)
  114. mxs_reg_32(hw_apbh_debug)
  115. uint32_t reserved[36];
  116. union {
  117. struct {
  118. mxs_reg_32(hw_apbh_ch_curcmdar)
  119. mxs_reg_32(hw_apbh_ch_nxtcmdar)
  120. mxs_reg_32(hw_apbh_ch_cmd)
  121. mxs_reg_32(hw_apbh_ch_bar)
  122. mxs_reg_32(hw_apbh_ch_sema)
  123. mxs_reg_32(hw_apbh_ch_debug1)
  124. mxs_reg_32(hw_apbh_ch_debug2)
  125. } ch[16];
  126. struct {
  127. mxs_reg_32(hw_apbh_ch0_curcmdar)
  128. mxs_reg_32(hw_apbh_ch0_nxtcmdar)
  129. mxs_reg_32(hw_apbh_ch0_cmd)
  130. mxs_reg_32(hw_apbh_ch0_bar)
  131. mxs_reg_32(hw_apbh_ch0_sema)
  132. mxs_reg_32(hw_apbh_ch0_debug1)
  133. mxs_reg_32(hw_apbh_ch0_debug2)
  134. mxs_reg_32(hw_apbh_ch1_curcmdar)
  135. mxs_reg_32(hw_apbh_ch1_nxtcmdar)
  136. mxs_reg_32(hw_apbh_ch1_cmd)
  137. mxs_reg_32(hw_apbh_ch1_bar)
  138. mxs_reg_32(hw_apbh_ch1_sema)
  139. mxs_reg_32(hw_apbh_ch1_debug1)
  140. mxs_reg_32(hw_apbh_ch1_debug2)
  141. mxs_reg_32(hw_apbh_ch2_curcmdar)
  142. mxs_reg_32(hw_apbh_ch2_nxtcmdar)
  143. mxs_reg_32(hw_apbh_ch2_cmd)
  144. mxs_reg_32(hw_apbh_ch2_bar)
  145. mxs_reg_32(hw_apbh_ch2_sema)
  146. mxs_reg_32(hw_apbh_ch2_debug1)
  147. mxs_reg_32(hw_apbh_ch2_debug2)
  148. mxs_reg_32(hw_apbh_ch3_curcmdar)
  149. mxs_reg_32(hw_apbh_ch3_nxtcmdar)
  150. mxs_reg_32(hw_apbh_ch3_cmd)
  151. mxs_reg_32(hw_apbh_ch3_bar)
  152. mxs_reg_32(hw_apbh_ch3_sema)
  153. mxs_reg_32(hw_apbh_ch3_debug1)
  154. mxs_reg_32(hw_apbh_ch3_debug2)
  155. mxs_reg_32(hw_apbh_ch4_curcmdar)
  156. mxs_reg_32(hw_apbh_ch4_nxtcmdar)
  157. mxs_reg_32(hw_apbh_ch4_cmd)
  158. mxs_reg_32(hw_apbh_ch4_bar)
  159. mxs_reg_32(hw_apbh_ch4_sema)
  160. mxs_reg_32(hw_apbh_ch4_debug1)
  161. mxs_reg_32(hw_apbh_ch4_debug2)
  162. mxs_reg_32(hw_apbh_ch5_curcmdar)
  163. mxs_reg_32(hw_apbh_ch5_nxtcmdar)
  164. mxs_reg_32(hw_apbh_ch5_cmd)
  165. mxs_reg_32(hw_apbh_ch5_bar)
  166. mxs_reg_32(hw_apbh_ch5_sema)
  167. mxs_reg_32(hw_apbh_ch5_debug1)
  168. mxs_reg_32(hw_apbh_ch5_debug2)
  169. mxs_reg_32(hw_apbh_ch6_curcmdar)
  170. mxs_reg_32(hw_apbh_ch6_nxtcmdar)
  171. mxs_reg_32(hw_apbh_ch6_cmd)
  172. mxs_reg_32(hw_apbh_ch6_bar)
  173. mxs_reg_32(hw_apbh_ch6_sema)
  174. mxs_reg_32(hw_apbh_ch6_debug1)
  175. mxs_reg_32(hw_apbh_ch6_debug2)
  176. mxs_reg_32(hw_apbh_ch7_curcmdar)
  177. mxs_reg_32(hw_apbh_ch7_nxtcmdar)
  178. mxs_reg_32(hw_apbh_ch7_cmd)
  179. mxs_reg_32(hw_apbh_ch7_bar)
  180. mxs_reg_32(hw_apbh_ch7_sema)
  181. mxs_reg_32(hw_apbh_ch7_debug1)
  182. mxs_reg_32(hw_apbh_ch7_debug2)
  183. mxs_reg_32(hw_apbh_ch8_curcmdar)
  184. mxs_reg_32(hw_apbh_ch8_nxtcmdar)
  185. mxs_reg_32(hw_apbh_ch8_cmd)
  186. mxs_reg_32(hw_apbh_ch8_bar)
  187. mxs_reg_32(hw_apbh_ch8_sema)
  188. mxs_reg_32(hw_apbh_ch8_debug1)
  189. mxs_reg_32(hw_apbh_ch8_debug2)
  190. mxs_reg_32(hw_apbh_ch9_curcmdar)
  191. mxs_reg_32(hw_apbh_ch9_nxtcmdar)
  192. mxs_reg_32(hw_apbh_ch9_cmd)
  193. mxs_reg_32(hw_apbh_ch9_bar)
  194. mxs_reg_32(hw_apbh_ch9_sema)
  195. mxs_reg_32(hw_apbh_ch9_debug1)
  196. mxs_reg_32(hw_apbh_ch9_debug2)
  197. mxs_reg_32(hw_apbh_ch10_curcmdar)
  198. mxs_reg_32(hw_apbh_ch10_nxtcmdar)
  199. mxs_reg_32(hw_apbh_ch10_cmd)
  200. mxs_reg_32(hw_apbh_ch10_bar)
  201. mxs_reg_32(hw_apbh_ch10_sema)
  202. mxs_reg_32(hw_apbh_ch10_debug1)
  203. mxs_reg_32(hw_apbh_ch10_debug2)
  204. mxs_reg_32(hw_apbh_ch11_curcmdar)
  205. mxs_reg_32(hw_apbh_ch11_nxtcmdar)
  206. mxs_reg_32(hw_apbh_ch11_cmd)
  207. mxs_reg_32(hw_apbh_ch11_bar)
  208. mxs_reg_32(hw_apbh_ch11_sema)
  209. mxs_reg_32(hw_apbh_ch11_debug1)
  210. mxs_reg_32(hw_apbh_ch11_debug2)
  211. mxs_reg_32(hw_apbh_ch12_curcmdar)
  212. mxs_reg_32(hw_apbh_ch12_nxtcmdar)
  213. mxs_reg_32(hw_apbh_ch12_cmd)
  214. mxs_reg_32(hw_apbh_ch12_bar)
  215. mxs_reg_32(hw_apbh_ch12_sema)
  216. mxs_reg_32(hw_apbh_ch12_debug1)
  217. mxs_reg_32(hw_apbh_ch12_debug2)
  218. mxs_reg_32(hw_apbh_ch13_curcmdar)
  219. mxs_reg_32(hw_apbh_ch13_nxtcmdar)
  220. mxs_reg_32(hw_apbh_ch13_cmd)
  221. mxs_reg_32(hw_apbh_ch13_bar)
  222. mxs_reg_32(hw_apbh_ch13_sema)
  223. mxs_reg_32(hw_apbh_ch13_debug1)
  224. mxs_reg_32(hw_apbh_ch13_debug2)
  225. mxs_reg_32(hw_apbh_ch14_curcmdar)
  226. mxs_reg_32(hw_apbh_ch14_nxtcmdar)
  227. mxs_reg_32(hw_apbh_ch14_cmd)
  228. mxs_reg_32(hw_apbh_ch14_bar)
  229. mxs_reg_32(hw_apbh_ch14_sema)
  230. mxs_reg_32(hw_apbh_ch14_debug1)
  231. mxs_reg_32(hw_apbh_ch14_debug2)
  232. mxs_reg_32(hw_apbh_ch15_curcmdar)
  233. mxs_reg_32(hw_apbh_ch15_nxtcmdar)
  234. mxs_reg_32(hw_apbh_ch15_cmd)
  235. mxs_reg_32(hw_apbh_ch15_bar)
  236. mxs_reg_32(hw_apbh_ch15_sema)
  237. mxs_reg_32(hw_apbh_ch15_debug1)
  238. mxs_reg_32(hw_apbh_ch15_debug2)
  239. };
  240. };
  241. mxs_reg_32(hw_apbh_version)
  242. };
  243. #endif
  244. #endif
  245. #define APBH_CTRL0_SFTRST (1 << 31)
  246. #define APBH_CTRL0_CLKGATE (1 << 30)
  247. #define APBH_CTRL0_AHB_BURST8_EN (1 << 29)
  248. #define APBH_CTRL0_APB_BURST_EN (1 << 28)
  249. #if defined(CONFIG_MX23)
  250. #define APBH_CTRL0_RSVD0_MASK (0xf << 24)
  251. #define APBH_CTRL0_RSVD0_OFFSET 24
  252. #define APBH_CTRL0_RESET_CHANNEL_MASK (0xff << 16)
  253. #define APBH_CTRL0_RESET_CHANNEL_OFFSET 16
  254. #define APBH_CTRL0_CLKGATE_CHANNEL_MASK (0xff << 8)
  255. #define APBH_CTRL0_CLKGATE_CHANNEL_OFFSET 8
  256. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP0 0x02
  257. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP1 0x04
  258. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND0 0x10
  259. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND1 0x20
  260. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND2 0x40
  261. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND3 0x80
  262. #elif defined(CONFIG_MX28)
  263. #define APBH_CTRL0_RSVD0_MASK (0xfff << 16)
  264. #define APBH_CTRL0_RSVD0_OFFSET 16
  265. #define APBH_CTRL0_CLKGATE_CHANNEL_MASK 0xffff
  266. #define APBH_CTRL0_CLKGATE_CHANNEL_OFFSET 0
  267. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP0 0x0001
  268. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP1 0x0002
  269. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP2 0x0004
  270. #define APBH_CTRL0_CLKGATE_CHANNEL_SSP3 0x0008
  271. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND0 0x0010
  272. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND1 0x0020
  273. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND2 0x0040
  274. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND3 0x0080
  275. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND4 0x0100
  276. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND5 0x0200
  277. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND6 0x0400
  278. #define APBH_CTRL0_CLKGATE_CHANNEL_NAND7 0x0800
  279. #define APBH_CTRL0_CLKGATE_CHANNEL_HSADC 0x1000
  280. #define APBH_CTRL0_CLKGATE_CHANNEL_LCDIF 0x2000
  281. #endif
  282. #define APBH_CTRL1_CH15_CMDCMPLT_IRQ_EN (1 << 31)
  283. #define APBH_CTRL1_CH14_CMDCMPLT_IRQ_EN (1 << 30)
  284. #define APBH_CTRL1_CH13_CMDCMPLT_IRQ_EN (1 << 29)
  285. #define APBH_CTRL1_CH12_CMDCMPLT_IRQ_EN (1 << 28)
  286. #define APBH_CTRL1_CH11_CMDCMPLT_IRQ_EN (1 << 27)
  287. #define APBH_CTRL1_CH10_CMDCMPLT_IRQ_EN (1 << 26)
  288. #define APBH_CTRL1_CH9_CMDCMPLT_IRQ_EN (1 << 25)
  289. #define APBH_CTRL1_CH8_CMDCMPLT_IRQ_EN (1 << 24)
  290. #define APBH_CTRL1_CH7_CMDCMPLT_IRQ_EN (1 << 23)
  291. #define APBH_CTRL1_CH6_CMDCMPLT_IRQ_EN (1 << 22)
  292. #define APBH_CTRL1_CH5_CMDCMPLT_IRQ_EN (1 << 21)
  293. #define APBH_CTRL1_CH4_CMDCMPLT_IRQ_EN (1 << 20)
  294. #define APBH_CTRL1_CH3_CMDCMPLT_IRQ_EN (1 << 19)
  295. #define APBH_CTRL1_CH2_CMDCMPLT_IRQ_EN (1 << 18)
  296. #define APBH_CTRL1_CH1_CMDCMPLT_IRQ_EN (1 << 17)
  297. #define APBH_CTRL1_CH0_CMDCMPLT_IRQ_EN (1 << 16)
  298. #define APBH_CTRL1_CH_CMDCMPLT_IRQ_EN_OFFSET 16
  299. #define APBH_CTRL1_CH_CMDCMPLT_IRQ_EN_MASK (0xffff << 16)
  300. #define APBH_CTRL1_CH15_CMDCMPLT_IRQ (1 << 15)
  301. #define APBH_CTRL1_CH14_CMDCMPLT_IRQ (1 << 14)
  302. #define APBH_CTRL1_CH13_CMDCMPLT_IRQ (1 << 13)
  303. #define APBH_CTRL1_CH12_CMDCMPLT_IRQ (1 << 12)
  304. #define APBH_CTRL1_CH11_CMDCMPLT_IRQ (1 << 11)
  305. #define APBH_CTRL1_CH10_CMDCMPLT_IRQ (1 << 10)
  306. #define APBH_CTRL1_CH9_CMDCMPLT_IRQ (1 << 9)
  307. #define APBH_CTRL1_CH8_CMDCMPLT_IRQ (1 << 8)
  308. #define APBH_CTRL1_CH7_CMDCMPLT_IRQ (1 << 7)
  309. #define APBH_CTRL1_CH6_CMDCMPLT_IRQ (1 << 6)
  310. #define APBH_CTRL1_CH5_CMDCMPLT_IRQ (1 << 5)
  311. #define APBH_CTRL1_CH4_CMDCMPLT_IRQ (1 << 4)
  312. #define APBH_CTRL1_CH3_CMDCMPLT_IRQ (1 << 3)
  313. #define APBH_CTRL1_CH2_CMDCMPLT_IRQ (1 << 2)
  314. #define APBH_CTRL1_CH1_CMDCMPLT_IRQ (1 << 1)
  315. #define APBH_CTRL1_CH0_CMDCMPLT_IRQ (1 << 0)
  316. #define APBH_CTRL2_CH15_ERROR_STATUS (1 << 31)
  317. #define APBH_CTRL2_CH14_ERROR_STATUS (1 << 30)
  318. #define APBH_CTRL2_CH13_ERROR_STATUS (1 << 29)
  319. #define APBH_CTRL2_CH12_ERROR_STATUS (1 << 28)
  320. #define APBH_CTRL2_CH11_ERROR_STATUS (1 << 27)
  321. #define APBH_CTRL2_CH10_ERROR_STATUS (1 << 26)
  322. #define APBH_CTRL2_CH9_ERROR_STATUS (1 << 25)
  323. #define APBH_CTRL2_CH8_ERROR_STATUS (1 << 24)
  324. #define APBH_CTRL2_CH7_ERROR_STATUS (1 << 23)
  325. #define APBH_CTRL2_CH6_ERROR_STATUS (1 << 22)
  326. #define APBH_CTRL2_CH5_ERROR_STATUS (1 << 21)
  327. #define APBH_CTRL2_CH4_ERROR_STATUS (1 << 20)
  328. #define APBH_CTRL2_CH3_ERROR_STATUS (1 << 19)
  329. #define APBH_CTRL2_CH2_ERROR_STATUS (1 << 18)
  330. #define APBH_CTRL2_CH1_ERROR_STATUS (1 << 17)
  331. #define APBH_CTRL2_CH0_ERROR_STATUS (1 << 16)
  332. #define APBH_CTRL2_CH15_ERROR_IRQ (1 << 15)
  333. #define APBH_CTRL2_CH14_ERROR_IRQ (1 << 14)
  334. #define APBH_CTRL2_CH13_ERROR_IRQ (1 << 13)
  335. #define APBH_CTRL2_CH12_ERROR_IRQ (1 << 12)
  336. #define APBH_CTRL2_CH11_ERROR_IRQ (1 << 11)
  337. #define APBH_CTRL2_CH10_ERROR_IRQ (1 << 10)
  338. #define APBH_CTRL2_CH9_ERROR_IRQ (1 << 9)
  339. #define APBH_CTRL2_CH8_ERROR_IRQ (1 << 8)
  340. #define APBH_CTRL2_CH7_ERROR_IRQ (1 << 7)
  341. #define APBH_CTRL2_CH6_ERROR_IRQ (1 << 6)
  342. #define APBH_CTRL2_CH5_ERROR_IRQ (1 << 5)
  343. #define APBH_CTRL2_CH4_ERROR_IRQ (1 << 4)
  344. #define APBH_CTRL2_CH3_ERROR_IRQ (1 << 3)
  345. #define APBH_CTRL2_CH2_ERROR_IRQ (1 << 2)
  346. #define APBH_CTRL2_CH1_ERROR_IRQ (1 << 1)
  347. #define APBH_CTRL2_CH0_ERROR_IRQ (1 << 0)
  348. #if defined(CONFIG_MX28)
  349. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_MASK (0xffff << 16)
  350. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_OFFSET 16
  351. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_SSP0 (0x0001 << 16)
  352. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_SSP1 (0x0002 << 16)
  353. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_SSP2 (0x0004 << 16)
  354. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_SSP3 (0x0008 << 16)
  355. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND0 (0x0010 << 16)
  356. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND1 (0x0020 << 16)
  357. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND2 (0x0040 << 16)
  358. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND3 (0x0080 << 16)
  359. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND4 (0x0100 << 16)
  360. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND5 (0x0200 << 16)
  361. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND6 (0x0400 << 16)
  362. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_NAND7 (0x0800 << 16)
  363. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_HSADC (0x1000 << 16)
  364. #define APBH_CHANNEL_CTRL_RESET_CHANNEL_LCDIF (0x2000 << 16)
  365. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_MASK 0xffff
  366. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_OFFSET 0
  367. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_SSP0 0x0001
  368. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_SSP1 0x0002
  369. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_SSP2 0x0004
  370. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_SSP3 0x0008
  371. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND0 0x0010
  372. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND1 0x0020
  373. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND2 0x0040
  374. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND3 0x0080
  375. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND4 0x0100
  376. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND5 0x0200
  377. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND6 0x0400
  378. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_NAND7 0x0800
  379. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_HSADC 0x1000
  380. #define APBH_CHANNEL_CTRL_FREEZE_CHANNEL_LCDIF 0x2000
  381. #endif
  382. #if defined(CONFIG_MX23)
  383. #define APBH_DEVSEL_CH7_MASK (0xf << 28)
  384. #define APBH_DEVSEL_CH7_OFFSET 28
  385. #define APBH_DEVSEL_CH6_MASK (0xf << 24)
  386. #define APBH_DEVSEL_CH6_OFFSET 24
  387. #define APBH_DEVSEL_CH5_MASK (0xf << 20)
  388. #define APBH_DEVSEL_CH5_OFFSET 20
  389. #define APBH_DEVSEL_CH4_MASK (0xf << 16)
  390. #define APBH_DEVSEL_CH4_OFFSET 16
  391. #define APBH_DEVSEL_CH3_MASK (0xf << 12)
  392. #define APBH_DEVSEL_CH3_OFFSET 12
  393. #define APBH_DEVSEL_CH2_MASK (0xf << 8)
  394. #define APBH_DEVSEL_CH2_OFFSET 8
  395. #define APBH_DEVSEL_CH1_MASK (0xf << 4)
  396. #define APBH_DEVSEL_CH1_OFFSET 4
  397. #define APBH_DEVSEL_CH0_MASK (0xf << 0)
  398. #define APBH_DEVSEL_CH0_OFFSET 0
  399. #elif defined(CONFIG_MX28)
  400. #define APBH_DEVSEL_CH15_MASK (0x3 << 30)
  401. #define APBH_DEVSEL_CH15_OFFSET 30
  402. #define APBH_DEVSEL_CH14_MASK (0x3 << 28)
  403. #define APBH_DEVSEL_CH14_OFFSET 28
  404. #define APBH_DEVSEL_CH13_MASK (0x3 << 26)
  405. #define APBH_DEVSEL_CH13_OFFSET 26
  406. #define APBH_DEVSEL_CH12_MASK (0x3 << 24)
  407. #define APBH_DEVSEL_CH12_OFFSET 24
  408. #define APBH_DEVSEL_CH11_MASK (0x3 << 22)
  409. #define APBH_DEVSEL_CH11_OFFSET 22
  410. #define APBH_DEVSEL_CH10_MASK (0x3 << 20)
  411. #define APBH_DEVSEL_CH10_OFFSET 20
  412. #define APBH_DEVSEL_CH9_MASK (0x3 << 18)
  413. #define APBH_DEVSEL_CH9_OFFSET 18
  414. #define APBH_DEVSEL_CH8_MASK (0x3 << 16)
  415. #define APBH_DEVSEL_CH8_OFFSET 16
  416. #define APBH_DEVSEL_CH7_MASK (0x3 << 14)
  417. #define APBH_DEVSEL_CH7_OFFSET 14
  418. #define APBH_DEVSEL_CH6_MASK (0x3 << 12)
  419. #define APBH_DEVSEL_CH6_OFFSET 12
  420. #define APBH_DEVSEL_CH5_MASK (0x3 << 10)
  421. #define APBH_DEVSEL_CH5_OFFSET 10
  422. #define APBH_DEVSEL_CH4_MASK (0x3 << 8)
  423. #define APBH_DEVSEL_CH4_OFFSET 8
  424. #define APBH_DEVSEL_CH3_MASK (0x3 << 6)
  425. #define APBH_DEVSEL_CH3_OFFSET 6
  426. #define APBH_DEVSEL_CH2_MASK (0x3 << 4)
  427. #define APBH_DEVSEL_CH2_OFFSET 4
  428. #define APBH_DEVSEL_CH1_MASK (0x3 << 2)
  429. #define APBH_DEVSEL_CH1_OFFSET 2
  430. #define APBH_DEVSEL_CH0_MASK (0x3 << 0)
  431. #define APBH_DEVSEL_CH0_OFFSET 0
  432. #endif
  433. #if defined(CONFIG_MX28)
  434. #define APBH_DMA_BURST_SIZE_CH15_MASK (0x3 << 30)
  435. #define APBH_DMA_BURST_SIZE_CH15_OFFSET 30
  436. #define APBH_DMA_BURST_SIZE_CH14_MASK (0x3 << 28)
  437. #define APBH_DMA_BURST_SIZE_CH14_OFFSET 28
  438. #define APBH_DMA_BURST_SIZE_CH13_MASK (0x3 << 26)
  439. #define APBH_DMA_BURST_SIZE_CH13_OFFSET 26
  440. #define APBH_DMA_BURST_SIZE_CH12_MASK (0x3 << 24)
  441. #define APBH_DMA_BURST_SIZE_CH12_OFFSET 24
  442. #define APBH_DMA_BURST_SIZE_CH11_MASK (0x3 << 22)
  443. #define APBH_DMA_BURST_SIZE_CH11_OFFSET 22
  444. #define APBH_DMA_BURST_SIZE_CH10_MASK (0x3 << 20)
  445. #define APBH_DMA_BURST_SIZE_CH10_OFFSET 20
  446. #define APBH_DMA_BURST_SIZE_CH9_MASK (0x3 << 18)
  447. #define APBH_DMA_BURST_SIZE_CH9_OFFSET 18
  448. #define APBH_DMA_BURST_SIZE_CH8_MASK (0x3 << 16)
  449. #define APBH_DMA_BURST_SIZE_CH8_OFFSET 16
  450. #define APBH_DMA_BURST_SIZE_CH8_BURST0 (0x0 << 16)
  451. #define APBH_DMA_BURST_SIZE_CH8_BURST4 (0x1 << 16)
  452. #define APBH_DMA_BURST_SIZE_CH8_BURST8 (0x2 << 16)
  453. #define APBH_DMA_BURST_SIZE_CH7_MASK (0x3 << 14)
  454. #define APBH_DMA_BURST_SIZE_CH7_OFFSET 14
  455. #define APBH_DMA_BURST_SIZE_CH6_MASK (0x3 << 12)
  456. #define APBH_DMA_BURST_SIZE_CH6_OFFSET 12
  457. #define APBH_DMA_BURST_SIZE_CH5_MASK (0x3 << 10)
  458. #define APBH_DMA_BURST_SIZE_CH5_OFFSET 10
  459. #define APBH_DMA_BURST_SIZE_CH4_MASK (0x3 << 8)
  460. #define APBH_DMA_BURST_SIZE_CH4_OFFSET 8
  461. #define APBH_DMA_BURST_SIZE_CH3_MASK (0x3 << 6)
  462. #define APBH_DMA_BURST_SIZE_CH3_OFFSET 6
  463. #define APBH_DMA_BURST_SIZE_CH3_BURST0 (0x0 << 6)
  464. #define APBH_DMA_BURST_SIZE_CH3_BURST4 (0x1 << 6)
  465. #define APBH_DMA_BURST_SIZE_CH3_BURST8 (0x2 << 6)
  466. #define APBH_DMA_BURST_SIZE_CH2_MASK (0x3 << 4)
  467. #define APBH_DMA_BURST_SIZE_CH2_OFFSET 4
  468. #define APBH_DMA_BURST_SIZE_CH2_BURST0 (0x0 << 4)
  469. #define APBH_DMA_BURST_SIZE_CH2_BURST4 (0x1 << 4)
  470. #define APBH_DMA_BURST_SIZE_CH2_BURST8 (0x2 << 4)
  471. #define APBH_DMA_BURST_SIZE_CH1_MASK (0x3 << 2)
  472. #define APBH_DMA_BURST_SIZE_CH1_OFFSET 2
  473. #define APBH_DMA_BURST_SIZE_CH1_BURST0 (0x0 << 2)
  474. #define APBH_DMA_BURST_SIZE_CH1_BURST4 (0x1 << 2)
  475. #define APBH_DMA_BURST_SIZE_CH1_BURST8 (0x2 << 2)
  476. #define APBH_DMA_BURST_SIZE_CH0_MASK 0x3
  477. #define APBH_DMA_BURST_SIZE_CH0_OFFSET 0
  478. #define APBH_DMA_BURST_SIZE_CH0_BURST0 0x0
  479. #define APBH_DMA_BURST_SIZE_CH0_BURST4 0x1
  480. #define APBH_DMA_BURST_SIZE_CH0_BURST8 0x2
  481. #define APBH_DEBUG_GPMI_ONE_FIFO (1 << 0)
  482. #endif
  483. #define APBH_CHn_CURCMDAR_CMD_ADDR_MASK 0xffffffff
  484. #define APBH_CHn_CURCMDAR_CMD_ADDR_OFFSET 0
  485. #define APBH_CHn_NXTCMDAR_CMD_ADDR_MASK 0xffffffff
  486. #define APBH_CHn_NXTCMDAR_CMD_ADDR_OFFSET 0
  487. #define APBH_CHn_CMD_XFER_COUNT_MASK (0xffff << 16)
  488. #define APBH_CHn_CMD_XFER_COUNT_OFFSET 16
  489. #define APBH_CHn_CMD_CMDWORDS_MASK (0xf << 12)
  490. #define APBH_CHn_CMD_CMDWORDS_OFFSET 12
  491. #define APBH_CHn_CMD_HALTONTERMINATE (1 << 8)
  492. #define APBH_CHn_CMD_WAIT4ENDCMD (1 << 7)
  493. #define APBH_CHn_CMD_SEMAPHORE (1 << 6)
  494. #define APBH_CHn_CMD_NANDWAIT4READY (1 << 5)
  495. #define APBH_CHn_CMD_NANDLOCK (1 << 4)
  496. #define APBH_CHn_CMD_IRQONCMPLT (1 << 3)
  497. #define APBH_CHn_CMD_CHAIN (1 << 2)
  498. #define APBH_CHn_CMD_COMMAND_MASK 0x3
  499. #define APBH_CHn_CMD_COMMAND_OFFSET 0
  500. #define APBH_CHn_CMD_COMMAND_NO_DMA_XFER 0x0
  501. #define APBH_CHn_CMD_COMMAND_DMA_WRITE 0x1
  502. #define APBH_CHn_CMD_COMMAND_DMA_READ 0x2
  503. #define APBH_CHn_CMD_COMMAND_DMA_SENSE 0x3
  504. #define APBH_CHn_BAR_ADDRESS_MASK 0xffffffff
  505. #define APBH_CHn_BAR_ADDRESS_OFFSET 0
  506. #define APBH_CHn_SEMA_RSVD2_MASK (0xff << 24)
  507. #define APBH_CHn_SEMA_RSVD2_OFFSET 24
  508. #define APBH_CHn_SEMA_PHORE_MASK (0xff << 16)
  509. #define APBH_CHn_SEMA_PHORE_OFFSET 16
  510. #define APBH_CHn_SEMA_RSVD1_MASK (0xff << 8)
  511. #define APBH_CHn_SEMA_RSVD1_OFFSET 8
  512. #define APBH_CHn_SEMA_INCREMENT_SEMA_MASK (0xff << 0)
  513. #define APBH_CHn_SEMA_INCREMENT_SEMA_OFFSET 0
  514. #define APBH_CHn_DEBUG1_REQ (1 << 31)
  515. #define APBH_CHn_DEBUG1_BURST (1 << 30)
  516. #define APBH_CHn_DEBUG1_KICK (1 << 29)
  517. #define APBH_CHn_DEBUG1_END (1 << 28)
  518. #define APBH_CHn_DEBUG1_SENSE (1 << 27)
  519. #define APBH_CHn_DEBUG1_READY (1 << 26)
  520. #define APBH_CHn_DEBUG1_LOCK (1 << 25)
  521. #define APBH_CHn_DEBUG1_NEXTCMDADDRVALID (1 << 24)
  522. #define APBH_CHn_DEBUG1_RD_FIFO_EMPTY (1 << 23)
  523. #define APBH_CHn_DEBUG1_RD_FIFO_FULL (1 << 22)
  524. #define APBH_CHn_DEBUG1_WR_FIFO_EMPTY (1 << 21)
  525. #define APBH_CHn_DEBUG1_WR_FIFO_FULL (1 << 20)
  526. #define APBH_CHn_DEBUG1_RSVD1_MASK (0x7fff << 5)
  527. #define APBH_CHn_DEBUG1_RSVD1_OFFSET 5
  528. #define APBH_CHn_DEBUG1_STATEMACHINE_MASK 0x1f
  529. #define APBH_CHn_DEBUG1_STATEMACHINE_OFFSET 0
  530. #define APBH_CHn_DEBUG1_STATEMACHINE_IDLE 0x00
  531. #define APBH_CHn_DEBUG1_STATEMACHINE_REQ_CMD1 0x01
  532. #define APBH_CHn_DEBUG1_STATEMACHINE_REQ_CMD3 0x02
  533. #define APBH_CHn_DEBUG1_STATEMACHINE_REQ_CMD2 0x03
  534. #define APBH_CHn_DEBUG1_STATEMACHINE_XFER_DECODE 0x04
  535. #define APBH_CHn_DEBUG1_STATEMACHINE_REQ_WAIT 0x05
  536. #define APBH_CHn_DEBUG1_STATEMACHINE_REQ_CMD4 0x06
  537. #define APBH_CHn_DEBUG1_STATEMACHINE_PIO_REQ 0x07
  538. #define APBH_CHn_DEBUG1_STATEMACHINE_READ_FLUSH 0x08
  539. #define APBH_CHn_DEBUG1_STATEMACHINE_READ_WAIT 0x09
  540. #define APBH_CHn_DEBUG1_STATEMACHINE_WRITE 0x0c
  541. #define APBH_CHn_DEBUG1_STATEMACHINE_READ_REQ 0x0d
  542. #define APBH_CHn_DEBUG1_STATEMACHINE_CHECK_CHAIN 0x0e
  543. #define APBH_CHn_DEBUG1_STATEMACHINE_XFER_COMPLETE 0x0f
  544. #define APBH_CHn_DEBUG1_STATEMACHINE_TERMINATE 0x14
  545. #define APBH_CHn_DEBUG1_STATEMACHINE_WAIT_END 0x15
  546. #define APBH_CHn_DEBUG1_STATEMACHINE_WRITE_WAIT 0x1c
  547. #define APBH_CHn_DEBUG1_STATEMACHINE_HALT_AFTER_TERM 0x1d
  548. #define APBH_CHn_DEBUG1_STATEMACHINE_CHECK_WAIT 0x1e
  549. #define APBH_CHn_DEBUG1_STATEMACHINE_WAIT_READY 0x1f
  550. #define APBH_CHn_DEBUG2_APB_BYTES_MASK (0xffff << 16)
  551. #define APBH_CHn_DEBUG2_APB_BYTES_OFFSET 16
  552. #define APBH_CHn_DEBUG2_AHB_BYTES_MASK 0xffff
  553. #define APBH_CHn_DEBUG2_AHB_BYTES_OFFSET 0
  554. #define APBH_VERSION_MAJOR_MASK (0xff << 24)
  555. #define APBH_VERSION_MAJOR_OFFSET 24
  556. #define APBH_VERSION_MINOR_MASK (0xff << 16)
  557. #define APBH_VERSION_MINOR_OFFSET 16
  558. #define APBH_VERSION_STEP_MASK 0xffff
  559. #define APBH_VERSION_STEP_OFFSET 0
  560. #endif /* __REGS_APBH_H__ */