m53xxsim.h 54 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. /****************************************************************************/
  3. /*
  4. * m53xxsim.h -- ColdFire 5329 registers
  5. */
  6. /****************************************************************************/
  7. #ifndef m53xxsim_h
  8. #define m53xxsim_h
  9. /****************************************************************************/
  10. #define CPU_NAME "COLDFIRE(m53xx)"
  11. #define CPU_INSTR_PER_JIFFY 3
  12. #define MCF_BUSCLK (MCF_CLK / 3)
  13. #include <asm/m53xxacr.h>
  14. #define MCFINT_VECBASE 64
  15. #define MCFINT_UART0 26 /* Interrupt number for UART0 */
  16. #define MCFINT_UART1 27 /* Interrupt number for UART1 */
  17. #define MCFINT_UART2 28 /* Interrupt number for UART2 */
  18. #define MCFINT_I2C0 30 /* Interrupt number for I2C */
  19. #define MCFINT_QSPI 31 /* Interrupt number for QSPI */
  20. #define MCFINT_FECRX0 36 /* Interrupt number for FEC */
  21. #define MCFINT_FECTX0 40 /* Interrupt number for FEC */
  22. #define MCFINT_FECENTC0 42 /* Interrupt number for FEC */
  23. #define MCF_IRQ_UART0 (MCFINT_VECBASE + MCFINT_UART0)
  24. #define MCF_IRQ_UART1 (MCFINT_VECBASE + MCFINT_UART1)
  25. #define MCF_IRQ_UART2 (MCFINT_VECBASE + MCFINT_UART2)
  26. #define MCF_IRQ_FECRX0 (MCFINT_VECBASE + MCFINT_FECRX0)
  27. #define MCF_IRQ_FECTX0 (MCFINT_VECBASE + MCFINT_FECTX0)
  28. #define MCF_IRQ_FECENTC0 (MCFINT_VECBASE + MCFINT_FECENTC0)
  29. #define MCF_IRQ_I2C0 (MCFINT_VECBASE + MCFINT_I2C0)
  30. #define MCF_IRQ_QSPI (MCFINT_VECBASE + MCFINT_QSPI)
  31. #define MCF_WTM_WCR 0xFC098000
  32. /*
  33. * Define the 532x SIM register set addresses.
  34. */
  35. #define MCFSIM_IPRL 0xFC048004
  36. #define MCFSIM_IPRH 0xFC048000
  37. #define MCFSIM_IPR MCFSIM_IPRL
  38. #define MCFSIM_IMRL 0xFC04800C
  39. #define MCFSIM_IMRH 0xFC048008
  40. #define MCFSIM_IMR MCFSIM_IMRL
  41. #define MCFSIM_ICR0 0xFC048040
  42. #define MCFSIM_ICR1 0xFC048041
  43. #define MCFSIM_ICR2 0xFC048042
  44. #define MCFSIM_ICR3 0xFC048043
  45. #define MCFSIM_ICR4 0xFC048044
  46. #define MCFSIM_ICR5 0xFC048045
  47. #define MCFSIM_ICR6 0xFC048046
  48. #define MCFSIM_ICR7 0xFC048047
  49. #define MCFSIM_ICR8 0xFC048048
  50. #define MCFSIM_ICR9 0xFC048049
  51. #define MCFSIM_ICR10 0xFC04804A
  52. #define MCFSIM_ICR11 0xFC04804B
  53. /*
  54. * Some symbol defines for the above...
  55. */
  56. #define MCFSIM_SWDICR MCFSIM_ICR0 /* Watchdog timer ICR */
  57. #define MCFSIM_TIMER1ICR MCFSIM_ICR1 /* Timer 1 ICR */
  58. #define MCFSIM_TIMER2ICR MCFSIM_ICR2 /* Timer 2 ICR */
  59. #define MCFSIM_UART1ICR MCFSIM_ICR4 /* UART 1 ICR */
  60. #define MCFSIM_UART2ICR MCFSIM_ICR5 /* UART 2 ICR */
  61. #define MCFSIM_DMA0ICR MCFSIM_ICR6 /* DMA 0 ICR */
  62. #define MCFSIM_DMA1ICR MCFSIM_ICR7 /* DMA 1 ICR */
  63. #define MCFSIM_DMA2ICR MCFSIM_ICR8 /* DMA 2 ICR */
  64. #define MCFSIM_DMA3ICR MCFSIM_ICR9 /* DMA 3 ICR */
  65. #define MCFINTC0_SIMR 0xFC04801C
  66. #define MCFINTC0_CIMR 0xFC04801D
  67. #define MCFINTC0_ICR0 0xFC048040
  68. #define MCFINTC1_SIMR 0xFC04C01C
  69. #define MCFINTC1_CIMR 0xFC04C01D
  70. #define MCFINTC1_ICR0 0xFC04C040
  71. #define MCFINTC2_SIMR (0)
  72. #define MCFINTC2_CIMR (0)
  73. #define MCFINTC2_ICR0 (0)
  74. #define MCFSIM_ICR_TIMER1 (0xFC048040+32)
  75. #define MCFSIM_ICR_TIMER2 (0xFC048040+33)
  76. /*
  77. * Define system peripheral IRQ usage.
  78. */
  79. #define MCF_IRQ_TIMER (64 + 32) /* Timer0 */
  80. #define MCF_IRQ_PROFILER (64 + 33) /* Timer1 */
  81. /*
  82. * UART module.
  83. */
  84. #define MCFUART_BASE0 0xFC060000 /* Base address of UART1 */
  85. #define MCFUART_BASE1 0xFC064000 /* Base address of UART2 */
  86. #define MCFUART_BASE2 0xFC068000 /* Base address of UART3 */
  87. /*
  88. * FEC module.
  89. */
  90. #define MCFFEC_BASE0 0xFC030000 /* Base address of FEC0 */
  91. #define MCFFEC_SIZE0 0x800 /* Size of FEC0 region */
  92. /*
  93. * QSPI module.
  94. */
  95. #define MCFQSPI_BASE 0xFC05C000 /* Base address of QSPI */
  96. #define MCFQSPI_SIZE 0x40 /* Size of QSPI region */
  97. #define MCFQSPI_CS0 84
  98. #define MCFQSPI_CS1 85
  99. #define MCFQSPI_CS2 86
  100. /*
  101. * Timer module.
  102. */
  103. #define MCFTIMER_BASE1 0xFC070000 /* Base address of TIMER1 */
  104. #define MCFTIMER_BASE2 0xFC074000 /* Base address of TIMER2 */
  105. #define MCFTIMER_BASE3 0xFC078000 /* Base address of TIMER3 */
  106. #define MCFTIMER_BASE4 0xFC07C000 /* Base address of TIMER4 */
  107. /*********************************************************************
  108. *
  109. * Reset Controller Module
  110. *
  111. *********************************************************************/
  112. #define MCF_RCR 0xFC0A0000
  113. #define MCF_RSR 0xFC0A0001
  114. #define MCF_RCR_SWRESET 0x80 /* Software reset bit */
  115. #define MCF_RCR_FRCSTOUT 0x40 /* Force external reset */
  116. /*
  117. * Power Management
  118. */
  119. #define MCFPM_WCR 0xfc040013
  120. #define MCFPM_PPMSR0 0xfc04002c
  121. #define MCFPM_PPMCR0 0xfc04002d
  122. #define MCFPM_PPMSR1 0xfc04002e
  123. #define MCFPM_PPMCR1 0xfc04002f
  124. #define MCFPM_PPMHR0 0xfc040030
  125. #define MCFPM_PPMLR0 0xfc040034
  126. #define MCFPM_PPMHR1 0xfc040038
  127. #define MCFPM_LPCR 0xec090007
  128. /*
  129. * The M5329EVB board needs a help getting its devices initialized
  130. * at kernel start time if dBUG doesn't set it up (for example
  131. * it is not used), so we need to do it manually.
  132. */
  133. #ifdef __ASSEMBLER__
  134. .macro m5329EVB_setup
  135. movel #0xFC098000, %a7
  136. movel #0x0, (%a7)
  137. #define CORE_SRAM 0x80000000
  138. #define CORE_SRAM_SIZE 0x8000
  139. movel #CORE_SRAM, %d0
  140. addl #0x221, %d0
  141. movec %d0,%RAMBAR1
  142. movel #CORE_SRAM, %sp
  143. addl #CORE_SRAM_SIZE, %sp
  144. jsr sysinit
  145. .endm
  146. #define PLATFORM_SETUP m5329EVB_setup
  147. #endif /* __ASSEMBLER__ */
  148. /*********************************************************************
  149. *
  150. * Chip Configuration Module (CCM)
  151. *
  152. *********************************************************************/
  153. /* Register read/write macros */
  154. #define MCF_CCM_CCR 0xFC0A0004
  155. #define MCF_CCM_RCON 0xFC0A0008
  156. #define MCF_CCM_CIR 0xFC0A000A
  157. #define MCF_CCM_MISCCR 0xFC0A0010
  158. #define MCF_CCM_CDR 0xFC0A0012
  159. #define MCF_CCM_UHCSR 0xFC0A0014
  160. #define MCF_CCM_UOCSR 0xFC0A0016
  161. /* Bit definitions and macros for MCF_CCM_CCR */
  162. #define MCF_CCM_CCR_RESERVED (0x0001)
  163. #define MCF_CCM_CCR_PLL_MODE (0x0003)
  164. #define MCF_CCM_CCR_OSC_MODE (0x0005)
  165. #define MCF_CCM_CCR_BOOTPS(x) (((x)&0x0003)<<3|0x0001)
  166. #define MCF_CCM_CCR_LOAD (0x0021)
  167. #define MCF_CCM_CCR_LIMP (0x0041)
  168. #define MCF_CCM_CCR_CSC(x) (((x)&0x0003)<<8|0x0001)
  169. /* Bit definitions and macros for MCF_CCM_RCON */
  170. #define MCF_CCM_RCON_RESERVED (0x0001)
  171. #define MCF_CCM_RCON_PLL_MODE (0x0003)
  172. #define MCF_CCM_RCON_OSC_MODE (0x0005)
  173. #define MCF_CCM_RCON_BOOTPS(x) (((x)&0x0003)<<3|0x0001)
  174. #define MCF_CCM_RCON_LOAD (0x0021)
  175. #define MCF_CCM_RCON_LIMP (0x0041)
  176. #define MCF_CCM_RCON_CSC(x) (((x)&0x0003)<<8|0x0001)
  177. /* Bit definitions and macros for MCF_CCM_CIR */
  178. #define MCF_CCM_CIR_PRN(x) (((x)&0x003F)<<0)
  179. #define MCF_CCM_CIR_PIN(x) (((x)&0x03FF)<<6)
  180. /* Bit definitions and macros for MCF_CCM_MISCCR */
  181. #define MCF_CCM_MISCCR_USBSRC (0x0001)
  182. #define MCF_CCM_MISCCR_USBDIV (0x0002)
  183. #define MCF_CCM_MISCCR_SSI_SRC (0x0010)
  184. #define MCF_CCM_MISCCR_TIM_DMA (0x0020)
  185. #define MCF_CCM_MISCCR_SSI_PUS (0x0040)
  186. #define MCF_CCM_MISCCR_SSI_PUE (0x0080)
  187. #define MCF_CCM_MISCCR_LCD_CHEN (0x0100)
  188. #define MCF_CCM_MISCCR_LIMP (0x1000)
  189. #define MCF_CCM_MISCCR_PLL_LOCK (0x2000)
  190. /* Bit definitions and macros for MCF_CCM_CDR */
  191. #define MCF_CCM_CDR_SSIDIV(x) (((x)&0x000F)<<0)
  192. #define MCF_CCM_CDR_LPDIV(x) (((x)&0x000F)<<8)
  193. /* Bit definitions and macros for MCF_CCM_UHCSR */
  194. #define MCF_CCM_UHCSR_XPDE (0x0001)
  195. #define MCF_CCM_UHCSR_UHMIE (0x0002)
  196. #define MCF_CCM_UHCSR_WKUP (0x0004)
  197. #define MCF_CCM_UHCSR_PORTIND(x) (((x)&0x0003)<<14)
  198. /* Bit definitions and macros for MCF_CCM_UOCSR */
  199. #define MCF_CCM_UOCSR_XPDE (0x0001)
  200. #define MCF_CCM_UOCSR_UOMIE (0x0002)
  201. #define MCF_CCM_UOCSR_WKUP (0x0004)
  202. #define MCF_CCM_UOCSR_PWRFLT (0x0008)
  203. #define MCF_CCM_UOCSR_SEND (0x0010)
  204. #define MCF_CCM_UOCSR_VVLD (0x0020)
  205. #define MCF_CCM_UOCSR_BVLD (0x0040)
  206. #define MCF_CCM_UOCSR_AVLD (0x0080)
  207. #define MCF_CCM_UOCSR_DPPU (0x0100)
  208. #define MCF_CCM_UOCSR_DCR_VBUS (0x0200)
  209. #define MCF_CCM_UOCSR_CRG_VBUS (0x0400)
  210. #define MCF_CCM_UOCSR_DRV_VBUS (0x0800)
  211. #define MCF_CCM_UOCSR_DMPD (0x1000)
  212. #define MCF_CCM_UOCSR_DPPD (0x2000)
  213. #define MCF_CCM_UOCSR_PORTIND(x) (((x)&0x0003)<<14)
  214. /*********************************************************************
  215. *
  216. * FlexBus Chip Selects (FBCS)
  217. *
  218. *********************************************************************/
  219. /* Register read/write macros */
  220. #define MCF_FBCS0_CSAR 0xFC008000
  221. #define MCF_FBCS0_CSMR 0xFC008004
  222. #define MCF_FBCS0_CSCR 0xFC008008
  223. #define MCF_FBCS1_CSAR 0xFC00800C
  224. #define MCF_FBCS1_CSMR 0xFC008010
  225. #define MCF_FBCS1_CSCR 0xFC008014
  226. #define MCF_FBCS2_CSAR 0xFC008018
  227. #define MCF_FBCS2_CSMR 0xFC00801C
  228. #define MCF_FBCS2_CSCR 0xFC008020
  229. #define MCF_FBCS3_CSAR 0xFC008024
  230. #define MCF_FBCS3_CSMR 0xFC008028
  231. #define MCF_FBCS3_CSCR 0xFC00802C
  232. #define MCF_FBCS4_CSAR 0xFC008030
  233. #define MCF_FBCS4_CSMR 0xFC008034
  234. #define MCF_FBCS4_CSCR 0xFC008038
  235. #define MCF_FBCS5_CSAR 0xFC00803C
  236. #define MCF_FBCS5_CSMR 0xFC008040
  237. #define MCF_FBCS5_CSCR 0xFC008044
  238. /* Bit definitions and macros for MCF_FBCS_CSAR */
  239. #define MCF_FBCS_CSAR_BA(x) ((x)&0xFFFF0000)
  240. /* Bit definitions and macros for MCF_FBCS_CSMR */
  241. #define MCF_FBCS_CSMR_V (0x00000001)
  242. #define MCF_FBCS_CSMR_WP (0x00000100)
  243. #define MCF_FBCS_CSMR_BAM(x) (((x)&0x0000FFFF)<<16)
  244. #define MCF_FBCS_CSMR_BAM_4G (0xFFFF0000)
  245. #define MCF_FBCS_CSMR_BAM_2G (0x7FFF0000)
  246. #define MCF_FBCS_CSMR_BAM_1G (0x3FFF0000)
  247. #define MCF_FBCS_CSMR_BAM_1024M (0x3FFF0000)
  248. #define MCF_FBCS_CSMR_BAM_512M (0x1FFF0000)
  249. #define MCF_FBCS_CSMR_BAM_256M (0x0FFF0000)
  250. #define MCF_FBCS_CSMR_BAM_128M (0x07FF0000)
  251. #define MCF_FBCS_CSMR_BAM_64M (0x03FF0000)
  252. #define MCF_FBCS_CSMR_BAM_32M (0x01FF0000)
  253. #define MCF_FBCS_CSMR_BAM_16M (0x00FF0000)
  254. #define MCF_FBCS_CSMR_BAM_8M (0x007F0000)
  255. #define MCF_FBCS_CSMR_BAM_4M (0x003F0000)
  256. #define MCF_FBCS_CSMR_BAM_2M (0x001F0000)
  257. #define MCF_FBCS_CSMR_BAM_1M (0x000F0000)
  258. #define MCF_FBCS_CSMR_BAM_1024K (0x000F0000)
  259. #define MCF_FBCS_CSMR_BAM_512K (0x00070000)
  260. #define MCF_FBCS_CSMR_BAM_256K (0x00030000)
  261. #define MCF_FBCS_CSMR_BAM_128K (0x00010000)
  262. #define MCF_FBCS_CSMR_BAM_64K (0x00000000)
  263. /* Bit definitions and macros for MCF_FBCS_CSCR */
  264. #define MCF_FBCS_CSCR_BSTW (0x00000008)
  265. #define MCF_FBCS_CSCR_BSTR (0x00000010)
  266. #define MCF_FBCS_CSCR_BEM (0x00000020)
  267. #define MCF_FBCS_CSCR_PS(x) (((x)&0x00000003)<<6)
  268. #define MCF_FBCS_CSCR_AA (0x00000100)
  269. #define MCF_FBCS_CSCR_SBM (0x00000200)
  270. #define MCF_FBCS_CSCR_WS(x) (((x)&0x0000003F)<<10)
  271. #define MCF_FBCS_CSCR_WRAH(x) (((x)&0x00000003)<<16)
  272. #define MCF_FBCS_CSCR_RDAH(x) (((x)&0x00000003)<<18)
  273. #define MCF_FBCS_CSCR_ASET(x) (((x)&0x00000003)<<20)
  274. #define MCF_FBCS_CSCR_SWSEN (0x00800000)
  275. #define MCF_FBCS_CSCR_SWS(x) (((x)&0x0000003F)<<26)
  276. #define MCF_FBCS_CSCR_PS_8 (0x0040)
  277. #define MCF_FBCS_CSCR_PS_16 (0x0080)
  278. #define MCF_FBCS_CSCR_PS_32 (0x0000)
  279. /*********************************************************************
  280. *
  281. * General Purpose I/O (GPIO)
  282. *
  283. *********************************************************************/
  284. /* Register read/write macros */
  285. #define MCFGPIO_PODR_FECH (0xFC0A4000)
  286. #define MCFGPIO_PODR_FECL (0xFC0A4001)
  287. #define MCFGPIO_PODR_SSI (0xFC0A4002)
  288. #define MCFGPIO_PODR_BUSCTL (0xFC0A4003)
  289. #define MCFGPIO_PODR_BE (0xFC0A4004)
  290. #define MCFGPIO_PODR_CS (0xFC0A4005)
  291. #define MCFGPIO_PODR_PWM (0xFC0A4006)
  292. #define MCFGPIO_PODR_FECI2C (0xFC0A4007)
  293. #define MCFGPIO_PODR_UART (0xFC0A4009)
  294. #define MCFGPIO_PODR_QSPI (0xFC0A400A)
  295. #define MCFGPIO_PODR_TIMER (0xFC0A400B)
  296. #define MCFGPIO_PODR_LCDDATAH (0xFC0A400D)
  297. #define MCFGPIO_PODR_LCDDATAM (0xFC0A400E)
  298. #define MCFGPIO_PODR_LCDDATAL (0xFC0A400F)
  299. #define MCFGPIO_PODR_LCDCTLH (0xFC0A4010)
  300. #define MCFGPIO_PODR_LCDCTLL (0xFC0A4011)
  301. #define MCFGPIO_PDDR_FECH (0xFC0A4014)
  302. #define MCFGPIO_PDDR_FECL (0xFC0A4015)
  303. #define MCFGPIO_PDDR_SSI (0xFC0A4016)
  304. #define MCFGPIO_PDDR_BUSCTL (0xFC0A4017)
  305. #define MCFGPIO_PDDR_BE (0xFC0A4018)
  306. #define MCFGPIO_PDDR_CS (0xFC0A4019)
  307. #define MCFGPIO_PDDR_PWM (0xFC0A401A)
  308. #define MCFGPIO_PDDR_FECI2C (0xFC0A401B)
  309. #define MCFGPIO_PDDR_UART (0xFC0A401C)
  310. #define MCFGPIO_PDDR_QSPI (0xFC0A401E)
  311. #define MCFGPIO_PDDR_TIMER (0xFC0A401F)
  312. #define MCFGPIO_PDDR_LCDDATAH (0xFC0A4021)
  313. #define MCFGPIO_PDDR_LCDDATAM (0xFC0A4022)
  314. #define MCFGPIO_PDDR_LCDDATAL (0xFC0A4023)
  315. #define MCFGPIO_PDDR_LCDCTLH (0xFC0A4024)
  316. #define MCFGPIO_PDDR_LCDCTLL (0xFC0A4025)
  317. #define MCFGPIO_PPDSDR_FECH (0xFC0A4028)
  318. #define MCFGPIO_PPDSDR_FECL (0xFC0A4029)
  319. #define MCFGPIO_PPDSDR_SSI (0xFC0A402A)
  320. #define MCFGPIO_PPDSDR_BUSCTL (0xFC0A402B)
  321. #define MCFGPIO_PPDSDR_BE (0xFC0A402C)
  322. #define MCFGPIO_PPDSDR_CS (0xFC0A402D)
  323. #define MCFGPIO_PPDSDR_PWM (0xFC0A402E)
  324. #define MCFGPIO_PPDSDR_FECI2C (0xFC0A402F)
  325. #define MCFGPIO_PPDSDR_UART (0xFC0A4031)
  326. #define MCFGPIO_PPDSDR_QSPI (0xFC0A4032)
  327. #define MCFGPIO_PPDSDR_TIMER (0xFC0A4033)
  328. #define MCFGPIO_PPDSDR_LCDDATAH (0xFC0A4035)
  329. #define MCFGPIO_PPDSDR_LCDDATAM (0xFC0A4036)
  330. #define MCFGPIO_PPDSDR_LCDDATAL (0xFC0A4037)
  331. #define MCFGPIO_PPDSDR_LCDCTLH (0xFC0A4038)
  332. #define MCFGPIO_PPDSDR_LCDCTLL (0xFC0A4039)
  333. #define MCFGPIO_PCLRR_FECH (0xFC0A403C)
  334. #define MCFGPIO_PCLRR_FECL (0xFC0A403D)
  335. #define MCFGPIO_PCLRR_SSI (0xFC0A403E)
  336. #define MCFGPIO_PCLRR_BUSCTL (0xFC0A403F)
  337. #define MCFGPIO_PCLRR_BE (0xFC0A4040)
  338. #define MCFGPIO_PCLRR_CS (0xFC0A4041)
  339. #define MCFGPIO_PCLRR_PWM (0xFC0A4042)
  340. #define MCFGPIO_PCLRR_FECI2C (0xFC0A4043)
  341. #define MCFGPIO_PCLRR_UART (0xFC0A4045)
  342. #define MCFGPIO_PCLRR_QSPI (0xFC0A4046)
  343. #define MCFGPIO_PCLRR_TIMER (0xFC0A4047)
  344. #define MCFGPIO_PCLRR_LCDDATAH (0xFC0A4049)
  345. #define MCFGPIO_PCLRR_LCDDATAM (0xFC0A404A)
  346. #define MCFGPIO_PCLRR_LCDDATAL (0xFC0A404B)
  347. #define MCFGPIO_PCLRR_LCDCTLH (0xFC0A404C)
  348. #define MCFGPIO_PCLRR_LCDCTLL (0xFC0A404D)
  349. #define MCFGPIO_PAR_FEC (0xFC0A4050)
  350. #define MCFGPIO_PAR_PWM (0xFC0A4051)
  351. #define MCFGPIO_PAR_BUSCTL (0xFC0A4052)
  352. #define MCFGPIO_PAR_FECI2C (0xFC0A4053)
  353. #define MCFGPIO_PAR_BE (0xFC0A4054)
  354. #define MCFGPIO_PAR_CS (0xFC0A4055)
  355. #define MCFGPIO_PAR_SSI (0xFC0A4056)
  356. #define MCFGPIO_PAR_UART (0xFC0A4058)
  357. #define MCFGPIO_PAR_QSPI (0xFC0A405A)
  358. #define MCFGPIO_PAR_TIMER (0xFC0A405C)
  359. #define MCFGPIO_PAR_LCDDATA (0xFC0A405D)
  360. #define MCFGPIO_PAR_LCDCTL (0xFC0A405E)
  361. #define MCFGPIO_PAR_IRQ (0xFC0A4060)
  362. #define MCFGPIO_MSCR_FLEXBUS (0xFC0A4064)
  363. #define MCFGPIO_MSCR_SDRAM (0xFC0A4065)
  364. #define MCFGPIO_DSCR_I2C (0xFC0A4068)
  365. #define MCFGPIO_DSCR_PWM (0xFC0A4069)
  366. #define MCFGPIO_DSCR_FEC (0xFC0A406A)
  367. #define MCFGPIO_DSCR_UART (0xFC0A406B)
  368. #define MCFGPIO_DSCR_QSPI (0xFC0A406C)
  369. #define MCFGPIO_DSCR_TIMER (0xFC0A406D)
  370. #define MCFGPIO_DSCR_SSI (0xFC0A406E)
  371. #define MCFGPIO_DSCR_LCD (0xFC0A406F)
  372. #define MCFGPIO_DSCR_DEBUG (0xFC0A4070)
  373. #define MCFGPIO_DSCR_CLKRST (0xFC0A4071)
  374. #define MCFGPIO_DSCR_IRQ (0xFC0A4072)
  375. /* Bit definitions and macros for MCF_GPIO_PODR_FECH */
  376. #define MCF_GPIO_PODR_FECH_PODR_FECH0 (0x01)
  377. #define MCF_GPIO_PODR_FECH_PODR_FECH1 (0x02)
  378. #define MCF_GPIO_PODR_FECH_PODR_FECH2 (0x04)
  379. #define MCF_GPIO_PODR_FECH_PODR_FECH3 (0x08)
  380. #define MCF_GPIO_PODR_FECH_PODR_FECH4 (0x10)
  381. #define MCF_GPIO_PODR_FECH_PODR_FECH5 (0x20)
  382. #define MCF_GPIO_PODR_FECH_PODR_FECH6 (0x40)
  383. #define MCF_GPIO_PODR_FECH_PODR_FECH7 (0x80)
  384. /* Bit definitions and macros for MCF_GPIO_PODR_FECL */
  385. #define MCF_GPIO_PODR_FECL_PODR_FECL0 (0x01)
  386. #define MCF_GPIO_PODR_FECL_PODR_FECL1 (0x02)
  387. #define MCF_GPIO_PODR_FECL_PODR_FECL2 (0x04)
  388. #define MCF_GPIO_PODR_FECL_PODR_FECL3 (0x08)
  389. #define MCF_GPIO_PODR_FECL_PODR_FECL4 (0x10)
  390. #define MCF_GPIO_PODR_FECL_PODR_FECL5 (0x20)
  391. #define MCF_GPIO_PODR_FECL_PODR_FECL6 (0x40)
  392. #define MCF_GPIO_PODR_FECL_PODR_FECL7 (0x80)
  393. /* Bit definitions and macros for MCF_GPIO_PODR_SSI */
  394. #define MCF_GPIO_PODR_SSI_PODR_SSI0 (0x01)
  395. #define MCF_GPIO_PODR_SSI_PODR_SSI1 (0x02)
  396. #define MCF_GPIO_PODR_SSI_PODR_SSI2 (0x04)
  397. #define MCF_GPIO_PODR_SSI_PODR_SSI3 (0x08)
  398. #define MCF_GPIO_PODR_SSI_PODR_SSI4 (0x10)
  399. /* Bit definitions and macros for MCF_GPIO_PODR_BUSCTL */
  400. #define MCF_GPIO_PODR_BUSCTL_POSDR_BUSCTL0 (0x01)
  401. #define MCF_GPIO_PODR_BUSCTL_PODR_BUSCTL1 (0x02)
  402. #define MCF_GPIO_PODR_BUSCTL_PODR_BUSCTL2 (0x04)
  403. #define MCF_GPIO_PODR_BUSCTL_PODR_BUSCTL3 (0x08)
  404. /* Bit definitions and macros for MCF_GPIO_PODR_BE */
  405. #define MCF_GPIO_PODR_BE_PODR_BE0 (0x01)
  406. #define MCF_GPIO_PODR_BE_PODR_BE1 (0x02)
  407. #define MCF_GPIO_PODR_BE_PODR_BE2 (0x04)
  408. #define MCF_GPIO_PODR_BE_PODR_BE3 (0x08)
  409. /* Bit definitions and macros for MCF_GPIO_PODR_CS */
  410. #define MCF_GPIO_PODR_CS_PODR_CS1 (0x02)
  411. #define MCF_GPIO_PODR_CS_PODR_CS2 (0x04)
  412. #define MCF_GPIO_PODR_CS_PODR_CS3 (0x08)
  413. #define MCF_GPIO_PODR_CS_PODR_CS4 (0x10)
  414. #define MCF_GPIO_PODR_CS_PODR_CS5 (0x20)
  415. /* Bit definitions and macros for MCF_GPIO_PODR_PWM */
  416. #define MCF_GPIO_PODR_PWM_PODR_PWM2 (0x04)
  417. #define MCF_GPIO_PODR_PWM_PODR_PWM3 (0x08)
  418. #define MCF_GPIO_PODR_PWM_PODR_PWM4 (0x10)
  419. #define MCF_GPIO_PODR_PWM_PODR_PWM5 (0x20)
  420. /* Bit definitions and macros for MCF_GPIO_PODR_FECI2C */
  421. #define MCF_GPIO_PODR_FECI2C_PODR_FECI2C0 (0x01)
  422. #define MCF_GPIO_PODR_FECI2C_PODR_FECI2C1 (0x02)
  423. #define MCF_GPIO_PODR_FECI2C_PODR_FECI2C2 (0x04)
  424. #define MCF_GPIO_PODR_FECI2C_PODR_FECI2C3 (0x08)
  425. /* Bit definitions and macros for MCF_GPIO_PODR_UART */
  426. #define MCF_GPIO_PODR_UART_PODR_UART0 (0x01)
  427. #define MCF_GPIO_PODR_UART_PODR_UART1 (0x02)
  428. #define MCF_GPIO_PODR_UART_PODR_UART2 (0x04)
  429. #define MCF_GPIO_PODR_UART_PODR_UART3 (0x08)
  430. #define MCF_GPIO_PODR_UART_PODR_UART4 (0x10)
  431. #define MCF_GPIO_PODR_UART_PODR_UART5 (0x20)
  432. #define MCF_GPIO_PODR_UART_PODR_UART6 (0x40)
  433. #define MCF_GPIO_PODR_UART_PODR_UART7 (0x80)
  434. /* Bit definitions and macros for MCF_GPIO_PODR_QSPI */
  435. #define MCF_GPIO_PODR_QSPI_PODR_QSPI0 (0x01)
  436. #define MCF_GPIO_PODR_QSPI_PODR_QSPI1 (0x02)
  437. #define MCF_GPIO_PODR_QSPI_PODR_QSPI2 (0x04)
  438. #define MCF_GPIO_PODR_QSPI_PODR_QSPI3 (0x08)
  439. #define MCF_GPIO_PODR_QSPI_PODR_QSPI4 (0x10)
  440. #define MCF_GPIO_PODR_QSPI_PODR_QSPI5 (0x20)
  441. /* Bit definitions and macros for MCF_GPIO_PODR_TIMER */
  442. #define MCF_GPIO_PODR_TIMER_PODR_TIMER0 (0x01)
  443. #define MCF_GPIO_PODR_TIMER_PODR_TIMER1 (0x02)
  444. #define MCF_GPIO_PODR_TIMER_PODR_TIMER2 (0x04)
  445. #define MCF_GPIO_PODR_TIMER_PODR_TIMER3 (0x08)
  446. /* Bit definitions and macros for MCF_GPIO_PODR_LCDDATAH */
  447. #define MCF_GPIO_PODR_LCDDATAH_PODR_LCDDATAH0 (0x01)
  448. #define MCF_GPIO_PODR_LCDDATAH_PODR_LCDDATAH1 (0x02)
  449. /* Bit definitions and macros for MCF_GPIO_PODR_LCDDATAM */
  450. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM0 (0x01)
  451. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM1 (0x02)
  452. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM2 (0x04)
  453. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM3 (0x08)
  454. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM4 (0x10)
  455. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM5 (0x20)
  456. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM6 (0x40)
  457. #define MCF_GPIO_PODR_LCDDATAM_PODR_LCDDATAM7 (0x80)
  458. /* Bit definitions and macros for MCF_GPIO_PODR_LCDDATAL */
  459. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL0 (0x01)
  460. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL1 (0x02)
  461. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL2 (0x04)
  462. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL3 (0x08)
  463. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL4 (0x10)
  464. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL5 (0x20)
  465. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL6 (0x40)
  466. #define MCF_GPIO_PODR_LCDDATAL_PODR_LCDDATAL7 (0x80)
  467. /* Bit definitions and macros for MCF_GPIO_PODR_LCDCTLH */
  468. #define MCF_GPIO_PODR_LCDCTLH_PODR_LCDCTLH0 (0x01)
  469. /* Bit definitions and macros for MCF_GPIO_PODR_LCDCTLL */
  470. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL0 (0x01)
  471. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL1 (0x02)
  472. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL2 (0x04)
  473. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL3 (0x08)
  474. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL4 (0x10)
  475. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL5 (0x20)
  476. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL6 (0x40)
  477. #define MCF_GPIO_PODR_LCDCTLL_PODR_LCDCTLL7 (0x80)
  478. /* Bit definitions and macros for MCF_GPIO_PDDR_FECH */
  479. #define MCF_GPIO_PDDR_FECH_PDDR_FECH0 (0x01)
  480. #define MCF_GPIO_PDDR_FECH_PDDR_FECH1 (0x02)
  481. #define MCF_GPIO_PDDR_FECH_PDDR_FECH2 (0x04)
  482. #define MCF_GPIO_PDDR_FECH_PDDR_FECH3 (0x08)
  483. #define MCF_GPIO_PDDR_FECH_PDDR_FECH4 (0x10)
  484. #define MCF_GPIO_PDDR_FECH_PDDR_FECH5 (0x20)
  485. #define MCF_GPIO_PDDR_FECH_PDDR_FECH6 (0x40)
  486. #define MCF_GPIO_PDDR_FECH_PDDR_FECH7 (0x80)
  487. /* Bit definitions and macros for MCF_GPIO_PDDR_FECL */
  488. #define MCF_GPIO_PDDR_FECL_PDDR_FECL0 (0x01)
  489. #define MCF_GPIO_PDDR_FECL_PDDR_FECL1 (0x02)
  490. #define MCF_GPIO_PDDR_FECL_PDDR_FECL2 (0x04)
  491. #define MCF_GPIO_PDDR_FECL_PDDR_FECL3 (0x08)
  492. #define MCF_GPIO_PDDR_FECL_PDDR_FECL4 (0x10)
  493. #define MCF_GPIO_PDDR_FECL_PDDR_FECL5 (0x20)
  494. #define MCF_GPIO_PDDR_FECL_PDDR_FECL6 (0x40)
  495. #define MCF_GPIO_PDDR_FECL_PDDR_FECL7 (0x80)
  496. /* Bit definitions and macros for MCF_GPIO_PDDR_SSI */
  497. #define MCF_GPIO_PDDR_SSI_PDDR_SSI0 (0x01)
  498. #define MCF_GPIO_PDDR_SSI_PDDR_SSI1 (0x02)
  499. #define MCF_GPIO_PDDR_SSI_PDDR_SSI2 (0x04)
  500. #define MCF_GPIO_PDDR_SSI_PDDR_SSI3 (0x08)
  501. #define MCF_GPIO_PDDR_SSI_PDDR_SSI4 (0x10)
  502. /* Bit definitions and macros for MCF_GPIO_PDDR_BUSCTL */
  503. #define MCF_GPIO_PDDR_BUSCTL_POSDR_BUSCTL0 (0x01)
  504. #define MCF_GPIO_PDDR_BUSCTL_PDDR_BUSCTL1 (0x02)
  505. #define MCF_GPIO_PDDR_BUSCTL_PDDR_BUSCTL2 (0x04)
  506. #define MCF_GPIO_PDDR_BUSCTL_PDDR_BUSCTL3 (0x08)
  507. /* Bit definitions and macros for MCF_GPIO_PDDR_BE */
  508. #define MCF_GPIO_PDDR_BE_PDDR_BE0 (0x01)
  509. #define MCF_GPIO_PDDR_BE_PDDR_BE1 (0x02)
  510. #define MCF_GPIO_PDDR_BE_PDDR_BE2 (0x04)
  511. #define MCF_GPIO_PDDR_BE_PDDR_BE3 (0x08)
  512. /* Bit definitions and macros for MCF_GPIO_PDDR_CS */
  513. #define MCF_GPIO_PDDR_CS_PDDR_CS1 (0x02)
  514. #define MCF_GPIO_PDDR_CS_PDDR_CS2 (0x04)
  515. #define MCF_GPIO_PDDR_CS_PDDR_CS3 (0x08)
  516. #define MCF_GPIO_PDDR_CS_PDDR_CS4 (0x10)
  517. #define MCF_GPIO_PDDR_CS_PDDR_CS5 (0x20)
  518. /* Bit definitions and macros for MCF_GPIO_PDDR_PWM */
  519. #define MCF_GPIO_PDDR_PWM_PDDR_PWM2 (0x04)
  520. #define MCF_GPIO_PDDR_PWM_PDDR_PWM3 (0x08)
  521. #define MCF_GPIO_PDDR_PWM_PDDR_PWM4 (0x10)
  522. #define MCF_GPIO_PDDR_PWM_PDDR_PWM5 (0x20)
  523. /* Bit definitions and macros for MCF_GPIO_PDDR_FECI2C */
  524. #define MCF_GPIO_PDDR_FECI2C_PDDR_FECI2C0 (0x01)
  525. #define MCF_GPIO_PDDR_FECI2C_PDDR_FECI2C1 (0x02)
  526. #define MCF_GPIO_PDDR_FECI2C_PDDR_FECI2C2 (0x04)
  527. #define MCF_GPIO_PDDR_FECI2C_PDDR_FECI2C3 (0x08)
  528. /* Bit definitions and macros for MCF_GPIO_PDDR_UART */
  529. #define MCF_GPIO_PDDR_UART_PDDR_UART0 (0x01)
  530. #define MCF_GPIO_PDDR_UART_PDDR_UART1 (0x02)
  531. #define MCF_GPIO_PDDR_UART_PDDR_UART2 (0x04)
  532. #define MCF_GPIO_PDDR_UART_PDDR_UART3 (0x08)
  533. #define MCF_GPIO_PDDR_UART_PDDR_UART4 (0x10)
  534. #define MCF_GPIO_PDDR_UART_PDDR_UART5 (0x20)
  535. #define MCF_GPIO_PDDR_UART_PDDR_UART6 (0x40)
  536. #define MCF_GPIO_PDDR_UART_PDDR_UART7 (0x80)
  537. /* Bit definitions and macros for MCF_GPIO_PDDR_QSPI */
  538. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI0 (0x01)
  539. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI1 (0x02)
  540. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI2 (0x04)
  541. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI3 (0x08)
  542. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI4 (0x10)
  543. #define MCF_GPIO_PDDR_QSPI_PDDR_QSPI5 (0x20)
  544. /* Bit definitions and macros for MCF_GPIO_PDDR_TIMER */
  545. #define MCF_GPIO_PDDR_TIMER_PDDR_TIMER0 (0x01)
  546. #define MCF_GPIO_PDDR_TIMER_PDDR_TIMER1 (0x02)
  547. #define MCF_GPIO_PDDR_TIMER_PDDR_TIMER2 (0x04)
  548. #define MCF_GPIO_PDDR_TIMER_PDDR_TIMER3 (0x08)
  549. /* Bit definitions and macros for MCF_GPIO_PDDR_LCDDATAH */
  550. #define MCF_GPIO_PDDR_LCDDATAH_PDDR_LCDDATAH0 (0x01)
  551. #define MCF_GPIO_PDDR_LCDDATAH_PDDR_LCDDATAH1 (0x02)
  552. /* Bit definitions and macros for MCF_GPIO_PDDR_LCDDATAM */
  553. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM0 (0x01)
  554. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM1 (0x02)
  555. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM2 (0x04)
  556. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM3 (0x08)
  557. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM4 (0x10)
  558. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM5 (0x20)
  559. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM6 (0x40)
  560. #define MCF_GPIO_PDDR_LCDDATAM_PDDR_LCDDATAM7 (0x80)
  561. /* Bit definitions and macros for MCF_GPIO_PDDR_LCDDATAL */
  562. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL0 (0x01)
  563. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL1 (0x02)
  564. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL2 (0x04)
  565. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL3 (0x08)
  566. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL4 (0x10)
  567. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL5 (0x20)
  568. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL6 (0x40)
  569. #define MCF_GPIO_PDDR_LCDDATAL_PDDR_LCDDATAL7 (0x80)
  570. /* Bit definitions and macros for MCF_GPIO_PDDR_LCDCTLH */
  571. #define MCF_GPIO_PDDR_LCDCTLH_PDDR_LCDCTLH0 (0x01)
  572. /* Bit definitions and macros for MCF_GPIO_PDDR_LCDCTLL */
  573. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL0 (0x01)
  574. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL1 (0x02)
  575. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL2 (0x04)
  576. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL3 (0x08)
  577. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL4 (0x10)
  578. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL5 (0x20)
  579. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL6 (0x40)
  580. #define MCF_GPIO_PDDR_LCDCTLL_PDDR_LCDCTLL7 (0x80)
  581. /* Bit definitions and macros for MCF_GPIO_PPDSDR_FECH */
  582. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH0 (0x01)
  583. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH1 (0x02)
  584. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH2 (0x04)
  585. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH3 (0x08)
  586. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH4 (0x10)
  587. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH5 (0x20)
  588. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH6 (0x40)
  589. #define MCF_GPIO_PPDSDR_FECH_PPDSDR_FECH7 (0x80)
  590. /* Bit definitions and macros for MCF_GPIO_PPDSDR_FECL */
  591. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL0 (0x01)
  592. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL1 (0x02)
  593. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL2 (0x04)
  594. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL3 (0x08)
  595. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL4 (0x10)
  596. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL5 (0x20)
  597. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL6 (0x40)
  598. #define MCF_GPIO_PPDSDR_FECL_PPDSDR_FECL7 (0x80)
  599. /* Bit definitions and macros for MCF_GPIO_PPDSDR_SSI */
  600. #define MCF_GPIO_PPDSDR_SSI_PPDSDR_SSI0 (0x01)
  601. #define MCF_GPIO_PPDSDR_SSI_PPDSDR_SSI1 (0x02)
  602. #define MCF_GPIO_PPDSDR_SSI_PPDSDR_SSI2 (0x04)
  603. #define MCF_GPIO_PPDSDR_SSI_PPDSDR_SSI3 (0x08)
  604. #define MCF_GPIO_PPDSDR_SSI_PPDSDR_SSI4 (0x10)
  605. /* Bit definitions and macros for MCF_GPIO_PPDSDR_BUSCTL */
  606. #define MCF_GPIO_PPDSDR_BUSCTL_POSDR_BUSCTL0 (0x01)
  607. #define MCF_GPIO_PPDSDR_BUSCTL_PPDSDR_BUSCTL1 (0x02)
  608. #define MCF_GPIO_PPDSDR_BUSCTL_PPDSDR_BUSCTL2 (0x04)
  609. #define MCF_GPIO_PPDSDR_BUSCTL_PPDSDR_BUSCTL3 (0x08)
  610. /* Bit definitions and macros for MCF_GPIO_PPDSDR_BE */
  611. #define MCF_GPIO_PPDSDR_BE_PPDSDR_BE0 (0x01)
  612. #define MCF_GPIO_PPDSDR_BE_PPDSDR_BE1 (0x02)
  613. #define MCF_GPIO_PPDSDR_BE_PPDSDR_BE2 (0x04)
  614. #define MCF_GPIO_PPDSDR_BE_PPDSDR_BE3 (0x08)
  615. /* Bit definitions and macros for MCF_GPIO_PPDSDR_CS */
  616. #define MCF_GPIO_PPDSDR_CS_PPDSDR_CS1 (0x02)
  617. #define MCF_GPIO_PPDSDR_CS_PPDSDR_CS2 (0x04)
  618. #define MCF_GPIO_PPDSDR_CS_PPDSDR_CS3 (0x08)
  619. #define MCF_GPIO_PPDSDR_CS_PPDSDR_CS4 (0x10)
  620. #define MCF_GPIO_PPDSDR_CS_PPDSDR_CS5 (0x20)
  621. /* Bit definitions and macros for MCF_GPIO_PPDSDR_PWM */
  622. #define MCF_GPIO_PPDSDR_PWM_PPDSDR_PWM2 (0x04)
  623. #define MCF_GPIO_PPDSDR_PWM_PPDSDR_PWM3 (0x08)
  624. #define MCF_GPIO_PPDSDR_PWM_PPDSDR_PWM4 (0x10)
  625. #define MCF_GPIO_PPDSDR_PWM_PPDSDR_PWM5 (0x20)
  626. /* Bit definitions and macros for MCF_GPIO_PPDSDR_FECI2C */
  627. #define MCF_GPIO_PPDSDR_FECI2C_PPDSDR_FECI2C0 (0x01)
  628. #define MCF_GPIO_PPDSDR_FECI2C_PPDSDR_FECI2C1 (0x02)
  629. #define MCF_GPIO_PPDSDR_FECI2C_PPDSDR_FECI2C2 (0x04)
  630. #define MCF_GPIO_PPDSDR_FECI2C_PPDSDR_FECI2C3 (0x08)
  631. /* Bit definitions and macros for MCF_GPIO_PPDSDR_UART */
  632. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART0 (0x01)
  633. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART1 (0x02)
  634. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART2 (0x04)
  635. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART3 (0x08)
  636. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART4 (0x10)
  637. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART5 (0x20)
  638. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART6 (0x40)
  639. #define MCF_GPIO_PPDSDR_UART_PPDSDR_UART7 (0x80)
  640. /* Bit definitions and macros for MCF_GPIO_PPDSDR_QSPI */
  641. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI0 (0x01)
  642. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI1 (0x02)
  643. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI2 (0x04)
  644. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI3 (0x08)
  645. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI4 (0x10)
  646. #define MCF_GPIO_PPDSDR_QSPI_PPDSDR_QSPI5 (0x20)
  647. /* Bit definitions and macros for MCF_GPIO_PPDSDR_TIMER */
  648. #define MCF_GPIO_PPDSDR_TIMER_PPDSDR_TIMER0 (0x01)
  649. #define MCF_GPIO_PPDSDR_TIMER_PPDSDR_TIMER1 (0x02)
  650. #define MCF_GPIO_PPDSDR_TIMER_PPDSDR_TIMER2 (0x04)
  651. #define MCF_GPIO_PPDSDR_TIMER_PPDSDR_TIMER3 (0x08)
  652. /* Bit definitions and macros for MCF_GPIO_PPDSDR_LCDDATAH */
  653. #define MCF_GPIO_PPDSDR_LCDDATAH_PPDSDR_LCDDATAH0 (0x01)
  654. #define MCF_GPIO_PPDSDR_LCDDATAH_PPDSDR_LCDDATAH1 (0x02)
  655. /* Bit definitions and macros for MCF_GPIO_PPDSDR_LCDDATAM */
  656. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM0 (0x01)
  657. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM1 (0x02)
  658. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM2 (0x04)
  659. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM3 (0x08)
  660. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM4 (0x10)
  661. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM5 (0x20)
  662. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM6 (0x40)
  663. #define MCF_GPIO_PPDSDR_LCDDATAM_PPDSDR_LCDDATAM7 (0x80)
  664. /* Bit definitions and macros for MCF_GPIO_PPDSDR_LCDDATAL */
  665. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL0 (0x01)
  666. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL1 (0x02)
  667. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL2 (0x04)
  668. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL3 (0x08)
  669. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL4 (0x10)
  670. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL5 (0x20)
  671. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL6 (0x40)
  672. #define MCF_GPIO_PPDSDR_LCDDATAL_PPDSDR_LCDDATAL7 (0x80)
  673. /* Bit definitions and macros for MCF_GPIO_PPDSDR_LCDCTLH */
  674. #define MCF_GPIO_PPDSDR_LCDCTLH_PPDSDR_LCDCTLH0 (0x01)
  675. /* Bit definitions and macros for MCF_GPIO_PPDSDR_LCDCTLL */
  676. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL0 (0x01)
  677. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL1 (0x02)
  678. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL2 (0x04)
  679. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL3 (0x08)
  680. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL4 (0x10)
  681. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL5 (0x20)
  682. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL6 (0x40)
  683. #define MCF_GPIO_PPDSDR_LCDCTLL_PPDSDR_LCDCTLL7 (0x80)
  684. /* Bit definitions and macros for MCF_GPIO_PCLRR_FECH */
  685. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH0 (0x01)
  686. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH1 (0x02)
  687. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH2 (0x04)
  688. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH3 (0x08)
  689. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH4 (0x10)
  690. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH5 (0x20)
  691. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH6 (0x40)
  692. #define MCF_GPIO_PCLRR_FECH_PCLRR_FECH7 (0x80)
  693. /* Bit definitions and macros for MCF_GPIO_PCLRR_FECL */
  694. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL0 (0x01)
  695. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL1 (0x02)
  696. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL2 (0x04)
  697. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL3 (0x08)
  698. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL4 (0x10)
  699. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL5 (0x20)
  700. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL6 (0x40)
  701. #define MCF_GPIO_PCLRR_FECL_PCLRR_FECL7 (0x80)
  702. /* Bit definitions and macros for MCF_GPIO_PCLRR_SSI */
  703. #define MCF_GPIO_PCLRR_SSI_PCLRR_SSI0 (0x01)
  704. #define MCF_GPIO_PCLRR_SSI_PCLRR_SSI1 (0x02)
  705. #define MCF_GPIO_PCLRR_SSI_PCLRR_SSI2 (0x04)
  706. #define MCF_GPIO_PCLRR_SSI_PCLRR_SSI3 (0x08)
  707. #define MCF_GPIO_PCLRR_SSI_PCLRR_SSI4 (0x10)
  708. /* Bit definitions and macros for MCF_GPIO_PCLRR_BUSCTL */
  709. #define MCF_GPIO_PCLRR_BUSCTL_POSDR_BUSCTL0 (0x01)
  710. #define MCF_GPIO_PCLRR_BUSCTL_PCLRR_BUSCTL1 (0x02)
  711. #define MCF_GPIO_PCLRR_BUSCTL_PCLRR_BUSCTL2 (0x04)
  712. #define MCF_GPIO_PCLRR_BUSCTL_PCLRR_BUSCTL3 (0x08)
  713. /* Bit definitions and macros for MCF_GPIO_PCLRR_BE */
  714. #define MCF_GPIO_PCLRR_BE_PCLRR_BE0 (0x01)
  715. #define MCF_GPIO_PCLRR_BE_PCLRR_BE1 (0x02)
  716. #define MCF_GPIO_PCLRR_BE_PCLRR_BE2 (0x04)
  717. #define MCF_GPIO_PCLRR_BE_PCLRR_BE3 (0x08)
  718. /* Bit definitions and macros for MCF_GPIO_PCLRR_CS */
  719. #define MCF_GPIO_PCLRR_CS_PCLRR_CS1 (0x02)
  720. #define MCF_GPIO_PCLRR_CS_PCLRR_CS2 (0x04)
  721. #define MCF_GPIO_PCLRR_CS_PCLRR_CS3 (0x08)
  722. #define MCF_GPIO_PCLRR_CS_PCLRR_CS4 (0x10)
  723. #define MCF_GPIO_PCLRR_CS_PCLRR_CS5 (0x20)
  724. /* Bit definitions and macros for MCF_GPIO_PCLRR_PWM */
  725. #define MCF_GPIO_PCLRR_PWM_PCLRR_PWM2 (0x04)
  726. #define MCF_GPIO_PCLRR_PWM_PCLRR_PWM3 (0x08)
  727. #define MCF_GPIO_PCLRR_PWM_PCLRR_PWM4 (0x10)
  728. #define MCF_GPIO_PCLRR_PWM_PCLRR_PWM5 (0x20)
  729. /* Bit definitions and macros for MCF_GPIO_PCLRR_FECI2C */
  730. #define MCF_GPIO_PCLRR_FECI2C_PCLRR_FECI2C0 (0x01)
  731. #define MCF_GPIO_PCLRR_FECI2C_PCLRR_FECI2C1 (0x02)
  732. #define MCF_GPIO_PCLRR_FECI2C_PCLRR_FECI2C2 (0x04)
  733. #define MCF_GPIO_PCLRR_FECI2C_PCLRR_FECI2C3 (0x08)
  734. /* Bit definitions and macros for MCF_GPIO_PCLRR_UART */
  735. #define MCF_GPIO_PCLRR_UART_PCLRR_UART0 (0x01)
  736. #define MCF_GPIO_PCLRR_UART_PCLRR_UART1 (0x02)
  737. #define MCF_GPIO_PCLRR_UART_PCLRR_UART2 (0x04)
  738. #define MCF_GPIO_PCLRR_UART_PCLRR_UART3 (0x08)
  739. #define MCF_GPIO_PCLRR_UART_PCLRR_UART4 (0x10)
  740. #define MCF_GPIO_PCLRR_UART_PCLRR_UART5 (0x20)
  741. #define MCF_GPIO_PCLRR_UART_PCLRR_UART6 (0x40)
  742. #define MCF_GPIO_PCLRR_UART_PCLRR_UART7 (0x80)
  743. /* Bit definitions and macros for MCF_GPIO_PCLRR_QSPI */
  744. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI0 (0x01)
  745. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI1 (0x02)
  746. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI2 (0x04)
  747. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI3 (0x08)
  748. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI4 (0x10)
  749. #define MCF_GPIO_PCLRR_QSPI_PCLRR_QSPI5 (0x20)
  750. /* Bit definitions and macros for MCF_GPIO_PCLRR_TIMER */
  751. #define MCF_GPIO_PCLRR_TIMER_PCLRR_TIMER0 (0x01)
  752. #define MCF_GPIO_PCLRR_TIMER_PCLRR_TIMER1 (0x02)
  753. #define MCF_GPIO_PCLRR_TIMER_PCLRR_TIMER2 (0x04)
  754. #define MCF_GPIO_PCLRR_TIMER_PCLRR_TIMER3 (0x08)
  755. /* Bit definitions and macros for MCF_GPIO_PCLRR_LCDDATAH */
  756. #define MCF_GPIO_PCLRR_LCDDATAH_PCLRR_LCDDATAH0 (0x01)
  757. #define MCF_GPIO_PCLRR_LCDDATAH_PCLRR_LCDDATAH1 (0x02)
  758. /* Bit definitions and macros for MCF_GPIO_PCLRR_LCDDATAM */
  759. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM0 (0x01)
  760. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM1 (0x02)
  761. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM2 (0x04)
  762. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM3 (0x08)
  763. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM4 (0x10)
  764. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM5 (0x20)
  765. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM6 (0x40)
  766. #define MCF_GPIO_PCLRR_LCDDATAM_PCLRR_LCDDATAM7 (0x80)
  767. /* Bit definitions and macros for MCF_GPIO_PCLRR_LCDDATAL */
  768. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL0 (0x01)
  769. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL1 (0x02)
  770. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL2 (0x04)
  771. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL3 (0x08)
  772. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL4 (0x10)
  773. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL5 (0x20)
  774. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL6 (0x40)
  775. #define MCF_GPIO_PCLRR_LCDDATAL_PCLRR_LCDDATAL7 (0x80)
  776. /* Bit definitions and macros for MCF_GPIO_PCLRR_LCDCTLH */
  777. #define MCF_GPIO_PCLRR_LCDCTLH_PCLRR_LCDCTLH0 (0x01)
  778. /* Bit definitions and macros for MCF_GPIO_PCLRR_LCDCTLL */
  779. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL0 (0x01)
  780. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL1 (0x02)
  781. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL2 (0x04)
  782. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL3 (0x08)
  783. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL4 (0x10)
  784. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL5 (0x20)
  785. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL6 (0x40)
  786. #define MCF_GPIO_PCLRR_LCDCTLL_PCLRR_LCDCTLL7 (0x80)
  787. /* Bit definitions and macros for MCF_GPIO_PAR_FEC */
  788. #define MCF_GPIO_PAR_FEC_PAR_FEC_MII(x) (((x)&0x03)<<0)
  789. #define MCF_GPIO_PAR_FEC_PAR_FEC_7W(x) (((x)&0x03)<<2)
  790. #define MCF_GPIO_PAR_FEC_PAR_FEC_7W_GPIO (0x00)
  791. #define MCF_GPIO_PAR_FEC_PAR_FEC_7W_URTS1 (0x04)
  792. #define MCF_GPIO_PAR_FEC_PAR_FEC_7W_FEC (0x0C)
  793. #define MCF_GPIO_PAR_FEC_PAR_FEC_MII_GPIO (0x00)
  794. #define MCF_GPIO_PAR_FEC_PAR_FEC_MII_UART (0x01)
  795. #define MCF_GPIO_PAR_FEC_PAR_FEC_MII_FEC (0x03)
  796. /* Bit definitions and macros for MCF_GPIO_PAR_PWM */
  797. #define MCF_GPIO_PAR_PWM_PAR_PWM1(x) (((x)&0x03)<<0)
  798. #define MCF_GPIO_PAR_PWM_PAR_PWM3(x) (((x)&0x03)<<2)
  799. #define MCF_GPIO_PAR_PWM_PAR_PWM5 (0x10)
  800. #define MCF_GPIO_PAR_PWM_PAR_PWM7 (0x20)
  801. /* Bit definitions and macros for MCF_GPIO_PAR_BUSCTL */
  802. #define MCF_GPIO_PAR_BUSCTL_PAR_TS(x) (((x)&0x03)<<3)
  803. #define MCF_GPIO_PAR_BUSCTL_PAR_RWB (0x20)
  804. #define MCF_GPIO_PAR_BUSCTL_PAR_TA (0x40)
  805. #define MCF_GPIO_PAR_BUSCTL_PAR_OE (0x80)
  806. #define MCF_GPIO_PAR_BUSCTL_PAR_OE_GPIO (0x00)
  807. #define MCF_GPIO_PAR_BUSCTL_PAR_OE_OE (0x80)
  808. #define MCF_GPIO_PAR_BUSCTL_PAR_TA_GPIO (0x00)
  809. #define MCF_GPIO_PAR_BUSCTL_PAR_TA_TA (0x40)
  810. #define MCF_GPIO_PAR_BUSCTL_PAR_RWB_GPIO (0x00)
  811. #define MCF_GPIO_PAR_BUSCTL_PAR_RWB_RWB (0x20)
  812. #define MCF_GPIO_PAR_BUSCTL_PAR_TS_GPIO (0x00)
  813. #define MCF_GPIO_PAR_BUSCTL_PAR_TS_DACK0 (0x10)
  814. #define MCF_GPIO_PAR_BUSCTL_PAR_TS_TS (0x18)
  815. /* Bit definitions and macros for MCF_GPIO_PAR_FECI2C */
  816. #define MCF_GPIO_PAR_FECI2C_PAR_SDA(x) (((x)&0x03)<<0)
  817. #define MCF_GPIO_PAR_FECI2C_PAR_SCL(x) (((x)&0x03)<<2)
  818. #define MCF_GPIO_PAR_FECI2C_PAR_MDIO(x) (((x)&0x03)<<4)
  819. #define MCF_GPIO_PAR_FECI2C_PAR_MDC(x) (((x)&0x03)<<6)
  820. #define MCF_GPIO_PAR_FECI2C_PAR_MDC_GPIO (0x00)
  821. #define MCF_GPIO_PAR_FECI2C_PAR_MDC_UTXD2 (0x40)
  822. #define MCF_GPIO_PAR_FECI2C_PAR_MDC_SCL (0x80)
  823. #define MCF_GPIO_PAR_FECI2C_PAR_MDC_EMDC (0xC0)
  824. #define MCF_GPIO_PAR_FECI2C_PAR_MDIO_GPIO (0x00)
  825. #define MCF_GPIO_PAR_FECI2C_PAR_MDIO_URXD2 (0x10)
  826. #define MCF_GPIO_PAR_FECI2C_PAR_MDIO_SDA (0x20)
  827. #define MCF_GPIO_PAR_FECI2C_PAR_MDIO_EMDIO (0x30)
  828. #define MCF_GPIO_PAR_FECI2C_PAR_SCL_GPIO (0x00)
  829. #define MCF_GPIO_PAR_FECI2C_PAR_SCL_UTXD2 (0x04)
  830. #define MCF_GPIO_PAR_FECI2C_PAR_SCL_SCL (0x0C)
  831. #define MCF_GPIO_PAR_FECI2C_PAR_SDA_GPIO (0x00)
  832. #define MCF_GPIO_PAR_FECI2C_PAR_SDA_URXD2 (0x02)
  833. #define MCF_GPIO_PAR_FECI2C_PAR_SDA_SDA (0x03)
  834. /* Bit definitions and macros for MCF_GPIO_PAR_BE */
  835. #define MCF_GPIO_PAR_BE_PAR_BE0 (0x01)
  836. #define MCF_GPIO_PAR_BE_PAR_BE1 (0x02)
  837. #define MCF_GPIO_PAR_BE_PAR_BE2 (0x04)
  838. #define MCF_GPIO_PAR_BE_PAR_BE3 (0x08)
  839. /* Bit definitions and macros for MCF_GPIO_PAR_CS */
  840. #define MCF_GPIO_PAR_CS_PAR_CS1 (0x02)
  841. #define MCF_GPIO_PAR_CS_PAR_CS2 (0x04)
  842. #define MCF_GPIO_PAR_CS_PAR_CS3 (0x08)
  843. #define MCF_GPIO_PAR_CS_PAR_CS4 (0x10)
  844. #define MCF_GPIO_PAR_CS_PAR_CS5 (0x20)
  845. #define MCF_GPIO_PAR_CS_PAR_CS_CS1_GPIO (0x00)
  846. #define MCF_GPIO_PAR_CS_PAR_CS_CS1_SDCS1 (0x01)
  847. #define MCF_GPIO_PAR_CS_PAR_CS_CS1_CS1 (0x03)
  848. /* Bit definitions and macros for MCF_GPIO_PAR_SSI */
  849. #define MCF_GPIO_PAR_SSI_PAR_MCLK (0x0080)
  850. #define MCF_GPIO_PAR_SSI_PAR_TXD(x) (((x)&0x0003)<<8)
  851. #define MCF_GPIO_PAR_SSI_PAR_RXD(x) (((x)&0x0003)<<10)
  852. #define MCF_GPIO_PAR_SSI_PAR_FS(x) (((x)&0x0003)<<12)
  853. #define MCF_GPIO_PAR_SSI_PAR_BCLK(x) (((x)&0x0003)<<14)
  854. /* Bit definitions and macros for MCF_GPIO_PAR_UART */
  855. #define MCF_GPIO_PAR_UART_PAR_UTXD0 (0x0001)
  856. #define MCF_GPIO_PAR_UART_PAR_URXD0 (0x0002)
  857. #define MCF_GPIO_PAR_UART_PAR_URTS0 (0x0004)
  858. #define MCF_GPIO_PAR_UART_PAR_UCTS0 (0x0008)
  859. #define MCF_GPIO_PAR_UART_PAR_UTXD1(x) (((x)&0x0003)<<4)
  860. #define MCF_GPIO_PAR_UART_PAR_URXD1(x) (((x)&0x0003)<<6)
  861. #define MCF_GPIO_PAR_UART_PAR_URTS1(x) (((x)&0x0003)<<8)
  862. #define MCF_GPIO_PAR_UART_PAR_UCTS1(x) (((x)&0x0003)<<10)
  863. #define MCF_GPIO_PAR_UART_PAR_UCTS1_GPIO (0x0000)
  864. #define MCF_GPIO_PAR_UART_PAR_UCTS1_SSI_BCLK (0x0800)
  865. #define MCF_GPIO_PAR_UART_PAR_UCTS1_ULPI_D7 (0x0400)
  866. #define MCF_GPIO_PAR_UART_PAR_UCTS1_UCTS1 (0x0C00)
  867. #define MCF_GPIO_PAR_UART_PAR_URTS1_GPIO (0x0000)
  868. #define MCF_GPIO_PAR_UART_PAR_URTS1_SSI_FS (0x0200)
  869. #define MCF_GPIO_PAR_UART_PAR_URTS1_ULPI_D6 (0x0100)
  870. #define MCF_GPIO_PAR_UART_PAR_URTS1_URTS1 (0x0300)
  871. #define MCF_GPIO_PAR_UART_PAR_URXD1_GPIO (0x0000)
  872. #define MCF_GPIO_PAR_UART_PAR_URXD1_SSI_RXD (0x0080)
  873. #define MCF_GPIO_PAR_UART_PAR_URXD1_ULPI_D5 (0x0040)
  874. #define MCF_GPIO_PAR_UART_PAR_URXD1_URXD1 (0x00C0)
  875. #define MCF_GPIO_PAR_UART_PAR_UTXD1_GPIO (0x0000)
  876. #define MCF_GPIO_PAR_UART_PAR_UTXD1_SSI_TXD (0x0020)
  877. #define MCF_GPIO_PAR_UART_PAR_UTXD1_ULPI_D4 (0x0010)
  878. #define MCF_GPIO_PAR_UART_PAR_UTXD1_UTXD1 (0x0030)
  879. /* Bit definitions and macros for MCF_GPIO_PAR_QSPI */
  880. #define MCF_GPIO_PAR_QSPI_PAR_SCK(x) (((x)&0x0003)<<4)
  881. #define MCF_GPIO_PAR_QSPI_PAR_DOUT(x) (((x)&0x0003)<<6)
  882. #define MCF_GPIO_PAR_QSPI_PAR_DIN(x) (((x)&0x0003)<<8)
  883. #define MCF_GPIO_PAR_QSPI_PAR_PCS0(x) (((x)&0x0003)<<10)
  884. #define MCF_GPIO_PAR_QSPI_PAR_PCS1(x) (((x)&0x0003)<<12)
  885. #define MCF_GPIO_PAR_QSPI_PAR_PCS2(x) (((x)&0x0003)<<14)
  886. /* Bit definitions and macros for MCF_GPIO_PAR_TIMER */
  887. #define MCF_GPIO_PAR_TIMER_PAR_TIN0(x) (((x)&0x03)<<0)
  888. #define MCF_GPIO_PAR_TIMER_PAR_TIN1(x) (((x)&0x03)<<2)
  889. #define MCF_GPIO_PAR_TIMER_PAR_TIN2(x) (((x)&0x03)<<4)
  890. #define MCF_GPIO_PAR_TIMER_PAR_TIN3(x) (((x)&0x03)<<6)
  891. #define MCF_GPIO_PAR_TIMER_PAR_TIN3_GPIO (0x00)
  892. #define MCF_GPIO_PAR_TIMER_PAR_TIN3_TOUT3 (0x80)
  893. #define MCF_GPIO_PAR_TIMER_PAR_TIN3_URXD2 (0x40)
  894. #define MCF_GPIO_PAR_TIMER_PAR_TIN3_TIN3 (0xC0)
  895. #define MCF_GPIO_PAR_TIMER_PAR_TIN2_GPIO (0x00)
  896. #define MCF_GPIO_PAR_TIMER_PAR_TIN2_TOUT2 (0x20)
  897. #define MCF_GPIO_PAR_TIMER_PAR_TIN2_UTXD2 (0x10)
  898. #define MCF_GPIO_PAR_TIMER_PAR_TIN2_TIN2 (0x30)
  899. #define MCF_GPIO_PAR_TIMER_PAR_TIN1_GPIO (0x00)
  900. #define MCF_GPIO_PAR_TIMER_PAR_TIN1_TOUT1 (0x08)
  901. #define MCF_GPIO_PAR_TIMER_PAR_TIN1_DACK1 (0x04)
  902. #define MCF_GPIO_PAR_TIMER_PAR_TIN1_TIN1 (0x0C)
  903. #define MCF_GPIO_PAR_TIMER_PAR_TIN0_GPIO (0x00)
  904. #define MCF_GPIO_PAR_TIMER_PAR_TIN0_TOUT0 (0x02)
  905. #define MCF_GPIO_PAR_TIMER_PAR_TIN0_DREQ0 (0x01)
  906. #define MCF_GPIO_PAR_TIMER_PAR_TIN0_TIN0 (0x03)
  907. /* Bit definitions and macros for MCF_GPIO_PAR_LCDDATA */
  908. #define MCF_GPIO_PAR_LCDDATA_PAR_LD7_0(x) (((x)&0x03)<<0)
  909. #define MCF_GPIO_PAR_LCDDATA_PAR_LD15_8(x) (((x)&0x03)<<2)
  910. #define MCF_GPIO_PAR_LCDDATA_PAR_LD16(x) (((x)&0x03)<<4)
  911. #define MCF_GPIO_PAR_LCDDATA_PAR_LD17(x) (((x)&0x03)<<6)
  912. /* Bit definitions and macros for MCF_GPIO_PAR_LCDCTL */
  913. #define MCF_GPIO_PAR_LCDCTL_PAR_CLS (0x0001)
  914. #define MCF_GPIO_PAR_LCDCTL_PAR_PS (0x0002)
  915. #define MCF_GPIO_PAR_LCDCTL_PAR_REV (0x0004)
  916. #define MCF_GPIO_PAR_LCDCTL_PAR_SPL_SPR (0x0008)
  917. #define MCF_GPIO_PAR_LCDCTL_PAR_CONTRAST (0x0010)
  918. #define MCF_GPIO_PAR_LCDCTL_PAR_LSCLK (0x0020)
  919. #define MCF_GPIO_PAR_LCDCTL_PAR_LP_HSYNC (0x0040)
  920. #define MCF_GPIO_PAR_LCDCTL_PAR_FLM_VSYNC (0x0080)
  921. #define MCF_GPIO_PAR_LCDCTL_PAR_ACD_OE (0x0100)
  922. /* Bit definitions and macros for MCF_GPIO_PAR_IRQ */
  923. #define MCF_GPIO_PAR_IRQ_PAR_IRQ1(x) (((x)&0x0003)<<4)
  924. #define MCF_GPIO_PAR_IRQ_PAR_IRQ2(x) (((x)&0x0003)<<6)
  925. #define MCF_GPIO_PAR_IRQ_PAR_IRQ4(x) (((x)&0x0003)<<8)
  926. #define MCF_GPIO_PAR_IRQ_PAR_IRQ5(x) (((x)&0x0003)<<10)
  927. #define MCF_GPIO_PAR_IRQ_PAR_IRQ6(x) (((x)&0x0003)<<12)
  928. /* Bit definitions and macros for MCF_GPIO_MSCR_FLEXBUS */
  929. #define MCF_GPIO_MSCR_FLEXBUS_MSCR_ADDRCTL(x) (((x)&0x03)<<0)
  930. #define MCF_GPIO_MSCR_FLEXBUS_MSCR_DLOWER(x) (((x)&0x03)<<2)
  931. #define MCF_GPIO_MSCR_FLEXBUS_MSCR_DUPPER(x) (((x)&0x03)<<4)
  932. /* Bit definitions and macros for MCF_GPIO_MSCR_SDRAM */
  933. #define MCF_GPIO_MSCR_SDRAM_MSCR_SDRAM(x) (((x)&0x03)<<0)
  934. #define MCF_GPIO_MSCR_SDRAM_MSCR_SDCLK(x) (((x)&0x03)<<2)
  935. #define MCF_GPIO_MSCR_SDRAM_MSCR_SDCLKB(x) (((x)&0x03)<<4)
  936. /* Bit definitions and macros for MCF_GPIO_DSCR_I2C */
  937. #define MCF_GPIO_DSCR_I2C_I2C_DSE(x) (((x)&0x03)<<0)
  938. /* Bit definitions and macros for MCF_GPIO_DSCR_PWM */
  939. #define MCF_GPIO_DSCR_PWM_PWM_DSE(x) (((x)&0x03)<<0)
  940. /* Bit definitions and macros for MCF_GPIO_DSCR_FEC */
  941. #define MCF_GPIO_DSCR_FEC_FEC_DSE(x) (((x)&0x03)<<0)
  942. /* Bit definitions and macros for MCF_GPIO_DSCR_UART */
  943. #define MCF_GPIO_DSCR_UART_UART0_DSE(x) (((x)&0x03)<<0)
  944. #define MCF_GPIO_DSCR_UART_UART1_DSE(x) (((x)&0x03)<<2)
  945. /* Bit definitions and macros for MCF_GPIO_DSCR_QSPI */
  946. #define MCF_GPIO_DSCR_QSPI_QSPI_DSE(x) (((x)&0x03)<<0)
  947. /* Bit definitions and macros for MCF_GPIO_DSCR_TIMER */
  948. #define MCF_GPIO_DSCR_TIMER_TIMER_DSE(x) (((x)&0x03)<<0)
  949. /* Bit definitions and macros for MCF_GPIO_DSCR_SSI */
  950. #define MCF_GPIO_DSCR_SSI_SSI_DSE(x) (((x)&0x03)<<0)
  951. /* Bit definitions and macros for MCF_GPIO_DSCR_LCD */
  952. #define MCF_GPIO_DSCR_LCD_LCD_DSE(x) (((x)&0x03)<<0)
  953. /* Bit definitions and macros for MCF_GPIO_DSCR_DEBUG */
  954. #define MCF_GPIO_DSCR_DEBUG_DEBUG_DSE(x) (((x)&0x03)<<0)
  955. /* Bit definitions and macros for MCF_GPIO_DSCR_CLKRST */
  956. #define MCF_GPIO_DSCR_CLKRST_CLKRST_DSE(x) (((x)&0x03)<<0)
  957. /* Bit definitions and macros for MCF_GPIO_DSCR_IRQ */
  958. #define MCF_GPIO_DSCR_IRQ_IRQ_DSE(x) (((x)&0x03)<<0)
  959. /*
  960. * Generic GPIO support
  961. */
  962. #define MCFGPIO_PODR MCFGPIO_PODR_FECH
  963. #define MCFGPIO_PDDR MCFGPIO_PDDR_FECH
  964. #define MCFGPIO_PPDR MCFGPIO_PPDSDR_FECH
  965. #define MCFGPIO_SETR MCFGPIO_PPDSDR_FECH
  966. #define MCFGPIO_CLRR MCFGPIO_PCLRR_FECH
  967. #define MCFGPIO_PIN_MAX 136
  968. #define MCFGPIO_IRQ_MAX 8
  969. #define MCFGPIO_IRQ_VECBASE MCFINT_VECBASE
  970. /*********************************************************************
  971. *
  972. * Phase Locked Loop (PLL)
  973. *
  974. *********************************************************************/
  975. /* Register read/write macros */
  976. #define MCF_PLL_PODR 0xFC0C0000
  977. #define MCF_PLL_PLLCR 0xFC0C0004
  978. #define MCF_PLL_PMDR 0xFC0C0008
  979. #define MCF_PLL_PFDR 0xFC0C000C
  980. /* Bit definitions and macros for MCF_PLL_PODR */
  981. #define MCF_PLL_PODR_BUSDIV(x) (((x)&0x0F)<<0)
  982. #define MCF_PLL_PODR_CPUDIV(x) (((x)&0x0F)<<4)
  983. /* Bit definitions and macros for MCF_PLL_PLLCR */
  984. #define MCF_PLL_PLLCR_DITHDEV(x) (((x)&0x07)<<0)
  985. #define MCF_PLL_PLLCR_DITHEN (0x80)
  986. /* Bit definitions and macros for MCF_PLL_PMDR */
  987. #define MCF_PLL_PMDR_MODDIV(x) (((x)&0xFF)<<0)
  988. /* Bit definitions and macros for MCF_PLL_PFDR */
  989. #define MCF_PLL_PFDR_MFD(x) (((x)&0xFF)<<0)
  990. /*********************************************************************
  991. *
  992. * System Control Module Registers (SCM)
  993. *
  994. *********************************************************************/
  995. /* Register read/write macros */
  996. #define MCF_SCM_MPR 0xFC000000
  997. #define MCF_SCM_PACRA 0xFC000020
  998. #define MCF_SCM_PACRB 0xFC000024
  999. #define MCF_SCM_PACRC 0xFC000028
  1000. #define MCF_SCM_PACRD 0xFC00002C
  1001. #define MCF_SCM_PACRE 0xFC000040
  1002. #define MCF_SCM_PACRF 0xFC000044
  1003. #define MCF_SCM_BCR 0xFC040024
  1004. /*********************************************************************
  1005. *
  1006. * SDRAM Controller (SDRAMC)
  1007. *
  1008. *********************************************************************/
  1009. /* Register read/write macros */
  1010. #define MCF_SDRAMC_SDMR 0xFC0B8000
  1011. #define MCF_SDRAMC_SDCR 0xFC0B8004
  1012. #define MCF_SDRAMC_SDCFG1 0xFC0B8008
  1013. #define MCF_SDRAMC_SDCFG2 0xFC0B800C
  1014. #define MCF_SDRAMC_LIMP_FIX 0xFC0B8080
  1015. #define MCF_SDRAMC_SDDS 0xFC0B8100
  1016. #define MCF_SDRAMC_SDCS0 0xFC0B8110
  1017. #define MCF_SDRAMC_SDCS1 0xFC0B8114
  1018. #define MCF_SDRAMC_SDCS2 0xFC0B8118
  1019. #define MCF_SDRAMC_SDCS3 0xFC0B811C
  1020. /* Bit definitions and macros for MCF_SDRAMC_SDMR */
  1021. #define MCF_SDRAMC_SDMR_CMD (0x00010000)
  1022. #define MCF_SDRAMC_SDMR_AD(x) (((x)&0x00000FFF)<<18)
  1023. #define MCF_SDRAMC_SDMR_BNKAD(x) (((x)&0x00000003)<<30)
  1024. #define MCF_SDRAMC_SDMR_BNKAD_LMR (0x00000000)
  1025. #define MCF_SDRAMC_SDMR_BNKAD_LEMR (0x40000000)
  1026. /* Bit definitions and macros for MCF_SDRAMC_SDCR */
  1027. #define MCF_SDRAMC_SDCR_IPALL (0x00000002)
  1028. #define MCF_SDRAMC_SDCR_IREF (0x00000004)
  1029. #define MCF_SDRAMC_SDCR_DQS_OE(x) (((x)&0x0000000F)<<8)
  1030. #define MCF_SDRAMC_SDCR_PS(x) (((x)&0x00000003)<<12)
  1031. #define MCF_SDRAMC_SDCR_RCNT(x) (((x)&0x0000003F)<<16)
  1032. #define MCF_SDRAMC_SDCR_OE_RULE (0x00400000)
  1033. #define MCF_SDRAMC_SDCR_MUX(x) (((x)&0x00000003)<<24)
  1034. #define MCF_SDRAMC_SDCR_REF (0x10000000)
  1035. #define MCF_SDRAMC_SDCR_DDR (0x20000000)
  1036. #define MCF_SDRAMC_SDCR_CKE (0x40000000)
  1037. #define MCF_SDRAMC_SDCR_MODE_EN (0x80000000)
  1038. #define MCF_SDRAMC_SDCR_PS_16 (0x00002000)
  1039. #define MCF_SDRAMC_SDCR_PS_32 (0x00000000)
  1040. /* Bit definitions and macros for MCF_SDRAMC_SDCFG1 */
  1041. #define MCF_SDRAMC_SDCFG1_WTLAT(x) (((x)&0x00000007)<<4)
  1042. #define MCF_SDRAMC_SDCFG1_REF2ACT(x) (((x)&0x0000000F)<<8)
  1043. #define MCF_SDRAMC_SDCFG1_PRE2ACT(x) (((x)&0x00000007)<<12)
  1044. #define MCF_SDRAMC_SDCFG1_ACT2RW(x) (((x)&0x00000007)<<16)
  1045. #define MCF_SDRAMC_SDCFG1_RDLAT(x) (((x)&0x0000000F)<<20)
  1046. #define MCF_SDRAMC_SDCFG1_SWT2RD(x) (((x)&0x00000007)<<24)
  1047. #define MCF_SDRAMC_SDCFG1_SRD2RW(x) (((x)&0x0000000F)<<28)
  1048. /* Bit definitions and macros for MCF_SDRAMC_SDCFG2 */
  1049. #define MCF_SDRAMC_SDCFG2_BL(x) (((x)&0x0000000F)<<16)
  1050. #define MCF_SDRAMC_SDCFG2_BRD2WT(x) (((x)&0x0000000F)<<20)
  1051. #define MCF_SDRAMC_SDCFG2_BWT2RW(x) (((x)&0x0000000F)<<24)
  1052. #define MCF_SDRAMC_SDCFG2_BRD2PRE(x) (((x)&0x0000000F)<<28)
  1053. /* Device Errata - LIMP mode work around */
  1054. #define MCF_SDRAMC_REFRESH (0x40000000)
  1055. /* Bit definitions and macros for MCF_SDRAMC_SDDS */
  1056. #define MCF_SDRAMC_SDDS_SB_D(x) (((x)&0x00000003)<<0)
  1057. #define MCF_SDRAMC_SDDS_SB_S(x) (((x)&0x00000003)<<2)
  1058. #define MCF_SDRAMC_SDDS_SB_A(x) (((x)&0x00000003)<<4)
  1059. #define MCF_SDRAMC_SDDS_SB_C(x) (((x)&0x00000003)<<6)
  1060. #define MCF_SDRAMC_SDDS_SB_E(x) (((x)&0x00000003)<<8)
  1061. /* Bit definitions and macros for MCF_SDRAMC_SDCS */
  1062. #define MCF_SDRAMC_SDCS_CSSZ(x) (((x)&0x0000001F)<<0)
  1063. #define MCF_SDRAMC_SDCS_BASE(x) (((x)&0x00000FFF)<<20)
  1064. #define MCF_SDRAMC_SDCS_BA(x) ((x)&0xFFF00000)
  1065. #define MCF_SDRAMC_SDCS_CSSZ_DIABLE (0x00000000)
  1066. #define MCF_SDRAMC_SDCS_CSSZ_1MBYTE (0x00000013)
  1067. #define MCF_SDRAMC_SDCS_CSSZ_2MBYTE (0x00000014)
  1068. #define MCF_SDRAMC_SDCS_CSSZ_4MBYTE (0x00000015)
  1069. #define MCF_SDRAMC_SDCS_CSSZ_8MBYTE (0x00000016)
  1070. #define MCF_SDRAMC_SDCS_CSSZ_16MBYTE (0x00000017)
  1071. #define MCF_SDRAMC_SDCS_CSSZ_32MBYTE (0x00000018)
  1072. #define MCF_SDRAMC_SDCS_CSSZ_64MBYTE (0x00000019)
  1073. #define MCF_SDRAMC_SDCS_CSSZ_128MBYTE (0x0000001A)
  1074. #define MCF_SDRAMC_SDCS_CSSZ_256MBYTE (0x0000001B)
  1075. #define MCF_SDRAMC_SDCS_CSSZ_512MBYTE (0x0000001C)
  1076. #define MCF_SDRAMC_SDCS_CSSZ_1GBYTE (0x0000001D)
  1077. #define MCF_SDRAMC_SDCS_CSSZ_2GBYTE (0x0000001E)
  1078. #define MCF_SDRAMC_SDCS_CSSZ_4GBYTE (0x0000001F)
  1079. /*
  1080. * Edge Port Module (EPORT)
  1081. */
  1082. #define MCFEPORT_EPPAR (0xFC094000)
  1083. #define MCFEPORT_EPDDR (0xFC094002)
  1084. #define MCFEPORT_EPIER (0xFC094003)
  1085. #define MCFEPORT_EPDR (0xFC094004)
  1086. #define MCFEPORT_EPPDR (0xFC094005)
  1087. #define MCFEPORT_EPFR (0xFC094006)
  1088. /*
  1089. * I2C Module
  1090. */
  1091. #define MCFI2C_BASE0 (0xFc058000)
  1092. #define MCFI2C_SIZE0 0x40
  1093. /********************************************************************/
  1094. #endif /* m53xxsim_h */