cdefBF52x_base.h 70 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204
  1. /*
  2. * File: include/asm-blackfin/mach-bf527/cdefBF52x_base.h
  3. * Based on:
  4. * Author:
  5. *
  6. * Created:
  7. * Description:
  8. *
  9. * Rev:
  10. *
  11. * Modified:
  12. *
  13. * Bugs: Enter bugs at http://blackfin.uclinux.org/
  14. *
  15. * This program is free software; you can redistribute it and/or modify
  16. * it under the terms of the GNU General Public License as published by
  17. * the Free Software Foundation; either version 2, or (at your option)
  18. * any later version.
  19. *
  20. * This program is distributed in the hope that it will be useful,
  21. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  22. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  23. * GNU General Public License for more details.
  24. *
  25. * You should have received a copy of the GNU General Public License
  26. * along with this program; see the file COPYING.
  27. * If not, write to the Free Software Foundation,
  28. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
  29. */
  30. #ifndef _CDEF_BF52X_H
  31. #define _CDEF_BF52X_H
  32. #include <asm/system.h>
  33. #include <asm/blackfin.h>
  34. #include "defBF52x_base.h"
  35. /* Include core specific register pointer definitions */
  36. #include <asm/cdef_LPBlackfin.h>
  37. /* ==== begin from cdefBF534.h ==== */
  38. /* Clock and System Control (0xFFC00000 - 0xFFC000FF) */
  39. #define bfin_read_PLL_CTL() bfin_read16(PLL_CTL)
  40. /* Writing to PLL_CTL initiates a PLL relock sequence. */
  41. static __inline__ void bfin_write_PLL_CTL(unsigned int val)
  42. {
  43. unsigned long flags, iwr0, iwr1;
  44. if (val == bfin_read_PLL_CTL())
  45. return;
  46. local_irq_save(flags);
  47. /* Enable the PLL Wakeup bit in SIC IWR */
  48. iwr0 = bfin_read32(SIC_IWR0);
  49. iwr1 = bfin_read32(SIC_IWR1);
  50. /* Only allow PPL Wakeup) */
  51. bfin_write32(SIC_IWR0, IWR_ENABLE(0));
  52. bfin_write32(SIC_IWR1, 0);
  53. bfin_write16(PLL_CTL, val);
  54. SSYNC();
  55. asm("IDLE;");
  56. bfin_write32(SIC_IWR0, iwr0);
  57. bfin_write32(SIC_IWR1, iwr1);
  58. local_irq_restore(flags);
  59. }
  60. #define bfin_read_PLL_DIV() bfin_read16(PLL_DIV)
  61. #define bfin_write_PLL_DIV(val) bfin_write16(PLL_DIV, val)
  62. #define bfin_read_VR_CTL() bfin_read16(VR_CTL)
  63. /* Writing to VR_CTL initiates a PLL relock sequence. */
  64. static __inline__ void bfin_write_VR_CTL(unsigned int val)
  65. {
  66. unsigned long flags, iwr0, iwr1;
  67. if (val == bfin_read_VR_CTL())
  68. return;
  69. local_irq_save(flags);
  70. /* Enable the PLL Wakeup bit in SIC IWR */
  71. iwr0 = bfin_read32(SIC_IWR0);
  72. iwr1 = bfin_read32(SIC_IWR1);
  73. /* Only allow PPL Wakeup) */
  74. bfin_write32(SIC_IWR0, IWR_ENABLE(0));
  75. bfin_write32(SIC_IWR1, 0);
  76. bfin_write16(VR_CTL, val);
  77. SSYNC();
  78. asm("IDLE;");
  79. bfin_write32(SIC_IWR0, iwr0);
  80. bfin_write32(SIC_IWR1, iwr1);
  81. local_irq_restore(flags);
  82. }
  83. #define bfin_read_PLL_STAT() bfin_read16(PLL_STAT)
  84. #define bfin_write_PLL_STAT(val) bfin_write16(PLL_STAT, val)
  85. #define bfin_read_PLL_LOCKCNT() bfin_read16(PLL_LOCKCNT)
  86. #define bfin_write_PLL_LOCKCNT(val) bfin_write16(PLL_LOCKCNT, val)
  87. #define bfin_read_CHIPID() bfin_read32(CHIPID)
  88. #define bfin_write_CHIPID(val) bfin_write32(CHIPID, val)
  89. /* System Interrupt Controller (0xFFC00100 - 0xFFC001FF) */
  90. #define bfin_read_SWRST() bfin_read16(SWRST)
  91. #define bfin_write_SWRST(val) bfin_write16(SWRST, val)
  92. #define bfin_read_SYSCR() bfin_read16(SYSCR)
  93. #define bfin_write_SYSCR(val) bfin_write16(SYSCR, val)
  94. #define bfin_read_SIC_RVECT() bfin_read32(SIC_RVECT)
  95. #define bfin_write_SIC_RVECT(val) bfin_write32(SIC_RVECT, val)
  96. #define bfin_read_SIC_IMASK0() bfin_read32(SIC_IMASK0)
  97. #define bfin_write_SIC_IMASK0(val) bfin_write32(SIC_IMASK0, val)
  98. #define bfin_read_SIC_IMASK(x) bfin_read32(SIC_IMASK0 + (x << 6))
  99. #define bfin_write_SIC_IMASK(x, val) bfin_write32((SIC_IMASK0 + (x << 6)), val)
  100. #define bfin_read_SIC_IAR0() bfin_read32(SIC_IAR0)
  101. #define bfin_write_SIC_IAR0(val) bfin_write32(SIC_IAR0, val)
  102. #define bfin_read_SIC_IAR1() bfin_read32(SIC_IAR1)
  103. #define bfin_write_SIC_IAR1(val) bfin_write32(SIC_IAR1, val)
  104. #define bfin_read_SIC_IAR2() bfin_read32(SIC_IAR2)
  105. #define bfin_write_SIC_IAR2(val) bfin_write32(SIC_IAR2, val)
  106. #define bfin_read_SIC_IAR3() bfin_read32(SIC_IAR3)
  107. #define bfin_write_SIC_IAR3(val) bfin_write32(SIC_IAR3, val)
  108. #define bfin_read_SIC_ISR0() bfin_read32(SIC_ISR0)
  109. #define bfin_write_SIC_ISR0(val) bfin_write32(SIC_ISR0, val)
  110. #define bfin_read_SIC_ISR(x) bfin_read32(SIC_ISR0 + (x << 6))
  111. #define bfin_write_SIC_ISR(x, val) bfin_write32((SIC_ISR0 + (x << 6)), val)
  112. #define bfin_read_SIC_IWR0() bfin_read32(SIC_IWR0)
  113. #define bfin_write_SIC_IWR0(val) bfin_write32(SIC_IWR0, val)
  114. #define bfin_read_SIC_IWR(x) bfin_read32(SIC_IWR0 + (x << 6))
  115. #define bfin_write_SIC_IWR(x, val) bfin_write32((SIC_IWR0 + (x << 6)), val)
  116. /* SIC Additions to ADSP-BF52x (0xFFC0014C - 0xFFC00162) */
  117. #define bfin_read_SIC_IMASK1() bfin_read32(SIC_IMASK1)
  118. #define bfin_write_SIC_IMASK1(val) bfin_write32(SIC_IMASK1, val)
  119. #define bfin_read_SIC_IAR4() bfin_read32(SIC_IAR4)
  120. #define bfin_write_SIC_IAR4(val) bfin_write32(SIC_IAR4, val)
  121. #define bfin_read_SIC_IAR5() bfin_read32(SIC_IAR5)
  122. #define bfin_write_SIC_IAR5(val) bfin_write32(SIC_IAR5, val)
  123. #define bfin_read_SIC_IAR6() bfin_read32(SIC_IAR6)
  124. #define bfin_write_SIC_IAR6(val) bfin_write32(SIC_IAR6, val)
  125. #define bfin_read_SIC_IAR7() bfin_read32(SIC_IAR7)
  126. #define bfin_write_SIC_IAR7(val) bfin_write32(SIC_IAR7, val)
  127. #define bfin_read_SIC_ISR1() bfin_read32(SIC_ISR1)
  128. #define bfin_write_SIC_ISR1(val) bfin_write32(SIC_ISR1, val)
  129. #define bfin_read_SIC_IWR1() bfin_read32(SIC_IWR1)
  130. #define bfin_write_SIC_IWR1(val) bfin_write32(SIC_IWR1, val)
  131. /* Watchdog Timer (0xFFC00200 - 0xFFC002FF) */
  132. #define bfin_read_WDOG_CTL() bfin_read16(WDOG_CTL)
  133. #define bfin_write_WDOG_CTL(val) bfin_write16(WDOG_CTL, val)
  134. #define bfin_read_WDOG_CNT() bfin_read32(WDOG_CNT)
  135. #define bfin_write_WDOG_CNT(val) bfin_write32(WDOG_CNT, val)
  136. #define bfin_read_WDOG_STAT() bfin_read32(WDOG_STAT)
  137. #define bfin_write_WDOG_STAT(val) bfin_write32(WDOG_STAT, val)
  138. /* Real Time Clock (0xFFC00300 - 0xFFC003FF) */
  139. #define bfin_read_RTC_STAT() bfin_read32(RTC_STAT)
  140. #define bfin_write_RTC_STAT(val) bfin_write32(RTC_STAT, val)
  141. #define bfin_read_RTC_ICTL() bfin_read16(RTC_ICTL)
  142. #define bfin_write_RTC_ICTL(val) bfin_write16(RTC_ICTL, val)
  143. #define bfin_read_RTC_ISTAT() bfin_read16(RTC_ISTAT)
  144. #define bfin_write_RTC_ISTAT(val) bfin_write16(RTC_ISTAT, val)
  145. #define bfin_read_RTC_SWCNT() bfin_read16(RTC_SWCNT)
  146. #define bfin_write_RTC_SWCNT(val) bfin_write16(RTC_SWCNT, val)
  147. #define bfin_read_RTC_ALARM() bfin_read32(RTC_ALARM)
  148. #define bfin_write_RTC_ALARM(val) bfin_write32(RTC_ALARM, val)
  149. #define bfin_read_RTC_FAST() bfin_read16(RTC_FAST)
  150. #define bfin_write_RTC_FAST(val) bfin_write16(RTC_FAST, val)
  151. #define bfin_read_RTC_PREN() bfin_read16(RTC_PREN)
  152. #define bfin_write_RTC_PREN(val) bfin_write16(RTC_PREN, val)
  153. /* UART0 Controller (0xFFC00400 - 0xFFC004FF) */
  154. #define bfin_read_UART0_THR() bfin_read16(UART0_THR)
  155. #define bfin_write_UART0_THR(val) bfin_write16(UART0_THR, val)
  156. #define bfin_read_UART0_RBR() bfin_read16(UART0_RBR)
  157. #define bfin_write_UART0_RBR(val) bfin_write16(UART0_RBR, val)
  158. #define bfin_read_UART0_DLL() bfin_read16(UART0_DLL)
  159. #define bfin_write_UART0_DLL(val) bfin_write16(UART0_DLL, val)
  160. #define bfin_read_UART0_IER() bfin_read16(UART0_IER)
  161. #define bfin_write_UART0_IER(val) bfin_write16(UART0_IER, val)
  162. #define bfin_read_UART0_DLH() bfin_read16(UART0_DLH)
  163. #define bfin_write_UART0_DLH(val) bfin_write16(UART0_DLH, val)
  164. #define bfin_read_UART0_IIR() bfin_read16(UART0_IIR)
  165. #define bfin_write_UART0_IIR(val) bfin_write16(UART0_IIR, val)
  166. #define bfin_read_UART0_LCR() bfin_read16(UART0_LCR)
  167. #define bfin_write_UART0_LCR(val) bfin_write16(UART0_LCR, val)
  168. #define bfin_read_UART0_MCR() bfin_read16(UART0_MCR)
  169. #define bfin_write_UART0_MCR(val) bfin_write16(UART0_MCR, val)
  170. #define bfin_read_UART0_LSR() bfin_read16(UART0_LSR)
  171. #define bfin_write_UART0_LSR(val) bfin_write16(UART0_LSR, val)
  172. #define bfin_read_UART0_MSR() bfin_read16(UART0_MSR)
  173. #define bfin_write_UART0_MSR(val) bfin_write16(UART0_MSR, val)
  174. #define bfin_read_UART0_SCR() bfin_read16(UART0_SCR)
  175. #define bfin_write_UART0_SCR(val) bfin_write16(UART0_SCR, val)
  176. #define bfin_read_UART0_GCTL() bfin_read16(UART0_GCTL)
  177. #define bfin_write_UART0_GCTL(val) bfin_write16(UART0_GCTL, val)
  178. /* SPI Controller (0xFFC00500 - 0xFFC005FF) */
  179. #define bfin_read_SPI_CTL() bfin_read16(SPI_CTL)
  180. #define bfin_write_SPI_CTL(val) bfin_write16(SPI_CTL, val)
  181. #define bfin_read_SPI_FLG() bfin_read16(SPI_FLG)
  182. #define bfin_write_SPI_FLG(val) bfin_write16(SPI_FLG, val)
  183. #define bfin_read_SPI_STAT() bfin_read16(SPI_STAT)
  184. #define bfin_write_SPI_STAT(val) bfin_write16(SPI_STAT, val)
  185. #define bfin_read_SPI_TDBR() bfin_read16(SPI_TDBR)
  186. #define bfin_write_SPI_TDBR(val) bfin_write16(SPI_TDBR, val)
  187. #define bfin_read_SPI_RDBR() bfin_read16(SPI_RDBR)
  188. #define bfin_write_SPI_RDBR(val) bfin_write16(SPI_RDBR, val)
  189. #define bfin_read_SPI_BAUD() bfin_read16(SPI_BAUD)
  190. #define bfin_write_SPI_BAUD(val) bfin_write16(SPI_BAUD, val)
  191. #define bfin_read_SPI_SHADOW() bfin_read16(SPI_SHADOW)
  192. #define bfin_write_SPI_SHADOW(val) bfin_write16(SPI_SHADOW, val)
  193. /* TIMER0-7 Registers (0xFFC00600 - 0xFFC006FF) */
  194. #define bfin_read_TIMER0_CONFIG() bfin_read16(TIMER0_CONFIG)
  195. #define bfin_write_TIMER0_CONFIG(val) bfin_write16(TIMER0_CONFIG, val)
  196. #define bfin_read_TIMER0_COUNTER() bfin_read32(TIMER0_COUNTER)
  197. #define bfin_write_TIMER0_COUNTER(val) bfin_write32(TIMER0_COUNTER, val)
  198. #define bfin_read_TIMER0_PERIOD() bfin_read32(TIMER0_PERIOD)
  199. #define bfin_write_TIMER0_PERIOD(val) bfin_write32(TIMER0_PERIOD, val)
  200. #define bfin_read_TIMER0_WIDTH() bfin_read32(TIMER0_WIDTH)
  201. #define bfin_write_TIMER0_WIDTH(val) bfin_write32(TIMER0_WIDTH, val)
  202. #define bfin_read_TIMER1_CONFIG() bfin_read16(TIMER1_CONFIG)
  203. #define bfin_write_TIMER1_CONFIG(val) bfin_write16(TIMER1_CONFIG, val)
  204. #define bfin_read_TIMER1_COUNTER() bfin_read32(TIMER1_COUNTER)
  205. #define bfin_write_TIMER1_COUNTER(val) bfin_write32(TIMER1_COUNTER, val)
  206. #define bfin_read_TIMER1_PERIOD() bfin_read32(TIMER1_PERIOD)
  207. #define bfin_write_TIMER1_PERIOD(val) bfin_write32(TIMER1_PERIOD, val)
  208. #define bfin_read_TIMER1_WIDTH() bfin_read32(TIMER1_WIDTH)
  209. #define bfin_write_TIMER1_WIDTH(val) bfin_write32(TIMER1_WIDTH, val)
  210. #define bfin_read_TIMER2_CONFIG() bfin_read16(TIMER2_CONFIG)
  211. #define bfin_write_TIMER2_CONFIG(val) bfin_write16(TIMER2_CONFIG, val)
  212. #define bfin_read_TIMER2_COUNTER() bfin_read32(TIMER2_COUNTER)
  213. #define bfin_write_TIMER2_COUNTER(val) bfin_write32(TIMER2_COUNTER, val)
  214. #define bfin_read_TIMER2_PERIOD() bfin_read32(TIMER2_PERIOD)
  215. #define bfin_write_TIMER2_PERIOD(val) bfin_write32(TIMER2_PERIOD, val)
  216. #define bfin_read_TIMER2_WIDTH() bfin_read32(TIMER2_WIDTH)
  217. #define bfin_write_TIMER2_WIDTH(val) bfin_write32(TIMER2_WIDTH, val)
  218. #define bfin_read_TIMER3_CONFIG() bfin_read16(TIMER3_CONFIG)
  219. #define bfin_write_TIMER3_CONFIG(val) bfin_write16(TIMER3_CONFIG, val)
  220. #define bfin_read_TIMER3_COUNTER() bfin_read32(TIMER3_COUNTER)
  221. #define bfin_write_TIMER3_COUNTER(val) bfin_write32(TIMER3_COUNTER, val)
  222. #define bfin_read_TIMER3_PERIOD() bfin_read32(TIMER3_PERIOD)
  223. #define bfin_write_TIMER3_PERIOD(val) bfin_write32(TIMER3_PERIOD, val)
  224. #define bfin_read_TIMER3_WIDTH() bfin_read32(TIMER3_WIDTH)
  225. #define bfin_write_TIMER3_WIDTH(val) bfin_write32(TIMER3_WIDTH, val)
  226. #define bfin_read_TIMER4_CONFIG() bfin_read16(TIMER4_CONFIG)
  227. #define bfin_write_TIMER4_CONFIG(val) bfin_write16(TIMER4_CONFIG, val)
  228. #define bfin_read_TIMER4_COUNTER() bfin_read32(TIMER4_COUNTER)
  229. #define bfin_write_TIMER4_COUNTER(val) bfin_write32(TIMER4_COUNTER, val)
  230. #define bfin_read_TIMER4_PERIOD() bfin_read32(TIMER4_PERIOD)
  231. #define bfin_write_TIMER4_PERIOD(val) bfin_write32(TIMER4_PERIOD, val)
  232. #define bfin_read_TIMER4_WIDTH() bfin_read32(TIMER4_WIDTH)
  233. #define bfin_write_TIMER4_WIDTH(val) bfin_write32(TIMER4_WIDTH, val)
  234. #define bfin_read_TIMER5_CONFIG() bfin_read16(TIMER5_CONFIG)
  235. #define bfin_write_TIMER5_CONFIG(val) bfin_write16(TIMER5_CONFIG, val)
  236. #define bfin_read_TIMER5_COUNTER() bfin_read32(TIMER5_COUNTER)
  237. #define bfin_write_TIMER5_COUNTER(val) bfin_write32(TIMER5_COUNTER, val)
  238. #define bfin_read_TIMER5_PERIOD() bfin_read32(TIMER5_PERIOD)
  239. #define bfin_write_TIMER5_PERIOD(val) bfin_write32(TIMER5_PERIOD, val)
  240. #define bfin_read_TIMER5_WIDTH() bfin_read32(TIMER5_WIDTH)
  241. #define bfin_write_TIMER5_WIDTH(val) bfin_write32(TIMER5_WIDTH, val)
  242. #define bfin_read_TIMER6_CONFIG() bfin_read16(TIMER6_CONFIG)
  243. #define bfin_write_TIMER6_CONFIG(val) bfin_write16(TIMER6_CONFIG, val)
  244. #define bfin_read_TIMER6_COUNTER() bfin_read32(TIMER6_COUNTER)
  245. #define bfin_write_TIMER6_COUNTER(val) bfin_write32(TIMER6_COUNTER, val)
  246. #define bfin_read_TIMER6_PERIOD() bfin_read32(TIMER6_PERIOD)
  247. #define bfin_write_TIMER6_PERIOD(val) bfin_write32(TIMER6_PERIOD, val)
  248. #define bfin_read_TIMER6_WIDTH() bfin_read32(TIMER6_WIDTH)
  249. #define bfin_write_TIMER6_WIDTH(val) bfin_write32(TIMER6_WIDTH, val)
  250. #define bfin_read_TIMER7_CONFIG() bfin_read16(TIMER7_CONFIG)
  251. #define bfin_write_TIMER7_CONFIG(val) bfin_write16(TIMER7_CONFIG, val)
  252. #define bfin_read_TIMER7_COUNTER() bfin_read32(TIMER7_COUNTER)
  253. #define bfin_write_TIMER7_COUNTER(val) bfin_write32(TIMER7_COUNTER, val)
  254. #define bfin_read_TIMER7_PERIOD() bfin_read32(TIMER7_PERIOD)
  255. #define bfin_write_TIMER7_PERIOD(val) bfin_write32(TIMER7_PERIOD, val)
  256. #define bfin_read_TIMER7_WIDTH() bfin_read32(TIMER7_WIDTH)
  257. #define bfin_write_TIMER7_WIDTH(val) bfin_write32(TIMER7_WIDTH, val)
  258. #define bfin_read_TIMER_ENABLE() bfin_read16(TIMER_ENABLE)
  259. #define bfin_write_TIMER_ENABLE(val) bfin_write16(TIMER_ENABLE, val)
  260. #define bfin_read_TIMER_DISABLE() bfin_read16(TIMER_DISABLE)
  261. #define bfin_write_TIMER_DISABLE(val) bfin_write16(TIMER_DISABLE, val)
  262. #define bfin_read_TIMER_STATUS() bfin_read32(TIMER_STATUS)
  263. #define bfin_write_TIMER_STATUS(val) bfin_write32(TIMER_STATUS, val)
  264. /* General Purpose I/O Port F (0xFFC00700 - 0xFFC007FF) */
  265. #define bfin_read_PORTFIO() bfin_read16(PORTFIO)
  266. #define bfin_write_PORTFIO(val) bfin_write16(PORTFIO, val)
  267. #define bfin_read_PORTFIO_CLEAR() bfin_read16(PORTFIO_CLEAR)
  268. #define bfin_write_PORTFIO_CLEAR(val) bfin_write16(PORTFIO_CLEAR, val)
  269. #define bfin_read_PORTFIO_SET() bfin_read16(PORTFIO_SET)
  270. #define bfin_write_PORTFIO_SET(val) bfin_write16(PORTFIO_SET, val)
  271. #define bfin_read_PORTFIO_TOGGLE() bfin_read16(PORTFIO_TOGGLE)
  272. #define bfin_write_PORTFIO_TOGGLE(val) bfin_write16(PORTFIO_TOGGLE, val)
  273. #define bfin_read_PORTFIO_MASKA() bfin_read16(PORTFIO_MASKA)
  274. #define bfin_write_PORTFIO_MASKA(val) bfin_write16(PORTFIO_MASKA, val)
  275. #define bfin_read_PORTFIO_MASKA_CLEAR() bfin_read16(PORTFIO_MASKA_CLEAR)
  276. #define bfin_write_PORTFIO_MASKA_CLEAR(val) bfin_write16(PORTFIO_MASKA_CLEAR, val)
  277. #define bfin_read_PORTFIO_MASKA_SET() bfin_read16(PORTFIO_MASKA_SET)
  278. #define bfin_write_PORTFIO_MASKA_SET(val) bfin_write16(PORTFIO_MASKA_SET, val)
  279. #define bfin_read_PORTFIO_MASKA_TOGGLE() bfin_read16(PORTFIO_MASKA_TOGGLE)
  280. #define bfin_write_PORTFIO_MASKA_TOGGLE(val) bfin_write16(PORTFIO_MASKA_TOGGLE, val)
  281. #define bfin_read_PORTFIO_MASKB() bfin_read16(PORTFIO_MASKB)
  282. #define bfin_write_PORTFIO_MASKB(val) bfin_write16(PORTFIO_MASKB, val)
  283. #define bfin_read_PORTFIO_MASKB_CLEAR() bfin_read16(PORTFIO_MASKB_CLEAR)
  284. #define bfin_write_PORTFIO_MASKB_CLEAR(val) bfin_write16(PORTFIO_MASKB_CLEAR, val)
  285. #define bfin_read_PORTFIO_MASKB_SET() bfin_read16(PORTFIO_MASKB_SET)
  286. #define bfin_write_PORTFIO_MASKB_SET(val) bfin_write16(PORTFIO_MASKB_SET, val)
  287. #define bfin_read_PORTFIO_MASKB_TOGGLE() bfin_read16(PORTFIO_MASKB_TOGGLE)
  288. #define bfin_write_PORTFIO_MASKB_TOGGLE(val) bfin_write16(PORTFIO_MASKB_TOGGLE, val)
  289. #define bfin_read_PORTFIO_DIR() bfin_read16(PORTFIO_DIR)
  290. #define bfin_write_PORTFIO_DIR(val) bfin_write16(PORTFIO_DIR, val)
  291. #define bfin_read_PORTFIO_POLAR() bfin_read16(PORTFIO_POLAR)
  292. #define bfin_write_PORTFIO_POLAR(val) bfin_write16(PORTFIO_POLAR, val)
  293. #define bfin_read_PORTFIO_EDGE() bfin_read16(PORTFIO_EDGE)
  294. #define bfin_write_PORTFIO_EDGE(val) bfin_write16(PORTFIO_EDGE, val)
  295. #define bfin_read_PORTFIO_BOTH() bfin_read16(PORTFIO_BOTH)
  296. #define bfin_write_PORTFIO_BOTH(val) bfin_write16(PORTFIO_BOTH, val)
  297. #define bfin_read_PORTFIO_INEN() bfin_read16(PORTFIO_INEN)
  298. #define bfin_write_PORTFIO_INEN(val) bfin_write16(PORTFIO_INEN, val)
  299. /* SPORT0 Controller (0xFFC00800 - 0xFFC008FF) */
  300. #define bfin_read_SPORT0_TCR1() bfin_read16(SPORT0_TCR1)
  301. #define bfin_write_SPORT0_TCR1(val) bfin_write16(SPORT0_TCR1, val)
  302. #define bfin_read_SPORT0_TCR2() bfin_read16(SPORT0_TCR2)
  303. #define bfin_write_SPORT0_TCR2(val) bfin_write16(SPORT0_TCR2, val)
  304. #define bfin_read_SPORT0_TCLKDIV() bfin_read16(SPORT0_TCLKDIV)
  305. #define bfin_write_SPORT0_TCLKDIV(val) bfin_write16(SPORT0_TCLKDIV, val)
  306. #define bfin_read_SPORT0_TFSDIV() bfin_read16(SPORT0_TFSDIV)
  307. #define bfin_write_SPORT0_TFSDIV(val) bfin_write16(SPORT0_TFSDIV, val)
  308. #define bfin_read_SPORT0_TX() bfin_read32(SPORT0_TX)
  309. #define bfin_write_SPORT0_TX(val) bfin_write32(SPORT0_TX, val)
  310. #define bfin_read_SPORT0_RX() bfin_read32(SPORT0_RX)
  311. #define bfin_write_SPORT0_RX(val) bfin_write32(SPORT0_RX, val)
  312. #define bfin_read_SPORT0_TX32() bfin_read32(SPORT0_TX32)
  313. #define bfin_write_SPORT0_TX32(val) bfin_write32(SPORT0_TX32, val)
  314. #define bfin_read_SPORT0_RX32() bfin_read32(SPORT0_RX32)
  315. #define bfin_write_SPORT0_RX32(val) bfin_write32(SPORT0_RX32, val)
  316. #define bfin_read_SPORT0_TX16() bfin_read16(SPORT0_TX16)
  317. #define bfin_write_SPORT0_TX16(val) bfin_write16(SPORT0_TX16, val)
  318. #define bfin_read_SPORT0_RX16() bfin_read16(SPORT0_RX16)
  319. #define bfin_write_SPORT0_RX16(val) bfin_write16(SPORT0_RX16, val)
  320. #define bfin_read_SPORT0_RCR1() bfin_read16(SPORT0_RCR1)
  321. #define bfin_write_SPORT0_RCR1(val) bfin_write16(SPORT0_RCR1, val)
  322. #define bfin_read_SPORT0_RCR2() bfin_read16(SPORT0_RCR2)
  323. #define bfin_write_SPORT0_RCR2(val) bfin_write16(SPORT0_RCR2, val)
  324. #define bfin_read_SPORT0_RCLKDIV() bfin_read16(SPORT0_RCLKDIV)
  325. #define bfin_write_SPORT0_RCLKDIV(val) bfin_write16(SPORT0_RCLKDIV, val)
  326. #define bfin_read_SPORT0_RFSDIV() bfin_read16(SPORT0_RFSDIV)
  327. #define bfin_write_SPORT0_RFSDIV(val) bfin_write16(SPORT0_RFSDIV, val)
  328. #define bfin_read_SPORT0_STAT() bfin_read16(SPORT0_STAT)
  329. #define bfin_write_SPORT0_STAT(val) bfin_write16(SPORT0_STAT, val)
  330. #define bfin_read_SPORT0_CHNL() bfin_read16(SPORT0_CHNL)
  331. #define bfin_write_SPORT0_CHNL(val) bfin_write16(SPORT0_CHNL, val)
  332. #define bfin_read_SPORT0_MCMC1() bfin_read16(SPORT0_MCMC1)
  333. #define bfin_write_SPORT0_MCMC1(val) bfin_write16(SPORT0_MCMC1, val)
  334. #define bfin_read_SPORT0_MCMC2() bfin_read16(SPORT0_MCMC2)
  335. #define bfin_write_SPORT0_MCMC2(val) bfin_write16(SPORT0_MCMC2, val)
  336. #define bfin_read_SPORT0_MTCS0() bfin_read32(SPORT0_MTCS0)
  337. #define bfin_write_SPORT0_MTCS0(val) bfin_write32(SPORT0_MTCS0, val)
  338. #define bfin_read_SPORT0_MTCS1() bfin_read32(SPORT0_MTCS1)
  339. #define bfin_write_SPORT0_MTCS1(val) bfin_write32(SPORT0_MTCS1, val)
  340. #define bfin_read_SPORT0_MTCS2() bfin_read32(SPORT0_MTCS2)
  341. #define bfin_write_SPORT0_MTCS2(val) bfin_write32(SPORT0_MTCS2, val)
  342. #define bfin_read_SPORT0_MTCS3() bfin_read32(SPORT0_MTCS3)
  343. #define bfin_write_SPORT0_MTCS3(val) bfin_write32(SPORT0_MTCS3, val)
  344. #define bfin_read_SPORT0_MRCS0() bfin_read32(SPORT0_MRCS0)
  345. #define bfin_write_SPORT0_MRCS0(val) bfin_write32(SPORT0_MRCS0, val)
  346. #define bfin_read_SPORT0_MRCS1() bfin_read32(SPORT0_MRCS1)
  347. #define bfin_write_SPORT0_MRCS1(val) bfin_write32(SPORT0_MRCS1, val)
  348. #define bfin_read_SPORT0_MRCS2() bfin_read32(SPORT0_MRCS2)
  349. #define bfin_write_SPORT0_MRCS2(val) bfin_write32(SPORT0_MRCS2, val)
  350. #define bfin_read_SPORT0_MRCS3() bfin_read32(SPORT0_MRCS3)
  351. #define bfin_write_SPORT0_MRCS3(val) bfin_write32(SPORT0_MRCS3, val)
  352. /* SPORT1 Controller (0xFFC00900 - 0xFFC009FF) */
  353. #define bfin_read_SPORT1_TCR1() bfin_read16(SPORT1_TCR1)
  354. #define bfin_write_SPORT1_TCR1(val) bfin_write16(SPORT1_TCR1, val)
  355. #define bfin_read_SPORT1_TCR2() bfin_read16(SPORT1_TCR2)
  356. #define bfin_write_SPORT1_TCR2(val) bfin_write16(SPORT1_TCR2, val)
  357. #define bfin_read_SPORT1_TCLKDIV() bfin_read16(SPORT1_TCLKDIV)
  358. #define bfin_write_SPORT1_TCLKDIV(val) bfin_write16(SPORT1_TCLKDIV, val)
  359. #define bfin_read_SPORT1_TFSDIV() bfin_read16(SPORT1_TFSDIV)
  360. #define bfin_write_SPORT1_TFSDIV(val) bfin_write16(SPORT1_TFSDIV, val)
  361. #define bfin_read_SPORT1_TX() bfin_read32(SPORT1_TX)
  362. #define bfin_write_SPORT1_TX(val) bfin_write32(SPORT1_TX, val)
  363. #define bfin_read_SPORT1_RX() bfin_read32(SPORT1_RX)
  364. #define bfin_write_SPORT1_RX(val) bfin_write32(SPORT1_RX, val)
  365. #define bfin_read_SPORT1_TX32() bfin_read32(SPORT1_TX32)
  366. #define bfin_write_SPORT1_TX32(val) bfin_write32(SPORT1_TX32, val)
  367. #define bfin_read_SPORT1_RX32() bfin_read32(SPORT1_RX32)
  368. #define bfin_write_SPORT1_RX32(val) bfin_write32(SPORT1_RX32, val)
  369. #define bfin_read_SPORT1_TX16() bfin_read16(SPORT1_TX16)
  370. #define bfin_write_SPORT1_TX16(val) bfin_write16(SPORT1_TX16, val)
  371. #define bfin_read_SPORT1_RX16() bfin_read16(SPORT1_RX16)
  372. #define bfin_write_SPORT1_RX16(val) bfin_write16(SPORT1_RX16, val)
  373. #define bfin_read_SPORT1_RCR1() bfin_read16(SPORT1_RCR1)
  374. #define bfin_write_SPORT1_RCR1(val) bfin_write16(SPORT1_RCR1, val)
  375. #define bfin_read_SPORT1_RCR2() bfin_read16(SPORT1_RCR2)
  376. #define bfin_write_SPORT1_RCR2(val) bfin_write16(SPORT1_RCR2, val)
  377. #define bfin_read_SPORT1_RCLKDIV() bfin_read16(SPORT1_RCLKDIV)
  378. #define bfin_write_SPORT1_RCLKDIV(val) bfin_write16(SPORT1_RCLKDIV, val)
  379. #define bfin_read_SPORT1_RFSDIV() bfin_read16(SPORT1_RFSDIV)
  380. #define bfin_write_SPORT1_RFSDIV(val) bfin_write16(SPORT1_RFSDIV, val)
  381. #define bfin_read_SPORT1_STAT() bfin_read16(SPORT1_STAT)
  382. #define bfin_write_SPORT1_STAT(val) bfin_write16(SPORT1_STAT, val)
  383. #define bfin_read_SPORT1_CHNL() bfin_read16(SPORT1_CHNL)
  384. #define bfin_write_SPORT1_CHNL(val) bfin_write16(SPORT1_CHNL, val)
  385. #define bfin_read_SPORT1_MCMC1() bfin_read16(SPORT1_MCMC1)
  386. #define bfin_write_SPORT1_MCMC1(val) bfin_write16(SPORT1_MCMC1, val)
  387. #define bfin_read_SPORT1_MCMC2() bfin_read16(SPORT1_MCMC2)
  388. #define bfin_write_SPORT1_MCMC2(val) bfin_write16(SPORT1_MCMC2, val)
  389. #define bfin_read_SPORT1_MTCS0() bfin_read32(SPORT1_MTCS0)
  390. #define bfin_write_SPORT1_MTCS0(val) bfin_write32(SPORT1_MTCS0, val)
  391. #define bfin_read_SPORT1_MTCS1() bfin_read32(SPORT1_MTCS1)
  392. #define bfin_write_SPORT1_MTCS1(val) bfin_write32(SPORT1_MTCS1, val)
  393. #define bfin_read_SPORT1_MTCS2() bfin_read32(SPORT1_MTCS2)
  394. #define bfin_write_SPORT1_MTCS2(val) bfin_write32(SPORT1_MTCS2, val)
  395. #define bfin_read_SPORT1_MTCS3() bfin_read32(SPORT1_MTCS3)
  396. #define bfin_write_SPORT1_MTCS3(val) bfin_write32(SPORT1_MTCS3, val)
  397. #define bfin_read_SPORT1_MRCS0() bfin_read32(SPORT1_MRCS0)
  398. #define bfin_write_SPORT1_MRCS0(val) bfin_write32(SPORT1_MRCS0, val)
  399. #define bfin_read_SPORT1_MRCS1() bfin_read32(SPORT1_MRCS1)
  400. #define bfin_write_SPORT1_MRCS1(val) bfin_write32(SPORT1_MRCS1, val)
  401. #define bfin_read_SPORT1_MRCS2() bfin_read32(SPORT1_MRCS2)
  402. #define bfin_write_SPORT1_MRCS2(val) bfin_write32(SPORT1_MRCS2, val)
  403. #define bfin_read_SPORT1_MRCS3() bfin_read32(SPORT1_MRCS3)
  404. #define bfin_write_SPORT1_MRCS3(val) bfin_write32(SPORT1_MRCS3, val)
  405. /* External Bus Interface Unit (0xFFC00A00 - 0xFFC00AFF) */
  406. #define bfin_read_EBIU_AMGCTL() bfin_read16(EBIU_AMGCTL)
  407. #define bfin_write_EBIU_AMGCTL(val) bfin_write16(EBIU_AMGCTL, val)
  408. #define bfin_read_EBIU_AMBCTL0() bfin_read32(EBIU_AMBCTL0)
  409. #define bfin_write_EBIU_AMBCTL0(val) bfin_write32(EBIU_AMBCTL0, val)
  410. #define bfin_read_EBIU_AMBCTL1() bfin_read32(EBIU_AMBCTL1)
  411. #define bfin_write_EBIU_AMBCTL1(val) bfin_write32(EBIU_AMBCTL1, val)
  412. #define bfin_read_EBIU_SDGCTL() bfin_read32(EBIU_SDGCTL)
  413. #define bfin_write_EBIU_SDGCTL(val) bfin_write32(EBIU_SDGCTL, val)
  414. #define bfin_read_EBIU_SDBCTL() bfin_read16(EBIU_SDBCTL)
  415. #define bfin_write_EBIU_SDBCTL(val) bfin_write16(EBIU_SDBCTL, val)
  416. #define bfin_read_EBIU_SDRRC() bfin_read16(EBIU_SDRRC)
  417. #define bfin_write_EBIU_SDRRC(val) bfin_write16(EBIU_SDRRC, val)
  418. #define bfin_read_EBIU_SDSTAT() bfin_read16(EBIU_SDSTAT)
  419. #define bfin_write_EBIU_SDSTAT(val) bfin_write16(EBIU_SDSTAT, val)
  420. /* DMA Traffic Control Registers */
  421. #define bfin_read_DMA_TC_PER() bfin_read16(DMA_TC_PER)
  422. #define bfin_write_DMA_TC_PER(val) bfin_write16(DMA_TC_PER, val)
  423. #define bfin_read_DMA_TC_CNT() bfin_read16(DMA_TC_CNT)
  424. #define bfin_write_DMA_TC_CNT(val) bfin_write16(DMA_TC_CNT, val)
  425. /* Alternate deprecated register names (below) provided for backwards code compatibility */
  426. #define bfin_read_DMA_TCPER() bfin_read16(DMA_TCPER)
  427. #define bfin_write_DMA_TCPER(val) bfin_write16(DMA_TCPER, val)
  428. #define bfin_read_DMA_TCCNT() bfin_read16(DMA_TCCNT)
  429. #define bfin_write_DMA_TCCNT(val) bfin_write16(DMA_TCCNT, val)
  430. /* DMA Controller */
  431. #define bfin_read_DMA0_CONFIG() bfin_read16(DMA0_CONFIG)
  432. #define bfin_write_DMA0_CONFIG(val) bfin_write16(DMA0_CONFIG, val)
  433. #define bfin_read_DMA0_NEXT_DESC_PTR() bfin_read32(DMA0_NEXT_DESC_PTR)
  434. #define bfin_write_DMA0_NEXT_DESC_PTR(val) bfin_write32(DMA0_NEXT_DESC_PTR, val)
  435. #define bfin_read_DMA0_START_ADDR() bfin_read32(DMA0_START_ADDR)
  436. #define bfin_write_DMA0_START_ADDR(val) bfin_write32(DMA0_START_ADDR, val)
  437. #define bfin_read_DMA0_X_COUNT() bfin_read16(DMA0_X_COUNT)
  438. #define bfin_write_DMA0_X_COUNT(val) bfin_write16(DMA0_X_COUNT, val)
  439. #define bfin_read_DMA0_Y_COUNT() bfin_read16(DMA0_Y_COUNT)
  440. #define bfin_write_DMA0_Y_COUNT(val) bfin_write16(DMA0_Y_COUNT, val)
  441. #define bfin_read_DMA0_X_MODIFY() bfin_read16(DMA0_X_MODIFY)
  442. #define bfin_write_DMA0_X_MODIFY(val) bfin_write16(DMA0_X_MODIFY, val)
  443. #define bfin_read_DMA0_Y_MODIFY() bfin_read16(DMA0_Y_MODIFY)
  444. #define bfin_write_DMA0_Y_MODIFY(val) bfin_write16(DMA0_Y_MODIFY, val)
  445. #define bfin_read_DMA0_CURR_DESC_PTR() bfin_read32(DMA0_CURR_DESC_PTR)
  446. #define bfin_write_DMA0_CURR_DESC_PTR(val) bfin_write32(DMA0_CURR_DESC_PTR, val)
  447. #define bfin_read_DMA0_CURR_ADDR() bfin_read32(DMA0_CURR_ADDR)
  448. #define bfin_write_DMA0_CURR_ADDR(val) bfin_write32(DMA0_CURR_ADDR, val)
  449. #define bfin_read_DMA0_CURR_X_COUNT() bfin_read16(DMA0_CURR_X_COUNT)
  450. #define bfin_write_DMA0_CURR_X_COUNT(val) bfin_write16(DMA0_CURR_X_COUNT, val)
  451. #define bfin_read_DMA0_CURR_Y_COUNT() bfin_read16(DMA0_CURR_Y_COUNT)
  452. #define bfin_write_DMA0_CURR_Y_COUNT(val) bfin_write16(DMA0_CURR_Y_COUNT, val)
  453. #define bfin_read_DMA0_IRQ_STATUS() bfin_read16(DMA0_IRQ_STATUS)
  454. #define bfin_write_DMA0_IRQ_STATUS(val) bfin_write16(DMA0_IRQ_STATUS, val)
  455. #define bfin_read_DMA0_PERIPHERAL_MAP() bfin_read16(DMA0_PERIPHERAL_MAP)
  456. #define bfin_write_DMA0_PERIPHERAL_MAP(val) bfin_write16(DMA0_PERIPHERAL_MAP, val)
  457. #define bfin_read_DMA1_CONFIG() bfin_read16(DMA1_CONFIG)
  458. #define bfin_write_DMA1_CONFIG(val) bfin_write16(DMA1_CONFIG, val)
  459. #define bfin_read_DMA1_NEXT_DESC_PTR() bfin_read32(DMA1_NEXT_DESC_PTR)
  460. #define bfin_write_DMA1_NEXT_DESC_PTR(val) bfin_write32(DMA1_NEXT_DESC_PTR, val)
  461. #define bfin_read_DMA1_START_ADDR() bfin_read32(DMA1_START_ADDR)
  462. #define bfin_write_DMA1_START_ADDR(val) bfin_write32(DMA1_START_ADDR, val)
  463. #define bfin_read_DMA1_X_COUNT() bfin_read16(DMA1_X_COUNT)
  464. #define bfin_write_DMA1_X_COUNT(val) bfin_write16(DMA1_X_COUNT, val)
  465. #define bfin_read_DMA1_Y_COUNT() bfin_read16(DMA1_Y_COUNT)
  466. #define bfin_write_DMA1_Y_COUNT(val) bfin_write16(DMA1_Y_COUNT, val)
  467. #define bfin_read_DMA1_X_MODIFY() bfin_read16(DMA1_X_MODIFY)
  468. #define bfin_write_DMA1_X_MODIFY(val) bfin_write16(DMA1_X_MODIFY, val)
  469. #define bfin_read_DMA1_Y_MODIFY() bfin_read16(DMA1_Y_MODIFY)
  470. #define bfin_write_DMA1_Y_MODIFY(val) bfin_write16(DMA1_Y_MODIFY, val)
  471. #define bfin_read_DMA1_CURR_DESC_PTR() bfin_read32(DMA1_CURR_DESC_PTR)
  472. #define bfin_write_DMA1_CURR_DESC_PTR(val) bfin_write32(DMA1_CURR_DESC_PTR, val)
  473. #define bfin_read_DMA1_CURR_ADDR() bfin_read32(DMA1_CURR_ADDR)
  474. #define bfin_write_DMA1_CURR_ADDR(val) bfin_write32(DMA1_CURR_ADDR, val)
  475. #define bfin_read_DMA1_CURR_X_COUNT() bfin_read16(DMA1_CURR_X_COUNT)
  476. #define bfin_write_DMA1_CURR_X_COUNT(val) bfin_write16(DMA1_CURR_X_COUNT, val)
  477. #define bfin_read_DMA1_CURR_Y_COUNT() bfin_read16(DMA1_CURR_Y_COUNT)
  478. #define bfin_write_DMA1_CURR_Y_COUNT(val) bfin_write16(DMA1_CURR_Y_COUNT, val)
  479. #define bfin_read_DMA1_IRQ_STATUS() bfin_read16(DMA1_IRQ_STATUS)
  480. #define bfin_write_DMA1_IRQ_STATUS(val) bfin_write16(DMA1_IRQ_STATUS, val)
  481. #define bfin_read_DMA1_PERIPHERAL_MAP() bfin_read16(DMA1_PERIPHERAL_MAP)
  482. #define bfin_write_DMA1_PERIPHERAL_MAP(val) bfin_write16(DMA1_PERIPHERAL_MAP, val)
  483. #define bfin_read_DMA2_CONFIG() bfin_read16(DMA2_CONFIG)
  484. #define bfin_write_DMA2_CONFIG(val) bfin_write16(DMA2_CONFIG, val)
  485. #define bfin_read_DMA2_NEXT_DESC_PTR() bfin_read32(DMA2_NEXT_DESC_PTR)
  486. #define bfin_write_DMA2_NEXT_DESC_PTR(val) bfin_write32(DMA2_NEXT_DESC_PTR, val)
  487. #define bfin_read_DMA2_START_ADDR() bfin_read32(DMA2_START_ADDR)
  488. #define bfin_write_DMA2_START_ADDR(val) bfin_write32(DMA2_START_ADDR, val)
  489. #define bfin_read_DMA2_X_COUNT() bfin_read16(DMA2_X_COUNT)
  490. #define bfin_write_DMA2_X_COUNT(val) bfin_write16(DMA2_X_COUNT, val)
  491. #define bfin_read_DMA2_Y_COUNT() bfin_read16(DMA2_Y_COUNT)
  492. #define bfin_write_DMA2_Y_COUNT(val) bfin_write16(DMA2_Y_COUNT, val)
  493. #define bfin_read_DMA2_X_MODIFY() bfin_read16(DMA2_X_MODIFY)
  494. #define bfin_write_DMA2_X_MODIFY(val) bfin_write16(DMA2_X_MODIFY, val)
  495. #define bfin_read_DMA2_Y_MODIFY() bfin_read16(DMA2_Y_MODIFY)
  496. #define bfin_write_DMA2_Y_MODIFY(val) bfin_write16(DMA2_Y_MODIFY, val)
  497. #define bfin_read_DMA2_CURR_DESC_PTR() bfin_read32(DMA2_CURR_DESC_PTR)
  498. #define bfin_write_DMA2_CURR_DESC_PTR(val) bfin_write32(DMA2_CURR_DESC_PTR, val)
  499. #define bfin_read_DMA2_CURR_ADDR() bfin_read32(DMA2_CURR_ADDR)
  500. #define bfin_write_DMA2_CURR_ADDR(val) bfin_write32(DMA2_CURR_ADDR, val)
  501. #define bfin_read_DMA2_CURR_X_COUNT() bfin_read16(DMA2_CURR_X_COUNT)
  502. #define bfin_write_DMA2_CURR_X_COUNT(val) bfin_write16(DMA2_CURR_X_COUNT, val)
  503. #define bfin_read_DMA2_CURR_Y_COUNT() bfin_read16(DMA2_CURR_Y_COUNT)
  504. #define bfin_write_DMA2_CURR_Y_COUNT(val) bfin_write16(DMA2_CURR_Y_COUNT, val)
  505. #define bfin_read_DMA2_IRQ_STATUS() bfin_read16(DMA2_IRQ_STATUS)
  506. #define bfin_write_DMA2_IRQ_STATUS(val) bfin_write16(DMA2_IRQ_STATUS, val)
  507. #define bfin_read_DMA2_PERIPHERAL_MAP() bfin_read16(DMA2_PERIPHERAL_MAP)
  508. #define bfin_write_DMA2_PERIPHERAL_MAP(val) bfin_write16(DMA2_PERIPHERAL_MAP, val)
  509. #define bfin_read_DMA3_CONFIG() bfin_read16(DMA3_CONFIG)
  510. #define bfin_write_DMA3_CONFIG(val) bfin_write16(DMA3_CONFIG, val)
  511. #define bfin_read_DMA3_NEXT_DESC_PTR() bfin_read32(DMA3_NEXT_DESC_PTR)
  512. #define bfin_write_DMA3_NEXT_DESC_PTR(val) bfin_write32(DMA3_NEXT_DESC_PTR, val)
  513. #define bfin_read_DMA3_START_ADDR() bfin_read32(DMA3_START_ADDR)
  514. #define bfin_write_DMA3_START_ADDR(val) bfin_write32(DMA3_START_ADDR, val)
  515. #define bfin_read_DMA3_X_COUNT() bfin_read16(DMA3_X_COUNT)
  516. #define bfin_write_DMA3_X_COUNT(val) bfin_write16(DMA3_X_COUNT, val)
  517. #define bfin_read_DMA3_Y_COUNT() bfin_read16(DMA3_Y_COUNT)
  518. #define bfin_write_DMA3_Y_COUNT(val) bfin_write16(DMA3_Y_COUNT, val)
  519. #define bfin_read_DMA3_X_MODIFY() bfin_read16(DMA3_X_MODIFY)
  520. #define bfin_write_DMA3_X_MODIFY(val) bfin_write16(DMA3_X_MODIFY, val)
  521. #define bfin_read_DMA3_Y_MODIFY() bfin_read16(DMA3_Y_MODIFY)
  522. #define bfin_write_DMA3_Y_MODIFY(val) bfin_write16(DMA3_Y_MODIFY, val)
  523. #define bfin_read_DMA3_CURR_DESC_PTR() bfin_read32(DMA3_CURR_DESC_PTR)
  524. #define bfin_write_DMA3_CURR_DESC_PTR(val) bfin_write32(DMA3_CURR_DESC_PTR, val)
  525. #define bfin_read_DMA3_CURR_ADDR() bfin_read32(DMA3_CURR_ADDR)
  526. #define bfin_write_DMA3_CURR_ADDR(val) bfin_write32(DMA3_CURR_ADDR, val)
  527. #define bfin_read_DMA3_CURR_X_COUNT() bfin_read16(DMA3_CURR_X_COUNT)
  528. #define bfin_write_DMA3_CURR_X_COUNT(val) bfin_write16(DMA3_CURR_X_COUNT, val)
  529. #define bfin_read_DMA3_CURR_Y_COUNT() bfin_read16(DMA3_CURR_Y_COUNT)
  530. #define bfin_write_DMA3_CURR_Y_COUNT(val) bfin_write16(DMA3_CURR_Y_COUNT, val)
  531. #define bfin_read_DMA3_IRQ_STATUS() bfin_read16(DMA3_IRQ_STATUS)
  532. #define bfin_write_DMA3_IRQ_STATUS(val) bfin_write16(DMA3_IRQ_STATUS, val)
  533. #define bfin_read_DMA3_PERIPHERAL_MAP() bfin_read16(DMA3_PERIPHERAL_MAP)
  534. #define bfin_write_DMA3_PERIPHERAL_MAP(val) bfin_write16(DMA3_PERIPHERAL_MAP, val)
  535. #define bfin_read_DMA4_CONFIG() bfin_read16(DMA4_CONFIG)
  536. #define bfin_write_DMA4_CONFIG(val) bfin_write16(DMA4_CONFIG, val)
  537. #define bfin_read_DMA4_NEXT_DESC_PTR() bfin_read32(DMA4_NEXT_DESC_PTR)
  538. #define bfin_write_DMA4_NEXT_DESC_PTR(val) bfin_write32(DMA4_NEXT_DESC_PTR, val)
  539. #define bfin_read_DMA4_START_ADDR() bfin_read32(DMA4_START_ADDR)
  540. #define bfin_write_DMA4_START_ADDR(val) bfin_write32(DMA4_START_ADDR, val)
  541. #define bfin_read_DMA4_X_COUNT() bfin_read16(DMA4_X_COUNT)
  542. #define bfin_write_DMA4_X_COUNT(val) bfin_write16(DMA4_X_COUNT, val)
  543. #define bfin_read_DMA4_Y_COUNT() bfin_read16(DMA4_Y_COUNT)
  544. #define bfin_write_DMA4_Y_COUNT(val) bfin_write16(DMA4_Y_COUNT, val)
  545. #define bfin_read_DMA4_X_MODIFY() bfin_read16(DMA4_X_MODIFY)
  546. #define bfin_write_DMA4_X_MODIFY(val) bfin_write16(DMA4_X_MODIFY, val)
  547. #define bfin_read_DMA4_Y_MODIFY() bfin_read16(DMA4_Y_MODIFY)
  548. #define bfin_write_DMA4_Y_MODIFY(val) bfin_write16(DMA4_Y_MODIFY, val)
  549. #define bfin_read_DMA4_CURR_DESC_PTR() bfin_read32(DMA4_CURR_DESC_PTR)
  550. #define bfin_write_DMA4_CURR_DESC_PTR(val) bfin_write32(DMA4_CURR_DESC_PTR, val)
  551. #define bfin_read_DMA4_CURR_ADDR() bfin_read32(DMA4_CURR_ADDR)
  552. #define bfin_write_DMA4_CURR_ADDR(val) bfin_write32(DMA4_CURR_ADDR, val)
  553. #define bfin_read_DMA4_CURR_X_COUNT() bfin_read16(DMA4_CURR_X_COUNT)
  554. #define bfin_write_DMA4_CURR_X_COUNT(val) bfin_write16(DMA4_CURR_X_COUNT, val)
  555. #define bfin_read_DMA4_CURR_Y_COUNT() bfin_read16(DMA4_CURR_Y_COUNT)
  556. #define bfin_write_DMA4_CURR_Y_COUNT(val) bfin_write16(DMA4_CURR_Y_COUNT, val)
  557. #define bfin_read_DMA4_IRQ_STATUS() bfin_read16(DMA4_IRQ_STATUS)
  558. #define bfin_write_DMA4_IRQ_STATUS(val) bfin_write16(DMA4_IRQ_STATUS, val)
  559. #define bfin_read_DMA4_PERIPHERAL_MAP() bfin_read16(DMA4_PERIPHERAL_MAP)
  560. #define bfin_write_DMA4_PERIPHERAL_MAP(val) bfin_write16(DMA4_PERIPHERAL_MAP, val)
  561. #define bfin_read_DMA5_CONFIG() bfin_read16(DMA5_CONFIG)
  562. #define bfin_write_DMA5_CONFIG(val) bfin_write16(DMA5_CONFIG, val)
  563. #define bfin_read_DMA5_NEXT_DESC_PTR() bfin_read32(DMA5_NEXT_DESC_PTR)
  564. #define bfin_write_DMA5_NEXT_DESC_PTR(val) bfin_write32(DMA5_NEXT_DESC_PTR, val)
  565. #define bfin_read_DMA5_START_ADDR() bfin_read32(DMA5_START_ADDR)
  566. #define bfin_write_DMA5_START_ADDR(val) bfin_write32(DMA5_START_ADDR, val)
  567. #define bfin_read_DMA5_X_COUNT() bfin_read16(DMA5_X_COUNT)
  568. #define bfin_write_DMA5_X_COUNT(val) bfin_write16(DMA5_X_COUNT, val)
  569. #define bfin_read_DMA5_Y_COUNT() bfin_read16(DMA5_Y_COUNT)
  570. #define bfin_write_DMA5_Y_COUNT(val) bfin_write16(DMA5_Y_COUNT, val)
  571. #define bfin_read_DMA5_X_MODIFY() bfin_read16(DMA5_X_MODIFY)
  572. #define bfin_write_DMA5_X_MODIFY(val) bfin_write16(DMA5_X_MODIFY, val)
  573. #define bfin_read_DMA5_Y_MODIFY() bfin_read16(DMA5_Y_MODIFY)
  574. #define bfin_write_DMA5_Y_MODIFY(val) bfin_write16(DMA5_Y_MODIFY, val)
  575. #define bfin_read_DMA5_CURR_DESC_PTR() bfin_read32(DMA5_CURR_DESC_PTR)
  576. #define bfin_write_DMA5_CURR_DESC_PTR(val) bfin_write32(DMA5_CURR_DESC_PTR, val)
  577. #define bfin_read_DMA5_CURR_ADDR() bfin_read32(DMA5_CURR_ADDR)
  578. #define bfin_write_DMA5_CURR_ADDR(val) bfin_write32(DMA5_CURR_ADDR, val)
  579. #define bfin_read_DMA5_CURR_X_COUNT() bfin_read16(DMA5_CURR_X_COUNT)
  580. #define bfin_write_DMA5_CURR_X_COUNT(val) bfin_write16(DMA5_CURR_X_COUNT, val)
  581. #define bfin_read_DMA5_CURR_Y_COUNT() bfin_read16(DMA5_CURR_Y_COUNT)
  582. #define bfin_write_DMA5_CURR_Y_COUNT(val) bfin_write16(DMA5_CURR_Y_COUNT, val)
  583. #define bfin_read_DMA5_IRQ_STATUS() bfin_read16(DMA5_IRQ_STATUS)
  584. #define bfin_write_DMA5_IRQ_STATUS(val) bfin_write16(DMA5_IRQ_STATUS, val)
  585. #define bfin_read_DMA5_PERIPHERAL_MAP() bfin_read16(DMA5_PERIPHERAL_MAP)
  586. #define bfin_write_DMA5_PERIPHERAL_MAP(val) bfin_write16(DMA5_PERIPHERAL_MAP, val)
  587. #define bfin_read_DMA6_CONFIG() bfin_read16(DMA6_CONFIG)
  588. #define bfin_write_DMA6_CONFIG(val) bfin_write16(DMA6_CONFIG, val)
  589. #define bfin_read_DMA6_NEXT_DESC_PTR() bfin_read32(DMA6_NEXT_DESC_PTR)
  590. #define bfin_write_DMA6_NEXT_DESC_PTR(val) bfin_write32(DMA6_NEXT_DESC_PTR, val)
  591. #define bfin_read_DMA6_START_ADDR() bfin_read32(DMA6_START_ADDR)
  592. #define bfin_write_DMA6_START_ADDR(val) bfin_write32(DMA6_START_ADDR, val)
  593. #define bfin_read_DMA6_X_COUNT() bfin_read16(DMA6_X_COUNT)
  594. #define bfin_write_DMA6_X_COUNT(val) bfin_write16(DMA6_X_COUNT, val)
  595. #define bfin_read_DMA6_Y_COUNT() bfin_read16(DMA6_Y_COUNT)
  596. #define bfin_write_DMA6_Y_COUNT(val) bfin_write16(DMA6_Y_COUNT, val)
  597. #define bfin_read_DMA6_X_MODIFY() bfin_read16(DMA6_X_MODIFY)
  598. #define bfin_write_DMA6_X_MODIFY(val) bfin_write16(DMA6_X_MODIFY, val)
  599. #define bfin_read_DMA6_Y_MODIFY() bfin_read16(DMA6_Y_MODIFY)
  600. #define bfin_write_DMA6_Y_MODIFY(val) bfin_write16(DMA6_Y_MODIFY, val)
  601. #define bfin_read_DMA6_CURR_DESC_PTR() bfin_read32(DMA6_CURR_DESC_PTR)
  602. #define bfin_write_DMA6_CURR_DESC_PTR(val) bfin_write32(DMA6_CURR_DESC_PTR, val)
  603. #define bfin_read_DMA6_CURR_ADDR() bfin_read32(DMA6_CURR_ADDR)
  604. #define bfin_write_DMA6_CURR_ADDR(val) bfin_write32(DMA6_CURR_ADDR, val)
  605. #define bfin_read_DMA6_CURR_X_COUNT() bfin_read16(DMA6_CURR_X_COUNT)
  606. #define bfin_write_DMA6_CURR_X_COUNT(val) bfin_write16(DMA6_CURR_X_COUNT, val)
  607. #define bfin_read_DMA6_CURR_Y_COUNT() bfin_read16(DMA6_CURR_Y_COUNT)
  608. #define bfin_write_DMA6_CURR_Y_COUNT(val) bfin_write16(DMA6_CURR_Y_COUNT, val)
  609. #define bfin_read_DMA6_IRQ_STATUS() bfin_read16(DMA6_IRQ_STATUS)
  610. #define bfin_write_DMA6_IRQ_STATUS(val) bfin_write16(DMA6_IRQ_STATUS, val)
  611. #define bfin_read_DMA6_PERIPHERAL_MAP() bfin_read16(DMA6_PERIPHERAL_MAP)
  612. #define bfin_write_DMA6_PERIPHERAL_MAP(val) bfin_write16(DMA6_PERIPHERAL_MAP, val)
  613. #define bfin_read_DMA7_CONFIG() bfin_read16(DMA7_CONFIG)
  614. #define bfin_write_DMA7_CONFIG(val) bfin_write16(DMA7_CONFIG, val)
  615. #define bfin_read_DMA7_NEXT_DESC_PTR() bfin_read32(DMA7_NEXT_DESC_PTR)
  616. #define bfin_write_DMA7_NEXT_DESC_PTR(val) bfin_write32(DMA7_NEXT_DESC_PTR, val)
  617. #define bfin_read_DMA7_START_ADDR() bfin_read32(DMA7_START_ADDR)
  618. #define bfin_write_DMA7_START_ADDR(val) bfin_write32(DMA7_START_ADDR, val)
  619. #define bfin_read_DMA7_X_COUNT() bfin_read16(DMA7_X_COUNT)
  620. #define bfin_write_DMA7_X_COUNT(val) bfin_write16(DMA7_X_COUNT, val)
  621. #define bfin_read_DMA7_Y_COUNT() bfin_read16(DMA7_Y_COUNT)
  622. #define bfin_write_DMA7_Y_COUNT(val) bfin_write16(DMA7_Y_COUNT, val)
  623. #define bfin_read_DMA7_X_MODIFY() bfin_read16(DMA7_X_MODIFY)
  624. #define bfin_write_DMA7_X_MODIFY(val) bfin_write16(DMA7_X_MODIFY, val)
  625. #define bfin_read_DMA7_Y_MODIFY() bfin_read16(DMA7_Y_MODIFY)
  626. #define bfin_write_DMA7_Y_MODIFY(val) bfin_write16(DMA7_Y_MODIFY, val)
  627. #define bfin_read_DMA7_CURR_DESC_PTR() bfin_read32(DMA7_CURR_DESC_PTR)
  628. #define bfin_write_DMA7_CURR_DESC_PTR(val) bfin_write32(DMA7_CURR_DESC_PTR, val)
  629. #define bfin_read_DMA7_CURR_ADDR() bfin_read32(DMA7_CURR_ADDR)
  630. #define bfin_write_DMA7_CURR_ADDR(val) bfin_write32(DMA7_CURR_ADDR, val)
  631. #define bfin_read_DMA7_CURR_X_COUNT() bfin_read16(DMA7_CURR_X_COUNT)
  632. #define bfin_write_DMA7_CURR_X_COUNT(val) bfin_write16(DMA7_CURR_X_COUNT, val)
  633. #define bfin_read_DMA7_CURR_Y_COUNT() bfin_read16(DMA7_CURR_Y_COUNT)
  634. #define bfin_write_DMA7_CURR_Y_COUNT(val) bfin_write16(DMA7_CURR_Y_COUNT, val)
  635. #define bfin_read_DMA7_IRQ_STATUS() bfin_read16(DMA7_IRQ_STATUS)
  636. #define bfin_write_DMA7_IRQ_STATUS(val) bfin_write16(DMA7_IRQ_STATUS, val)
  637. #define bfin_read_DMA7_PERIPHERAL_MAP() bfin_read16(DMA7_PERIPHERAL_MAP)
  638. #define bfin_write_DMA7_PERIPHERAL_MAP(val) bfin_write16(DMA7_PERIPHERAL_MAP, val)
  639. #define bfin_read_DMA8_CONFIG() bfin_read16(DMA8_CONFIG)
  640. #define bfin_write_DMA8_CONFIG(val) bfin_write16(DMA8_CONFIG, val)
  641. #define bfin_read_DMA8_NEXT_DESC_PTR() bfin_read32(DMA8_NEXT_DESC_PTR)
  642. #define bfin_write_DMA8_NEXT_DESC_PTR(val) bfin_write32(DMA8_NEXT_DESC_PTR, val)
  643. #define bfin_read_DMA8_START_ADDR() bfin_read32(DMA8_START_ADDR)
  644. #define bfin_write_DMA8_START_ADDR(val) bfin_write32(DMA8_START_ADDR, val)
  645. #define bfin_read_DMA8_X_COUNT() bfin_read16(DMA8_X_COUNT)
  646. #define bfin_write_DMA8_X_COUNT(val) bfin_write16(DMA8_X_COUNT, val)
  647. #define bfin_read_DMA8_Y_COUNT() bfin_read16(DMA8_Y_COUNT)
  648. #define bfin_write_DMA8_Y_COUNT(val) bfin_write16(DMA8_Y_COUNT, val)
  649. #define bfin_read_DMA8_X_MODIFY() bfin_read16(DMA8_X_MODIFY)
  650. #define bfin_write_DMA8_X_MODIFY(val) bfin_write16(DMA8_X_MODIFY, val)
  651. #define bfin_read_DMA8_Y_MODIFY() bfin_read16(DMA8_Y_MODIFY)
  652. #define bfin_write_DMA8_Y_MODIFY(val) bfin_write16(DMA8_Y_MODIFY, val)
  653. #define bfin_read_DMA8_CURR_DESC_PTR() bfin_read32(DMA8_CURR_DESC_PTR)
  654. #define bfin_write_DMA8_CURR_DESC_PTR(val) bfin_write32(DMA8_CURR_DESC_PTR, val)
  655. #define bfin_read_DMA8_CURR_ADDR() bfin_read32(DMA8_CURR_ADDR)
  656. #define bfin_write_DMA8_CURR_ADDR(val) bfin_write32(DMA8_CURR_ADDR, val)
  657. #define bfin_read_DMA8_CURR_X_COUNT() bfin_read16(DMA8_CURR_X_COUNT)
  658. #define bfin_write_DMA8_CURR_X_COUNT(val) bfin_write16(DMA8_CURR_X_COUNT, val)
  659. #define bfin_read_DMA8_CURR_Y_COUNT() bfin_read16(DMA8_CURR_Y_COUNT)
  660. #define bfin_write_DMA8_CURR_Y_COUNT(val) bfin_write16(DMA8_CURR_Y_COUNT, val)
  661. #define bfin_read_DMA8_IRQ_STATUS() bfin_read16(DMA8_IRQ_STATUS)
  662. #define bfin_write_DMA8_IRQ_STATUS(val) bfin_write16(DMA8_IRQ_STATUS, val)
  663. #define bfin_read_DMA8_PERIPHERAL_MAP() bfin_read16(DMA8_PERIPHERAL_MAP)
  664. #define bfin_write_DMA8_PERIPHERAL_MAP(val) bfin_write16(DMA8_PERIPHERAL_MAP, val)
  665. #define bfin_read_DMA9_CONFIG() bfin_read16(DMA9_CONFIG)
  666. #define bfin_write_DMA9_CONFIG(val) bfin_write16(DMA9_CONFIG, val)
  667. #define bfin_read_DMA9_NEXT_DESC_PTR() bfin_read32(DMA9_NEXT_DESC_PTR)
  668. #define bfin_write_DMA9_NEXT_DESC_PTR(val) bfin_write32(DMA9_NEXT_DESC_PTR, val)
  669. #define bfin_read_DMA9_START_ADDR() bfin_read32(DMA9_START_ADDR)
  670. #define bfin_write_DMA9_START_ADDR(val) bfin_write32(DMA9_START_ADDR, val)
  671. #define bfin_read_DMA9_X_COUNT() bfin_read16(DMA9_X_COUNT)
  672. #define bfin_write_DMA9_X_COUNT(val) bfin_write16(DMA9_X_COUNT, val)
  673. #define bfin_read_DMA9_Y_COUNT() bfin_read16(DMA9_Y_COUNT)
  674. #define bfin_write_DMA9_Y_COUNT(val) bfin_write16(DMA9_Y_COUNT, val)
  675. #define bfin_read_DMA9_X_MODIFY() bfin_read16(DMA9_X_MODIFY)
  676. #define bfin_write_DMA9_X_MODIFY(val) bfin_write16(DMA9_X_MODIFY, val)
  677. #define bfin_read_DMA9_Y_MODIFY() bfin_read16(DMA9_Y_MODIFY)
  678. #define bfin_write_DMA9_Y_MODIFY(val) bfin_write16(DMA9_Y_MODIFY, val)
  679. #define bfin_read_DMA9_CURR_DESC_PTR() bfin_read32(DMA9_CURR_DESC_PTR)
  680. #define bfin_write_DMA9_CURR_DESC_PTR(val) bfin_write32(DMA9_CURR_DESC_PTR, val)
  681. #define bfin_read_DMA9_CURR_ADDR() bfin_read32(DMA9_CURR_ADDR)
  682. #define bfin_write_DMA9_CURR_ADDR(val) bfin_write32(DMA9_CURR_ADDR, val)
  683. #define bfin_read_DMA9_CURR_X_COUNT() bfin_read16(DMA9_CURR_X_COUNT)
  684. #define bfin_write_DMA9_CURR_X_COUNT(val) bfin_write16(DMA9_CURR_X_COUNT, val)
  685. #define bfin_read_DMA9_CURR_Y_COUNT() bfin_read16(DMA9_CURR_Y_COUNT)
  686. #define bfin_write_DMA9_CURR_Y_COUNT(val) bfin_write16(DMA9_CURR_Y_COUNT, val)
  687. #define bfin_read_DMA9_IRQ_STATUS() bfin_read16(DMA9_IRQ_STATUS)
  688. #define bfin_write_DMA9_IRQ_STATUS(val) bfin_write16(DMA9_IRQ_STATUS, val)
  689. #define bfin_read_DMA9_PERIPHERAL_MAP() bfin_read16(DMA9_PERIPHERAL_MAP)
  690. #define bfin_write_DMA9_PERIPHERAL_MAP(val) bfin_write16(DMA9_PERIPHERAL_MAP, val)
  691. #define bfin_read_DMA10_CONFIG() bfin_read16(DMA10_CONFIG)
  692. #define bfin_write_DMA10_CONFIG(val) bfin_write16(DMA10_CONFIG, val)
  693. #define bfin_read_DMA10_NEXT_DESC_PTR() bfin_read32(DMA10_NEXT_DESC_PTR)
  694. #define bfin_write_DMA10_NEXT_DESC_PTR(val) bfin_write32(DMA10_NEXT_DESC_PTR, val)
  695. #define bfin_read_DMA10_START_ADDR() bfin_read32(DMA10_START_ADDR)
  696. #define bfin_write_DMA10_START_ADDR(val) bfin_write32(DMA10_START_ADDR, val)
  697. #define bfin_read_DMA10_X_COUNT() bfin_read16(DMA10_X_COUNT)
  698. #define bfin_write_DMA10_X_COUNT(val) bfin_write16(DMA10_X_COUNT, val)
  699. #define bfin_read_DMA10_Y_COUNT() bfin_read16(DMA10_Y_COUNT)
  700. #define bfin_write_DMA10_Y_COUNT(val) bfin_write16(DMA10_Y_COUNT, val)
  701. #define bfin_read_DMA10_X_MODIFY() bfin_read16(DMA10_X_MODIFY)
  702. #define bfin_write_DMA10_X_MODIFY(val) bfin_write16(DMA10_X_MODIFY, val)
  703. #define bfin_read_DMA10_Y_MODIFY() bfin_read16(DMA10_Y_MODIFY)
  704. #define bfin_write_DMA10_Y_MODIFY(val) bfin_write16(DMA10_Y_MODIFY, val)
  705. #define bfin_read_DMA10_CURR_DESC_PTR() bfin_read32(DMA10_CURR_DESC_PTR)
  706. #define bfin_write_DMA10_CURR_DESC_PTR(val) bfin_write32(DMA10_CURR_DESC_PTR, val)
  707. #define bfin_read_DMA10_CURR_ADDR() bfin_read32(DMA10_CURR_ADDR)
  708. #define bfin_write_DMA10_CURR_ADDR(val) bfin_write32(DMA10_CURR_ADDR, val)
  709. #define bfin_read_DMA10_CURR_X_COUNT() bfin_read16(DMA10_CURR_X_COUNT)
  710. #define bfin_write_DMA10_CURR_X_COUNT(val) bfin_write16(DMA10_CURR_X_COUNT, val)
  711. #define bfin_read_DMA10_CURR_Y_COUNT() bfin_read16(DMA10_CURR_Y_COUNT)
  712. #define bfin_write_DMA10_CURR_Y_COUNT(val) bfin_write16(DMA10_CURR_Y_COUNT, val)
  713. #define bfin_read_DMA10_IRQ_STATUS() bfin_read16(DMA10_IRQ_STATUS)
  714. #define bfin_write_DMA10_IRQ_STATUS(val) bfin_write16(DMA10_IRQ_STATUS, val)
  715. #define bfin_read_DMA10_PERIPHERAL_MAP() bfin_read16(DMA10_PERIPHERAL_MAP)
  716. #define bfin_write_DMA10_PERIPHERAL_MAP(val) bfin_write16(DMA10_PERIPHERAL_MAP, val)
  717. #define bfin_read_DMA11_CONFIG() bfin_read16(DMA11_CONFIG)
  718. #define bfin_write_DMA11_CONFIG(val) bfin_write16(DMA11_CONFIG, val)
  719. #define bfin_read_DMA11_NEXT_DESC_PTR() bfin_read32(DMA11_NEXT_DESC_PTR)
  720. #define bfin_write_DMA11_NEXT_DESC_PTR(val) bfin_write32(DMA11_NEXT_DESC_PTR, val)
  721. #define bfin_read_DMA11_START_ADDR() bfin_read32(DMA11_START_ADDR)
  722. #define bfin_write_DMA11_START_ADDR(val) bfin_write32(DMA11_START_ADDR, val)
  723. #define bfin_read_DMA11_X_COUNT() bfin_read16(DMA11_X_COUNT)
  724. #define bfin_write_DMA11_X_COUNT(val) bfin_write16(DMA11_X_COUNT, val)
  725. #define bfin_read_DMA11_Y_COUNT() bfin_read16(DMA11_Y_COUNT)
  726. #define bfin_write_DMA11_Y_COUNT(val) bfin_write16(DMA11_Y_COUNT, val)
  727. #define bfin_read_DMA11_X_MODIFY() bfin_read16(DMA11_X_MODIFY)
  728. #define bfin_write_DMA11_X_MODIFY(val) bfin_write16(DMA11_X_MODIFY, val)
  729. #define bfin_read_DMA11_Y_MODIFY() bfin_read16(DMA11_Y_MODIFY)
  730. #define bfin_write_DMA11_Y_MODIFY(val) bfin_write16(DMA11_Y_MODIFY, val)
  731. #define bfin_read_DMA11_CURR_DESC_PTR() bfin_read32(DMA11_CURR_DESC_PTR)
  732. #define bfin_write_DMA11_CURR_DESC_PTR(val) bfin_write32(DMA11_CURR_DESC_PTR, val)
  733. #define bfin_read_DMA11_CURR_ADDR() bfin_read32(DMA11_CURR_ADDR)
  734. #define bfin_write_DMA11_CURR_ADDR(val) bfin_write32(DMA11_CURR_ADDR, val)
  735. #define bfin_read_DMA11_CURR_X_COUNT() bfin_read16(DMA11_CURR_X_COUNT)
  736. #define bfin_write_DMA11_CURR_X_COUNT(val) bfin_write16(DMA11_CURR_X_COUNT, val)
  737. #define bfin_read_DMA11_CURR_Y_COUNT() bfin_read16(DMA11_CURR_Y_COUNT)
  738. #define bfin_write_DMA11_CURR_Y_COUNT(val) bfin_write16(DMA11_CURR_Y_COUNT, val)
  739. #define bfin_read_DMA11_IRQ_STATUS() bfin_read16(DMA11_IRQ_STATUS)
  740. #define bfin_write_DMA11_IRQ_STATUS(val) bfin_write16(DMA11_IRQ_STATUS, val)
  741. #define bfin_read_DMA11_PERIPHERAL_MAP() bfin_read16(DMA11_PERIPHERAL_MAP)
  742. #define bfin_write_DMA11_PERIPHERAL_MAP(val) bfin_write16(DMA11_PERIPHERAL_MAP, val)
  743. #define bfin_read_MDMA_D0_CONFIG() bfin_read16(MDMA_D0_CONFIG)
  744. #define bfin_write_MDMA_D0_CONFIG(val) bfin_write16(MDMA_D0_CONFIG, val)
  745. #define bfin_read_MDMA_D0_NEXT_DESC_PTR() bfin_read32(MDMA_D0_NEXT_DESC_PTR)
  746. #define bfin_write_MDMA_D0_NEXT_DESC_PTR(val) bfin_write32(MDMA_D0_NEXT_DESC_PTR, val)
  747. #define bfin_read_MDMA_D0_START_ADDR() bfin_read32(MDMA_D0_START_ADDR)
  748. #define bfin_write_MDMA_D0_START_ADDR(val) bfin_write32(MDMA_D0_START_ADDR, val)
  749. #define bfin_read_MDMA_D0_X_COUNT() bfin_read16(MDMA_D0_X_COUNT)
  750. #define bfin_write_MDMA_D0_X_COUNT(val) bfin_write16(MDMA_D0_X_COUNT, val)
  751. #define bfin_read_MDMA_D0_Y_COUNT() bfin_read16(MDMA_D0_Y_COUNT)
  752. #define bfin_write_MDMA_D0_Y_COUNT(val) bfin_write16(MDMA_D0_Y_COUNT, val)
  753. #define bfin_read_MDMA_D0_X_MODIFY() bfin_read16(MDMA_D0_X_MODIFY)
  754. #define bfin_write_MDMA_D0_X_MODIFY(val) bfin_write16(MDMA_D0_X_MODIFY, val)
  755. #define bfin_read_MDMA_D0_Y_MODIFY() bfin_read16(MDMA_D0_Y_MODIFY)
  756. #define bfin_write_MDMA_D0_Y_MODIFY(val) bfin_write16(MDMA_D0_Y_MODIFY, val)
  757. #define bfin_read_MDMA_D0_CURR_DESC_PTR() bfin_read32(MDMA_D0_CURR_DESC_PTR)
  758. #define bfin_write_MDMA_D0_CURR_DESC_PTR(val) bfin_write32(MDMA_D0_CURR_DESC_PTR, val)
  759. #define bfin_read_MDMA_D0_CURR_ADDR() bfin_read32(MDMA_D0_CURR_ADDR)
  760. #define bfin_write_MDMA_D0_CURR_ADDR(val) bfin_write32(MDMA_D0_CURR_ADDR, val)
  761. #define bfin_read_MDMA_D0_CURR_X_COUNT() bfin_read16(MDMA_D0_CURR_X_COUNT)
  762. #define bfin_write_MDMA_D0_CURR_X_COUNT(val) bfin_write16(MDMA_D0_CURR_X_COUNT, val)
  763. #define bfin_read_MDMA_D0_CURR_Y_COUNT() bfin_read16(MDMA_D0_CURR_Y_COUNT)
  764. #define bfin_write_MDMA_D0_CURR_Y_COUNT(val) bfin_write16(MDMA_D0_CURR_Y_COUNT, val)
  765. #define bfin_read_MDMA_D0_IRQ_STATUS() bfin_read16(MDMA_D0_IRQ_STATUS)
  766. #define bfin_write_MDMA_D0_IRQ_STATUS(val) bfin_write16(MDMA_D0_IRQ_STATUS, val)
  767. #define bfin_read_MDMA_D0_PERIPHERAL_MAP() bfin_read16(MDMA_D0_PERIPHERAL_MAP)
  768. #define bfin_write_MDMA_D0_PERIPHERAL_MAP(val) bfin_write16(MDMA_D0_PERIPHERAL_MAP, val)
  769. #define bfin_read_MDMA_S0_CONFIG() bfin_read16(MDMA_S0_CONFIG)
  770. #define bfin_write_MDMA_S0_CONFIG(val) bfin_write16(MDMA_S0_CONFIG, val)
  771. #define bfin_read_MDMA_S0_NEXT_DESC_PTR() bfin_read32(MDMA_S0_NEXT_DESC_PTR)
  772. #define bfin_write_MDMA_S0_NEXT_DESC_PTR(val) bfin_write32(MDMA_S0_NEXT_DESC_PTR, val)
  773. #define bfin_read_MDMA_S0_START_ADDR() bfin_read32(MDMA_S0_START_ADDR)
  774. #define bfin_write_MDMA_S0_START_ADDR(val) bfin_write32(MDMA_S0_START_ADDR, val)
  775. #define bfin_read_MDMA_S0_X_COUNT() bfin_read16(MDMA_S0_X_COUNT)
  776. #define bfin_write_MDMA_S0_X_COUNT(val) bfin_write16(MDMA_S0_X_COUNT, val)
  777. #define bfin_read_MDMA_S0_Y_COUNT() bfin_read16(MDMA_S0_Y_COUNT)
  778. #define bfin_write_MDMA_S0_Y_COUNT(val) bfin_write16(MDMA_S0_Y_COUNT, val)
  779. #define bfin_read_MDMA_S0_X_MODIFY() bfin_read16(MDMA_S0_X_MODIFY)
  780. #define bfin_write_MDMA_S0_X_MODIFY(val) bfin_write16(MDMA_S0_X_MODIFY, val)
  781. #define bfin_read_MDMA_S0_Y_MODIFY() bfin_read16(MDMA_S0_Y_MODIFY)
  782. #define bfin_write_MDMA_S0_Y_MODIFY(val) bfin_write16(MDMA_S0_Y_MODIFY, val)
  783. #define bfin_read_MDMA_S0_CURR_DESC_PTR() bfin_read32(MDMA_S0_CURR_DESC_PTR)
  784. #define bfin_write_MDMA_S0_CURR_DESC_PTR(val) bfin_write32(MDMA_S0_CURR_DESC_PTR, val)
  785. #define bfin_read_MDMA_S0_CURR_ADDR() bfin_read32(MDMA_S0_CURR_ADDR)
  786. #define bfin_write_MDMA_S0_CURR_ADDR(val) bfin_write32(MDMA_S0_CURR_ADDR, val)
  787. #define bfin_read_MDMA_S0_CURR_X_COUNT() bfin_read16(MDMA_S0_CURR_X_COUNT)
  788. #define bfin_write_MDMA_S0_CURR_X_COUNT(val) bfin_write16(MDMA_S0_CURR_X_COUNT, val)
  789. #define bfin_read_MDMA_S0_CURR_Y_COUNT() bfin_read16(MDMA_S0_CURR_Y_COUNT)
  790. #define bfin_write_MDMA_S0_CURR_Y_COUNT(val) bfin_write16(MDMA_S0_CURR_Y_COUNT, val)
  791. #define bfin_read_MDMA_S0_IRQ_STATUS() bfin_read16(MDMA_S0_IRQ_STATUS)
  792. #define bfin_write_MDMA_S0_IRQ_STATUS(val) bfin_write16(MDMA_S0_IRQ_STATUS, val)
  793. #define bfin_read_MDMA_S0_PERIPHERAL_MAP() bfin_read16(MDMA_S0_PERIPHERAL_MAP)
  794. #define bfin_write_MDMA_S0_PERIPHERAL_MAP(val) bfin_write16(MDMA_S0_PERIPHERAL_MAP, val)
  795. #define bfin_read_MDMA_D1_CONFIG() bfin_read16(MDMA_D1_CONFIG)
  796. #define bfin_write_MDMA_D1_CONFIG(val) bfin_write16(MDMA_D1_CONFIG, val)
  797. #define bfin_read_MDMA_D1_NEXT_DESC_PTR() bfin_read32(MDMA_D1_NEXT_DESC_PTR)
  798. #define bfin_write_MDMA_D1_NEXT_DESC_PTR(val) bfin_write32(MDMA_D1_NEXT_DESC_PTR, val)
  799. #define bfin_read_MDMA_D1_START_ADDR() bfin_read32(MDMA_D1_START_ADDR)
  800. #define bfin_write_MDMA_D1_START_ADDR(val) bfin_write32(MDMA_D1_START_ADDR, val)
  801. #define bfin_read_MDMA_D1_X_COUNT() bfin_read16(MDMA_D1_X_COUNT)
  802. #define bfin_write_MDMA_D1_X_COUNT(val) bfin_write16(MDMA_D1_X_COUNT, val)
  803. #define bfin_read_MDMA_D1_Y_COUNT() bfin_read16(MDMA_D1_Y_COUNT)
  804. #define bfin_write_MDMA_D1_Y_COUNT(val) bfin_write16(MDMA_D1_Y_COUNT, val)
  805. #define bfin_read_MDMA_D1_X_MODIFY() bfin_read16(MDMA_D1_X_MODIFY)
  806. #define bfin_write_MDMA_D1_X_MODIFY(val) bfin_write16(MDMA_D1_X_MODIFY, val)
  807. #define bfin_read_MDMA_D1_Y_MODIFY() bfin_read16(MDMA_D1_Y_MODIFY)
  808. #define bfin_write_MDMA_D1_Y_MODIFY(val) bfin_write16(MDMA_D1_Y_MODIFY, val)
  809. #define bfin_read_MDMA_D1_CURR_DESC_PTR() bfin_read32(MDMA_D1_CURR_DESC_PTR)
  810. #define bfin_write_MDMA_D1_CURR_DESC_PTR(val) bfin_write32(MDMA_D1_CURR_DESC_PTR, val)
  811. #define bfin_read_MDMA_D1_CURR_ADDR() bfin_read32(MDMA_D1_CURR_ADDR)
  812. #define bfin_write_MDMA_D1_CURR_ADDR(val) bfin_write32(MDMA_D1_CURR_ADDR, val)
  813. #define bfin_read_MDMA_D1_CURR_X_COUNT() bfin_read16(MDMA_D1_CURR_X_COUNT)
  814. #define bfin_write_MDMA_D1_CURR_X_COUNT(val) bfin_write16(MDMA_D1_CURR_X_COUNT, val)
  815. #define bfin_read_MDMA_D1_CURR_Y_COUNT() bfin_read16(MDMA_D1_CURR_Y_COUNT)
  816. #define bfin_write_MDMA_D1_CURR_Y_COUNT(val) bfin_write16(MDMA_D1_CURR_Y_COUNT, val)
  817. #define bfin_read_MDMA_D1_IRQ_STATUS() bfin_read16(MDMA_D1_IRQ_STATUS)
  818. #define bfin_write_MDMA_D1_IRQ_STATUS(val) bfin_write16(MDMA_D1_IRQ_STATUS, val)
  819. #define bfin_read_MDMA_D1_PERIPHERAL_MAP() bfin_read16(MDMA_D1_PERIPHERAL_MAP)
  820. #define bfin_write_MDMA_D1_PERIPHERAL_MAP(val) bfin_write16(MDMA_D1_PERIPHERAL_MAP, val)
  821. #define bfin_read_MDMA_S1_CONFIG() bfin_read16(MDMA_S1_CONFIG)
  822. #define bfin_write_MDMA_S1_CONFIG(val) bfin_write16(MDMA_S1_CONFIG, val)
  823. #define bfin_read_MDMA_S1_NEXT_DESC_PTR() bfin_read32(MDMA_S1_NEXT_DESC_PTR)
  824. #define bfin_write_MDMA_S1_NEXT_DESC_PTR(val) bfin_write32(MDMA_S1_NEXT_DESC_PTR, val)
  825. #define bfin_read_MDMA_S1_START_ADDR() bfin_read32(MDMA_S1_START_ADDR)
  826. #define bfin_write_MDMA_S1_START_ADDR(val) bfin_write32(MDMA_S1_START_ADDR, val)
  827. #define bfin_read_MDMA_S1_X_COUNT() bfin_read16(MDMA_S1_X_COUNT)
  828. #define bfin_write_MDMA_S1_X_COUNT(val) bfin_write16(MDMA_S1_X_COUNT, val)
  829. #define bfin_read_MDMA_S1_Y_COUNT() bfin_read16(MDMA_S1_Y_COUNT)
  830. #define bfin_write_MDMA_S1_Y_COUNT(val) bfin_write16(MDMA_S1_Y_COUNT, val)
  831. #define bfin_read_MDMA_S1_X_MODIFY() bfin_read16(MDMA_S1_X_MODIFY)
  832. #define bfin_write_MDMA_S1_X_MODIFY(val) bfin_write16(MDMA_S1_X_MODIFY, val)
  833. #define bfin_read_MDMA_S1_Y_MODIFY() bfin_read16(MDMA_S1_Y_MODIFY)
  834. #define bfin_write_MDMA_S1_Y_MODIFY(val) bfin_write16(MDMA_S1_Y_MODIFY, val)
  835. #define bfin_read_MDMA_S1_CURR_DESC_PTR() bfin_read32(MDMA_S1_CURR_DESC_PTR)
  836. #define bfin_write_MDMA_S1_CURR_DESC_PTR(val) bfin_write32(MDMA_S1_CURR_DESC_PTR, val)
  837. #define bfin_read_MDMA_S1_CURR_ADDR() bfin_read32(MDMA_S1_CURR_ADDR)
  838. #define bfin_write_MDMA_S1_CURR_ADDR(val) bfin_write32(MDMA_S1_CURR_ADDR, val)
  839. #define bfin_read_MDMA_S1_CURR_X_COUNT() bfin_read16(MDMA_S1_CURR_X_COUNT)
  840. #define bfin_write_MDMA_S1_CURR_X_COUNT(val) bfin_write16(MDMA_S1_CURR_X_COUNT, val)
  841. #define bfin_read_MDMA_S1_CURR_Y_COUNT() bfin_read16(MDMA_S1_CURR_Y_COUNT)
  842. #define bfin_write_MDMA_S1_CURR_Y_COUNT(val) bfin_write16(MDMA_S1_CURR_Y_COUNT, val)
  843. #define bfin_read_MDMA_S1_IRQ_STATUS() bfin_read16(MDMA_S1_IRQ_STATUS)
  844. #define bfin_write_MDMA_S1_IRQ_STATUS(val) bfin_write16(MDMA_S1_IRQ_STATUS, val)
  845. #define bfin_read_MDMA_S1_PERIPHERAL_MAP() bfin_read16(MDMA_S1_PERIPHERAL_MAP)
  846. #define bfin_write_MDMA_S1_PERIPHERAL_MAP(val) bfin_write16(MDMA_S1_PERIPHERAL_MAP, val)
  847. /* Parallel Peripheral Interface (0xFFC01000 - 0xFFC010FF) */
  848. #define bfin_read_PPI_CONTROL() bfin_read16(PPI_CONTROL)
  849. #define bfin_write_PPI_CONTROL(val) bfin_write16(PPI_CONTROL, val)
  850. #define bfin_read_PPI_STATUS() bfin_read16(PPI_STATUS)
  851. #define bfin_write_PPI_STATUS(val) bfin_write16(PPI_STATUS, val)
  852. #define bfin_read_PPI_DELAY() bfin_read16(PPI_DELAY)
  853. #define bfin_write_PPI_DELAY(val) bfin_write16(PPI_DELAY, val)
  854. #define bfin_read_PPI_COUNT() bfin_read16(PPI_COUNT)
  855. #define bfin_write_PPI_COUNT(val) bfin_write16(PPI_COUNT, val)
  856. #define bfin_read_PPI_FRAME() bfin_read16(PPI_FRAME)
  857. #define bfin_write_PPI_FRAME(val) bfin_write16(PPI_FRAME, val)
  858. /* Two-Wire Interface (0xFFC01400 - 0xFFC014FF) */
  859. /* General Purpose I/O Port G (0xFFC01500 - 0xFFC015FF) */
  860. #define bfin_read_PORTGIO() bfin_read16(PORTGIO)
  861. #define bfin_write_PORTGIO(val) bfin_write16(PORTGIO, val)
  862. #define bfin_read_PORTGIO_CLEAR() bfin_read16(PORTGIO_CLEAR)
  863. #define bfin_write_PORTGIO_CLEAR(val) bfin_write16(PORTGIO_CLEAR, val)
  864. #define bfin_read_PORTGIO_SET() bfin_read16(PORTGIO_SET)
  865. #define bfin_write_PORTGIO_SET(val) bfin_write16(PORTGIO_SET, val)
  866. #define bfin_read_PORTGIO_TOGGLE() bfin_read16(PORTGIO_TOGGLE)
  867. #define bfin_write_PORTGIO_TOGGLE(val) bfin_write16(PORTGIO_TOGGLE, val)
  868. #define bfin_read_PORTGIO_MASKA() bfin_read16(PORTGIO_MASKA)
  869. #define bfin_write_PORTGIO_MASKA(val) bfin_write16(PORTGIO_MASKA, val)
  870. #define bfin_read_PORTGIO_MASKA_CLEAR() bfin_read16(PORTGIO_MASKA_CLEAR)
  871. #define bfin_write_PORTGIO_MASKA_CLEAR(val) bfin_write16(PORTGIO_MASKA_CLEAR, val)
  872. #define bfin_read_PORTGIO_MASKA_SET() bfin_read16(PORTGIO_MASKA_SET)
  873. #define bfin_write_PORTGIO_MASKA_SET(val) bfin_write16(PORTGIO_MASKA_SET, val)
  874. #define bfin_read_PORTGIO_MASKA_TOGGLE() bfin_read16(PORTGIO_MASKA_TOGGLE)
  875. #define bfin_write_PORTGIO_MASKA_TOGGLE(val) bfin_write16(PORTGIO_MASKA_TOGGLE, val)
  876. #define bfin_read_PORTGIO_MASKB() bfin_read16(PORTGIO_MASKB)
  877. #define bfin_write_PORTGIO_MASKB(val) bfin_write16(PORTGIO_MASKB, val)
  878. #define bfin_read_PORTGIO_MASKB_CLEAR() bfin_read16(PORTGIO_MASKB_CLEAR)
  879. #define bfin_write_PORTGIO_MASKB_CLEAR(val) bfin_write16(PORTGIO_MASKB_CLEAR, val)
  880. #define bfin_read_PORTGIO_MASKB_SET() bfin_read16(PORTGIO_MASKB_SET)
  881. #define bfin_write_PORTGIO_MASKB_SET(val) bfin_write16(PORTGIO_MASKB_SET, val)
  882. #define bfin_read_PORTGIO_MASKB_TOGGLE() bfin_read16(PORTGIO_MASKB_TOGGLE)
  883. #define bfin_write_PORTGIO_MASKB_TOGGLE(val) bfin_write16(PORTGIO_MASKB_TOGGLE, val)
  884. #define bfin_read_PORTGIO_DIR() bfin_read16(PORTGIO_DIR)
  885. #define bfin_write_PORTGIO_DIR(val) bfin_write16(PORTGIO_DIR, val)
  886. #define bfin_read_PORTGIO_POLAR() bfin_read16(PORTGIO_POLAR)
  887. #define bfin_write_PORTGIO_POLAR(val) bfin_write16(PORTGIO_POLAR, val)
  888. #define bfin_read_PORTGIO_EDGE() bfin_read16(PORTGIO_EDGE)
  889. #define bfin_write_PORTGIO_EDGE(val) bfin_write16(PORTGIO_EDGE, val)
  890. #define bfin_read_PORTGIO_BOTH() bfin_read16(PORTGIO_BOTH)
  891. #define bfin_write_PORTGIO_BOTH(val) bfin_write16(PORTGIO_BOTH, val)
  892. #define bfin_read_PORTGIO_INEN() bfin_read16(PORTGIO_INEN)
  893. #define bfin_write_PORTGIO_INEN(val) bfin_write16(PORTGIO_INEN, val)
  894. /* General Purpose I/O Port H (0xFFC01700 - 0xFFC017FF) */
  895. #define bfin_read_PORTHIO() bfin_read16(PORTHIO)
  896. #define bfin_write_PORTHIO(val) bfin_write16(PORTHIO, val)
  897. #define bfin_read_PORTHIO_CLEAR() bfin_read16(PORTHIO_CLEAR)
  898. #define bfin_write_PORTHIO_CLEAR(val) bfin_write16(PORTHIO_CLEAR, val)
  899. #define bfin_read_PORTHIO_SET() bfin_read16(PORTHIO_SET)
  900. #define bfin_write_PORTHIO_SET(val) bfin_write16(PORTHIO_SET, val)
  901. #define bfin_read_PORTHIO_TOGGLE() bfin_read16(PORTHIO_TOGGLE)
  902. #define bfin_write_PORTHIO_TOGGLE(val) bfin_write16(PORTHIO_TOGGLE, val)
  903. #define bfin_read_PORTHIO_MASKA() bfin_read16(PORTHIO_MASKA)
  904. #define bfin_write_PORTHIO_MASKA(val) bfin_write16(PORTHIO_MASKA, val)
  905. #define bfin_read_PORTHIO_MASKA_CLEAR() bfin_read16(PORTHIO_MASKA_CLEAR)
  906. #define bfin_write_PORTHIO_MASKA_CLEAR(val) bfin_write16(PORTHIO_MASKA_CLEAR, val)
  907. #define bfin_read_PORTHIO_MASKA_SET() bfin_read16(PORTHIO_MASKA_SET)
  908. #define bfin_write_PORTHIO_MASKA_SET(val) bfin_write16(PORTHIO_MASKA_SET, val)
  909. #define bfin_read_PORTHIO_MASKA_TOGGLE() bfin_read16(PORTHIO_MASKA_TOGGLE)
  910. #define bfin_write_PORTHIO_MASKA_TOGGLE(val) bfin_write16(PORTHIO_MASKA_TOGGLE, val)
  911. #define bfin_read_PORTHIO_MASKB() bfin_read16(PORTHIO_MASKB)
  912. #define bfin_write_PORTHIO_MASKB(val) bfin_write16(PORTHIO_MASKB, val)
  913. #define bfin_read_PORTHIO_MASKB_CLEAR() bfin_read16(PORTHIO_MASKB_CLEAR)
  914. #define bfin_write_PORTHIO_MASKB_CLEAR(val) bfin_write16(PORTHIO_MASKB_CLEAR, val)
  915. #define bfin_read_PORTHIO_MASKB_SET() bfin_read16(PORTHIO_MASKB_SET)
  916. #define bfin_write_PORTHIO_MASKB_SET(val) bfin_write16(PORTHIO_MASKB_SET, val)
  917. #define bfin_read_PORTHIO_MASKB_TOGGLE() bfin_read16(PORTHIO_MASKB_TOGGLE)
  918. #define bfin_write_PORTHIO_MASKB_TOGGLE(val) bfin_write16(PORTHIO_MASKB_TOGGLE, val)
  919. #define bfin_read_PORTHIO_DIR() bfin_read16(PORTHIO_DIR)
  920. #define bfin_write_PORTHIO_DIR(val) bfin_write16(PORTHIO_DIR, val)
  921. #define bfin_read_PORTHIO_POLAR() bfin_read16(PORTHIO_POLAR)
  922. #define bfin_write_PORTHIO_POLAR(val) bfin_write16(PORTHIO_POLAR, val)
  923. #define bfin_read_PORTHIO_EDGE() bfin_read16(PORTHIO_EDGE)
  924. #define bfin_write_PORTHIO_EDGE(val) bfin_write16(PORTHIO_EDGE, val)
  925. #define bfin_read_PORTHIO_BOTH() bfin_read16(PORTHIO_BOTH)
  926. #define bfin_write_PORTHIO_BOTH(val) bfin_write16(PORTHIO_BOTH, val)
  927. #define bfin_read_PORTHIO_INEN() bfin_read16(PORTHIO_INEN)
  928. #define bfin_write_PORTHIO_INEN(val) bfin_write16(PORTHIO_INEN, val)
  929. /* UART1 Controller (0xFFC02000 - 0xFFC020FF) */
  930. #define bfin_read_UART1_THR() bfin_read16(UART1_THR)
  931. #define bfin_write_UART1_THR(val) bfin_write16(UART1_THR, val)
  932. #define bfin_read_UART1_RBR() bfin_read16(UART1_RBR)
  933. #define bfin_write_UART1_RBR(val) bfin_write16(UART1_RBR, val)
  934. #define bfin_read_UART1_DLL() bfin_read16(UART1_DLL)
  935. #define bfin_write_UART1_DLL(val) bfin_write16(UART1_DLL, val)
  936. #define bfin_read_UART1_IER() bfin_read16(UART1_IER)
  937. #define bfin_write_UART1_IER(val) bfin_write16(UART1_IER, val)
  938. #define bfin_read_UART1_DLH() bfin_read16(UART1_DLH)
  939. #define bfin_write_UART1_DLH(val) bfin_write16(UART1_DLH, val)
  940. #define bfin_read_UART1_IIR() bfin_read16(UART1_IIR)
  941. #define bfin_write_UART1_IIR(val) bfin_write16(UART1_IIR, val)
  942. #define bfin_read_UART1_LCR() bfin_read16(UART1_LCR)
  943. #define bfin_write_UART1_LCR(val) bfin_write16(UART1_LCR, val)
  944. #define bfin_read_UART1_MCR() bfin_read16(UART1_MCR)
  945. #define bfin_write_UART1_MCR(val) bfin_write16(UART1_MCR, val)
  946. #define bfin_read_UART1_LSR() bfin_read16(UART1_LSR)
  947. #define bfin_write_UART1_LSR(val) bfin_write16(UART1_LSR, val)
  948. #define bfin_read_UART1_MSR() bfin_read16(UART1_MSR)
  949. #define bfin_write_UART1_MSR(val) bfin_write16(UART1_MSR, val)
  950. #define bfin_read_UART1_SCR() bfin_read16(UART1_SCR)
  951. #define bfin_write_UART1_SCR(val) bfin_write16(UART1_SCR, val)
  952. #define bfin_read_UART1_GCTL() bfin_read16(UART1_GCTL)
  953. #define bfin_write_UART1_GCTL(val) bfin_write16(UART1_GCTL, val)
  954. /* Omit CAN register sets from the cdefBF534.h (CAN is not in the ADSP-BF52x processor) */
  955. /* Pin Control Registers (0xFFC03200 - 0xFFC032FF) */
  956. #define bfin_read_PORTF_FER() bfin_read16(PORTF_FER)
  957. #define bfin_write_PORTF_FER(val) bfin_write16(PORTF_FER, val)
  958. #define bfin_read_PORTG_FER() bfin_read16(PORTG_FER)
  959. #define bfin_write_PORTG_FER(val) bfin_write16(PORTG_FER, val)
  960. #define bfin_read_PORTH_FER() bfin_read16(PORTH_FER)
  961. #define bfin_write_PORTH_FER(val) bfin_write16(PORTH_FER, val)
  962. #define bfin_read_PORT_MUX() bfin_read16(PORT_MUX)
  963. #define bfin_write_PORT_MUX(val) bfin_write16(PORT_MUX, val)
  964. /* Handshake MDMA Registers (0xFFC03300 - 0xFFC033FF) */
  965. #define bfin_read_HMDMA0_CONTROL() bfin_read16(HMDMA0_CONTROL)
  966. #define bfin_write_HMDMA0_CONTROL(val) bfin_write16(HMDMA0_CONTROL, val)
  967. #define bfin_read_HMDMA0_ECINIT() bfin_read16(HMDMA0_ECINIT)
  968. #define bfin_write_HMDMA0_ECINIT(val) bfin_write16(HMDMA0_ECINIT, val)
  969. #define bfin_read_HMDMA0_BCINIT() bfin_read16(HMDMA0_BCINIT)
  970. #define bfin_write_HMDMA0_BCINIT(val) bfin_write16(HMDMA0_BCINIT, val)
  971. #define bfin_read_HMDMA0_ECURGENT() bfin_read16(HMDMA0_ECURGENT)
  972. #define bfin_write_HMDMA0_ECURGENT(val) bfin_write16(HMDMA0_ECURGENT, val)
  973. #define bfin_read_HMDMA0_ECOVERFLOW() bfin_read16(HMDMA0_ECOVERFLOW)
  974. #define bfin_write_HMDMA0_ECOVERFLOW(val) bfin_write16(HMDMA0_ECOVERFLOW, val)
  975. #define bfin_read_HMDMA0_ECOUNT() bfin_read16(HMDMA0_ECOUNT)
  976. #define bfin_write_HMDMA0_ECOUNT(val) bfin_write16(HMDMA0_ECOUNT, val)
  977. #define bfin_read_HMDMA0_BCOUNT() bfin_read16(HMDMA0_BCOUNT)
  978. #define bfin_write_HMDMA0_BCOUNT(val) bfin_write16(HMDMA0_BCOUNT, val)
  979. #define bfin_read_HMDMA1_CONTROL() bfin_read16(HMDMA1_CONTROL)
  980. #define bfin_write_HMDMA1_CONTROL(val) bfin_write16(HMDMA1_CONTROL, val)
  981. #define bfin_read_HMDMA1_ECINIT() bfin_read16(HMDMA1_ECINIT)
  982. #define bfin_write_HMDMA1_ECINIT(val) bfin_write16(HMDMA1_ECINIT, val)
  983. #define bfin_read_HMDMA1_BCINIT() bfin_read16(HMDMA1_BCINIT)
  984. #define bfin_write_HMDMA1_BCINIT(val) bfin_write16(HMDMA1_BCINIT, val)
  985. #define bfin_read_HMDMA1_ECURGENT() bfin_read16(HMDMA1_ECURGENT)
  986. #define bfin_write_HMDMA1_ECURGENT(val) bfin_write16(HMDMA1_ECURGENT, val)
  987. #define bfin_read_HMDMA1_ECOVERFLOW() bfin_read16(HMDMA1_ECOVERFLOW)
  988. #define bfin_write_HMDMA1_ECOVERFLOW(val) bfin_write16(HMDMA1_ECOVERFLOW, val)
  989. #define bfin_read_HMDMA1_ECOUNT() bfin_read16(HMDMA1_ECOUNT)
  990. #define bfin_write_HMDMA1_ECOUNT(val) bfin_write16(HMDMA1_ECOUNT, val)
  991. #define bfin_read_HMDMA1_BCOUNT() bfin_read16(HMDMA1_BCOUNT)
  992. #define bfin_write_HMDMA1_BCOUNT(val) bfin_write16(HMDMA1_BCOUNT, val)
  993. /* ==== end from cdefBF534.h ==== */
  994. /* GPIO PIN mux (0xFFC03210 - OxFFC03288) */
  995. #define bfin_read_PORTF_MUX() bfin_read16(PORTF_MUX)
  996. #define bfin_write_PORTF_MUX(val) bfin_write16(PORTF_MUX, val)
  997. #define bfin_read_PORTG_MUX() bfin_read16(PORTG_MUX)
  998. #define bfin_write_PORTG_MUX(val) bfin_write16(PORTG_MUX, val)
  999. #define bfin_read_PORTH_MUX() bfin_read16(PORTH_MUX)
  1000. #define bfin_write_PORTH_MUX(val) bfin_write16(PORTH_MUX, val)
  1001. #define bfin_read_PORTF_DRIVE() bfin_read16(PORTF_DRIVE)
  1002. #define bfin_write_PORTF_DRIVE(val) bfin_write16(PORTF_DRIVE, val)
  1003. #define bfin_read_PORTG_DRIVE() bfin_read16(PORTG_DRIVE)
  1004. #define bfin_write_PORTG_DRIVE(val) bfin_write16(PORTG_DRIVE, val)
  1005. #define bfin_read_PORTH_DRIVE() bfin_read16(PORTH_DRIVE)
  1006. #define bfin_write_PORTH_DRIVE(val) bfin_write16(PORTH_DRIVE, val)
  1007. #define bfin_read_PORTF_SLEW() bfin_read16(PORTF_SLEW)
  1008. #define bfin_write_PORTF_SLEW(val) bfin_write16(PORTF_SLEW, val)
  1009. #define bfin_read_PORTG_SLEW() bfin_read16(PORTG_SLEW)
  1010. #define bfin_write_PORTG_SLEW(val) bfin_write16(PORTG_SLEW, val)
  1011. #define bfin_read_PORTH_SLEW() bfin_read16(PORTH_SLEW)
  1012. #define bfin_write_PORTH_SLEW(val) bfin_write16(PORTH_SLEW, val)
  1013. #define bfin_read_PORTF_HYSTERISIS() bfin_read16(PORTF_HYSTERISIS)
  1014. #define bfin_write_PORTF_HYSTERISIS(val) bfin_write16(PORTF_HYSTERISIS, val)
  1015. #define bfin_read_PORTG_HYSTERISIS() bfin_read16(PORTG_HYSTERISIS)
  1016. #define bfin_write_PORTG_HYSTERISIS(val) bfin_write16(PORTG_HYSTERISIS, val)
  1017. #define bfin_read_PORTH_HYSTERISIS() bfin_read16(PORTH_HYSTERISIS)
  1018. #define bfin_write_PORTH_HYSTERISIS(val) bfin_write16(PORTH_HYSTERISIS, val)
  1019. #define bfin_read_MISCPORT_DRIVE() bfin_read16(MISCPORT_DRIVE)
  1020. #define bfin_write_MISCPORT_DRIVE(val) bfin_write16(MISCPORT_DRIVE, val)
  1021. #define bfin_read_MISCPORT_SLEW() bfin_read16(MISCPORT_SLEW)
  1022. #define bfin_write_MISCPORT_SLEW(val) bfin_write16(MISCPORT_SLEW, val)
  1023. #define bfin_read_MISCPORT_HYSTERISIS() bfin_read16(MISCPORT_HYSTERISIS)
  1024. #define bfin_write_MISCPORT_HYSTERISIS(val) bfin_write16(MISCPORT_HYSTERISIS, val)
  1025. /* HOST Port Registers */
  1026. #define bfin_read_HOST_CONTROL() bfin_read16(HOST_CONTROL)
  1027. #define bfin_write_HOST_CONTROL(val) bfin_write16(HOST_CONTROL, val)
  1028. #define bfin_read_HOST_STATUS() bfin_read16(HOST_STATUS)
  1029. #define bfin_write_HOST_STATUS(val) bfin_write16(HOST_STATUS, val)
  1030. #define bfin_read_HOST_TIMEOUT() bfin_read16(HOST_TIMEOUT)
  1031. #define bfin_write_HOST_TIMEOUT(val) bfin_write16(HOST_TIMEOUT, val)
  1032. /* Counter Registers */
  1033. #define bfin_read_CNT_CONFIG() bfin_read16(CNT_CONFIG)
  1034. #define bfin_write_CNT_CONFIG(val) bfin_write16(CNT_CONFIG, val)
  1035. #define bfin_read_CNT_IMASK() bfin_read16(CNT_IMASK)
  1036. #define bfin_write_CNT_IMASK(val) bfin_write16(CNT_IMASK, val)
  1037. #define bfin_read_CNT_STATUS() bfin_read16(CNT_STATUS)
  1038. #define bfin_write_CNT_STATUS(val) bfin_write16(CNT_STATUS, val)
  1039. #define bfin_read_CNT_COMMAND() bfin_read16(CNT_COMMAND)
  1040. #define bfin_write_CNT_COMMAND(val) bfin_write16(CNT_COMMAND, val)
  1041. #define bfin_read_CNT_DEBOUNCE() bfin_read16(CNT_DEBOUNCE)
  1042. #define bfin_write_CNT_DEBOUNCE(val) bfin_write16(CNT_DEBOUNCE, val)
  1043. #define bfin_read_CNT_COUNTER() bfin_read32(CNT_COUNTER)
  1044. #define bfin_write_CNT_COUNTER(val) bfin_write32(CNT_COUNTER, val)
  1045. #define bfin_read_CNT_MAX() bfin_read32(CNT_MAX)
  1046. #define bfin_write_CNT_MAX(val) bfin_write32(CNT_MAX, val)
  1047. #define bfin_read_CNT_MIN() bfin_read32(CNT_MIN)
  1048. #define bfin_write_CNT_MIN(val) bfin_write32(CNT_MIN, val)
  1049. /* OTP/FUSE Registers */
  1050. #define bfin_read_OTP_CONTROL() bfin_read16(OTP_CONTROL)
  1051. #define bfin_write_OTP_CONTROL(val) bfin_write16(OTP_CONTROL, val)
  1052. #define bfin_read_OTP_BEN() bfin_read16(OTP_BEN)
  1053. #define bfin_write_OTP_BEN(val) bfin_write16(OTP_BEN, val)
  1054. #define bfin_read_OTP_STATUS() bfin_read16(OTP_STATUS)
  1055. #define bfin_write_OTP_STATUS(val) bfin_write16(OTP_STATUS, val)
  1056. #define bfin_read_OTP_TIMING() bfin_read32(OTP_TIMING)
  1057. #define bfin_write_OTP_TIMING(val) bfin_write32(OTP_TIMING, val)
  1058. /* Security Registers */
  1059. #define bfin_read_SECURE_SYSSWT() bfin_read32(SECURE_SYSSWT)
  1060. #define bfin_write_SECURE_SYSSWT(val) bfin_write32(SECURE_SYSSWT, val)
  1061. #define bfin_read_SECURE_CONTROL() bfin_read16(SECURE_CONTROL)
  1062. #define bfin_write_SECURE_CONTROL(val) bfin_write16(SECURE_CONTROL, val)
  1063. #define bfin_read_SECURE_STATUS() bfin_read16(SECURE_STATUS)
  1064. #define bfin_write_SECURE_STATUS(val) bfin_write16(SECURE_STATUS, val)
  1065. /* OTP Read/Write Data Buffer Registers */
  1066. #define bfin_read_OTP_DATA0() bfin_read32(OTP_DATA0)
  1067. #define bfin_write_OTP_DATA0(val) bfin_write32(OTP_DATA0, val)
  1068. #define bfin_read_OTP_DATA1() bfin_read32(OTP_DATA1)
  1069. #define bfin_write_OTP_DATA1(val) bfin_write32(OTP_DATA1, val)
  1070. #define bfin_read_OTP_DATA2() bfin_read32(OTP_DATA2)
  1071. #define bfin_write_OTP_DATA2(val) bfin_write32(OTP_DATA2, val)
  1072. #define bfin_read_OTP_DATA3() bfin_read32(OTP_DATA3)
  1073. #define bfin_write_OTP_DATA3(val) bfin_write32(OTP_DATA3, val)
  1074. /* NFC Registers */
  1075. #define bfin_read_NFC_CTL() bfin_read16(NFC_CTL)
  1076. #define bfin_write_NFC_CTL(val) bfin_write16(NFC_CTL, val)
  1077. #define bfin_read_NFC_STAT() bfin_read16(NFC_STAT)
  1078. #define bfin_write_NFC_STAT(val) bfin_write16(NFC_STAT, val)
  1079. #define bfin_read_NFC_IRQSTAT() bfin_read16(NFC_IRQSTAT)
  1080. #define bfin_write_NFC_IRQSTAT(val) bfin_write16(NFC_IRQSTAT, val)
  1081. #define bfin_read_NFC_IRQMASK() bfin_read16(NFC_IRQMASK)
  1082. #define bfin_write_NFC_IRQMASK(val) bfin_write16(NFC_IRQMASK, val)
  1083. #define bfin_read_NFC_ECC0() bfin_read16(NFC_ECC0)
  1084. #define bfin_write_NFC_ECC0(val) bfin_write16(NFC_ECC0, val)
  1085. #define bfin_read_NFC_ECC1() bfin_read16(NFC_ECC1)
  1086. #define bfin_write_NFC_ECC1(val) bfin_write16(NFC_ECC1, val)
  1087. #define bfin_read_NFC_ECC2() bfin_read16(NFC_ECC2)
  1088. #define bfin_write_NFC_ECC2(val) bfin_write16(NFC_ECC2, val)
  1089. #define bfin_read_NFC_ECC3() bfin_read16(NFC_ECC3)
  1090. #define bfin_write_NFC_ECC3(val) bfin_write16(NFC_ECC3, val)
  1091. #define bfin_read_NFC_COUNT() bfin_read16(NFC_COUNT)
  1092. #define bfin_write_NFC_COUNT(val) bfin_write16(NFC_COUNT, val)
  1093. #define bfin_read_NFC_RST() bfin_read16(NFC_RST)
  1094. #define bfin_write_NFC_RST(val) bfin_write16(NFC_RST, val)
  1095. #define bfin_read_NFC_PGCTL() bfin_read16(NFC_PGCTL)
  1096. #define bfin_write_NFC_PGCTL(val) bfin_write16(NFC_PGCTL, val)
  1097. #define bfin_read_NFC_READ() bfin_read16(NFC_READ)
  1098. #define bfin_write_NFC_READ(val) bfin_write16(NFC_READ, val)
  1099. #define bfin_read_NFC_ADDR() bfin_read16(NFC_ADDR)
  1100. #define bfin_write_NFC_ADDR(val) bfin_write16(NFC_ADDR, val)
  1101. #define bfin_read_NFC_CMD() bfin_read16(NFC_CMD)
  1102. #define bfin_write_NFC_CMD(val) bfin_write16(NFC_CMD, val)
  1103. #define bfin_read_NFC_DATA_WR() bfin_read16(NFC_DATA_WR)
  1104. #define bfin_write_NFC_DATA_WR(val) bfin_write16(NFC_DATA_WR, val)
  1105. #define bfin_read_NFC_DATA_RD() bfin_read16(NFC_DATA_RD)
  1106. #define bfin_write_NFC_DATA_RD(val) bfin_write16(NFC_DATA_RD, val)
  1107. #endif /* _CDEF_BF52X_H */