m53xxsim.h 54 KB

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