cpu_init.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552
  1. /*
  2. * (C) Copyright 2003
  3. * Josef Baumgartner <josef.baumgartner@telex.de>
  4. *
  5. * MCF5282 additionals
  6. * (C) Copyright 2005
  7. * BuS Elektronik GmbH & Co. KG <esw@bus-elektronik.de>
  8. *
  9. * Copyright (C) 2004-2007 Freescale Semiconductor, Inc.
  10. * TsiChung Liew (Tsi-Chung.Liew@freescale.com)
  11. * Hayden Fraser (Hayden.Fraser@freescale.com)
  12. *
  13. * See file CREDITS for list of people who contributed to this
  14. * project.
  15. *
  16. * This program is free software; you can redistribute it and/or
  17. * modify it under the terms of the GNU General Public License as
  18. * published by the Free Software Foundation; either version 2 of
  19. * the License, or (at your option) any later version.
  20. *
  21. * This program is distributed in the hope that it will be useful,
  22. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  23. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  24. * GNU General Public License for more details.
  25. *
  26. * You should have received a copy of the GNU General Public License
  27. * along with this program; if not, write to the Free Software
  28. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  29. * MA 02111-1307 USA
  30. */
  31. #include <common.h>
  32. #include <watchdog.h>
  33. #include <asm/immap.h>
  34. #if defined(CONFIG_M5253)
  35. /*
  36. * Breath some life into the CPU...
  37. *
  38. * Set up the memory map,
  39. * initialize a bunch of registers,
  40. * initialize the UPM's
  41. */
  42. void cpu_init_f(void)
  43. {
  44. mbar_writeByte(MCFSIM_MPARK, 0x40); /* 5249 Internal Core takes priority over DMA */
  45. mbar_writeByte(MCFSIM_SYPCR, 0x00);
  46. mbar_writeByte(MCFSIM_SWIVR, 0x0f);
  47. mbar_writeByte(MCFSIM_SWSR, 0x00);
  48. mbar_writeByte(MCFSIM_SWDICR, 0x00);
  49. mbar_writeByte(MCFSIM_TIMER1ICR, 0x00);
  50. mbar_writeByte(MCFSIM_TIMER2ICR, 0x88);
  51. mbar_writeByte(MCFSIM_I2CICR, 0x00);
  52. mbar_writeByte(MCFSIM_UART1ICR, 0x00);
  53. mbar_writeByte(MCFSIM_UART2ICR, 0x00);
  54. mbar_writeByte(MCFSIM_ICR6, 0x00);
  55. mbar_writeByte(MCFSIM_ICR7, 0x00);
  56. mbar_writeByte(MCFSIM_ICR8, 0x00);
  57. mbar_writeByte(MCFSIM_ICR9, 0x00);
  58. mbar_writeByte(MCFSIM_QSPIICR, 0x00);
  59. mbar2_writeLong(MCFSIM_GPIO_INT_EN, 0x00000080);
  60. mbar2_writeByte(MCFSIM_INTBASE, 0x40); /* Base interrupts at 64 */
  61. mbar2_writeByte(MCFSIM_SPURVEC, 0x00);
  62. /*mbar2_writeLong(MCFSIM_IDECONFIG1, 0x00000020); */ /* Enable a 1 cycle pre-drive cycle on CS1 */
  63. /*
  64. * Setup chip selects...
  65. */
  66. mbar_writeShort(MCFSIM_CSAR1, CFG_CSAR1);
  67. mbar_writeShort(MCFSIM_CSCR1, CFG_CSCR1);
  68. mbar_writeLong(MCFSIM_CSMR1, CFG_CSMR1);
  69. mbar_writeShort(MCFSIM_CSAR0, CFG_CSAR0);
  70. mbar_writeShort(MCFSIM_CSCR0, CFG_CSCR0);
  71. mbar_writeLong(MCFSIM_CSMR0, CFG_CSMR0);
  72. /* enable instruction cache now */
  73. icache_enable();
  74. }
  75. /*initialize higher level parts of CPU like timers */
  76. int cpu_init_r(void)
  77. {
  78. return (0);
  79. }
  80. void uart_port_conf(void)
  81. {
  82. /* Setup Ports: */
  83. switch (CFG_UART_PORT) {
  84. case 0:
  85. break;
  86. case 1:
  87. break;
  88. case 2:
  89. break;
  90. }
  91. }
  92. #endif /* #if defined(CONFIG_M5253) */
  93. #if defined(CONFIG_M5271)
  94. void cpu_init_f(void)
  95. {
  96. #ifndef CONFIG_WATCHDOG
  97. /* Disable the watchdog if we aren't using it */
  98. mbar_writeShort(MCF_WTM_WCR, 0);
  99. #endif
  100. /* Set clockspeed to 100MHz */
  101. mbar_writeShort(MCF_FMPLL_SYNCR,
  102. MCF_FMPLL_SYNCR_MFD(0) | MCF_FMPLL_SYNCR_RFD(0));
  103. while (!mbar_readByte(MCF_FMPLL_SYNSR) & MCF_FMPLL_SYNSR_LOCK) ;
  104. }
  105. /*
  106. * initialize higher level parts of CPU like timers
  107. */
  108. int cpu_init_r(void)
  109. {
  110. return (0);
  111. }
  112. void uart_port_conf(void)
  113. {
  114. /* Setup Ports: */
  115. switch (CFG_UART_PORT) {
  116. case 0:
  117. mbar_writeShort(MCF_GPIO_PAR_UART, MCF_GPIO_PAR_UART_U0TXD |
  118. MCF_GPIO_PAR_UART_U0RXD);
  119. break;
  120. case 1:
  121. mbar_writeShort(MCF_GPIO_PAR_UART,
  122. MCF_GPIO_PAR_UART_U1RXD_UART1 |
  123. MCF_GPIO_PAR_UART_U1TXD_UART1);
  124. break;
  125. case 2:
  126. mbar_writeShort(MCF_GPIO_PAR_UART, 0x3000);
  127. break;
  128. }
  129. }
  130. #endif
  131. #if defined(CONFIG_M5272)
  132. /*
  133. * Breath some life into the CPU...
  134. *
  135. * Set up the memory map,
  136. * initialize a bunch of registers,
  137. * initialize the UPM's
  138. */
  139. void cpu_init_f(void)
  140. {
  141. /* if we come from RAM we assume the CPU is
  142. * already initialized.
  143. */
  144. #ifndef CONFIG_MONITOR_IS_IN_RAM
  145. volatile sysctrl_t *sysctrl = (sysctrl_t *) (CFG_MBAR);
  146. volatile gpio_t *gpio = (gpio_t *) (MMAP_GPIO);
  147. volatile csctrl_t *csctrl = (csctrl_t *) (MMAP_FBCS);
  148. sysctrl->sc_scr = CFG_SCR;
  149. sysctrl->sc_spr = CFG_SPR;
  150. /* Setup Ports: */
  151. gpio->gpio_pacnt = CFG_PACNT;
  152. gpio->gpio_paddr = CFG_PADDR;
  153. gpio->gpio_padat = CFG_PADAT;
  154. gpio->gpio_pbcnt = CFG_PBCNT;
  155. gpio->gpio_pbddr = CFG_PBDDR;
  156. gpio->gpio_pbdat = CFG_PBDAT;
  157. gpio->gpio_pdcnt = CFG_PDCNT;
  158. /* Memory Controller: */
  159. csctrl->cs_br0 = CFG_BR0_PRELIM;
  160. csctrl->cs_or0 = CFG_OR0_PRELIM;
  161. #if (defined(CFG_OR1_PRELIM) && defined(CFG_BR1_PRELIM))
  162. csctrl->cs_br1 = CFG_BR1_PRELIM;
  163. csctrl->cs_or1 = CFG_OR1_PRELIM;
  164. #endif
  165. #if defined(CFG_OR2_PRELIM) && defined(CFG_BR2_PRELIM)
  166. csctrl->cs_br2 = CFG_BR2_PRELIM;
  167. csctrl->cs_or2 = CFG_OR2_PRELIM;
  168. #endif
  169. #if defined(CFG_OR3_PRELIM) && defined(CFG_BR3_PRELIM)
  170. csctrl->cs_br3 = CFG_BR3_PRELIM;
  171. csctrl->cs_or3 = CFG_OR3_PRELIM;
  172. #endif
  173. #if defined(CFG_OR4_PRELIM) && defined(CFG_BR4_PRELIM)
  174. csctrl->cs_br4 = CFG_BR4_PRELIM;
  175. csctrl->cs_or4 = CFG_OR4_PRELIM;
  176. #endif
  177. #if defined(CFG_OR5_PRELIM) && defined(CFG_BR5_PRELIM)
  178. csctrl->cs_br5 = CFG_BR5_PRELIM;
  179. csctrl->cs_or5 = CFG_OR5_PRELIM;
  180. #endif
  181. #if defined(CFG_OR6_PRELIM) && defined(CFG_BR6_PRELIM)
  182. csctrl->cs_br6 = CFG_BR6_PRELIM;
  183. csctrl->cs_or6 = CFG_OR6_PRELIM;
  184. #endif
  185. #if defined(CFG_OR7_PRELIM) && defined(CFG_BR7_PRELIM)
  186. csctrl->cs_br7 = CFG_BR7_PRELIM;
  187. csctrl->cs_or7 = CFG_OR7_PRELIM;
  188. #endif
  189. #endif /* #ifndef CONFIG_MONITOR_IS_IN_RAM */
  190. /* enable instruction cache now */
  191. icache_enable();
  192. }
  193. /*
  194. * initialize higher level parts of CPU like timers
  195. */
  196. int cpu_init_r(void)
  197. {
  198. return (0);
  199. }
  200. void uart_port_conf(void)
  201. {
  202. volatile gpio_t *gpio = (gpio_t *) MMAP_GPIO;
  203. /* Setup Ports: */
  204. switch (CFG_UART_PORT) {
  205. case 0:
  206. gpio->gpio_pbcnt &= ~(GPIO_PBCNT_PB0MSK | GPIO_PBCNT_PB1MSK);
  207. gpio->gpio_pbcnt |= (GPIO_PBCNT_URT0_TXD | GPIO_PBCNT_URT0_RXD);
  208. break;
  209. case 1:
  210. gpio->gpio_pdcnt &= ~(GPIO_PDCNT_PD1MSK | GPIO_PDCNT_PD4MSK);
  211. gpio->gpio_pdcnt |= (GPIO_PDCNT_URT1_RXD | GPIO_PDCNT_URT1_TXD);
  212. break;
  213. }
  214. }
  215. #endif /* #if defined(CONFIG_M5272) */
  216. #if defined(CONFIG_M5282)
  217. /*
  218. * Breath some life into the CPU...
  219. *
  220. * Set up the memory map,
  221. * initialize a bunch of registers,
  222. * initialize the UPM's
  223. */
  224. void cpu_init_f(void)
  225. {
  226. #ifndef CONFIG_WATCHDOG
  227. /* disable watchdog if we aren't using it */
  228. MCFWTM_WCR = 0;
  229. #endif
  230. #ifndef CONFIG_MONITOR_IS_IN_RAM
  231. /* Set speed /PLL */
  232. MCFCLOCK_SYNCR =
  233. MCFCLOCK_SYNCR_MFD(CFG_MFD) | MCFCLOCK_SYNCR_RFD(CFG_RFD);
  234. while (!(MCFCLOCK_SYNSR & MCFCLOCK_SYNSR_LOCK)) ;
  235. MCFGPIO_PBCDPAR = 0xc0;
  236. /* Set up the GPIO ports */
  237. #ifdef CFG_PEPAR
  238. MCFGPIO_PEPAR = CFG_PEPAR;
  239. #endif
  240. #ifdef CFG_PFPAR
  241. MCFGPIO_PFPAR = CFG_PFPAR;
  242. #endif
  243. #ifdef CFG_PJPAR
  244. MCFGPIO_PJPAR = CFG_PJPAR;
  245. #endif
  246. #ifdef CFG_PSDPAR
  247. MCFGPIO_PSDPAR = CFG_PSDPAR;
  248. #endif
  249. #ifdef CFG_PASPAR
  250. MCFGPIO_PASPAR = CFG_PASPAR;
  251. #endif
  252. #ifdef CFG_PEHLPAR
  253. MCFGPIO_PEHLPAR = CFG_PEHLPAR;
  254. #endif
  255. #ifdef CFG_PQSPAR
  256. MCFGPIO_PQSPAR = CFG_PQSPAR;
  257. #endif
  258. #ifdef CFG_PTCPAR
  259. MCFGPIO_PTCPAR = CFG_PTCPAR;
  260. #endif
  261. #ifdef CFG_PTDPAR
  262. MCFGPIO_PTDPAR = CFG_PTDPAR;
  263. #endif
  264. #ifdef CFG_PUAPAR
  265. MCFGPIO_PUAPAR = CFG_PUAPAR;
  266. #endif
  267. #ifdef CFG_DDRUA
  268. MCFGPIO_DDRUA = CFG_DDRUA;
  269. #endif
  270. /* This is probably a bad place to setup chip selects, but everyone
  271. else is doing it! */
  272. #if defined(CFG_CS0_BASE) & defined(CFG_CS0_SIZE) & \
  273. defined(CFG_CS0_WIDTH) & defined(CFG_CS0_RO) & \
  274. defined(CFG_CS0_WS)
  275. MCFCSM_CSAR0 = (CFG_CS0_BASE >> 16) & 0xFFFF;
  276. #if (CFG_CS0_WIDTH == 8)
  277. #define CFG_CS0_PS MCFCSM_CSCR_PS_8
  278. #elif (CFG_CS0_WIDTH == 16)
  279. #define CFG_CS0_PS MCFCSM_CSCR_PS_16
  280. #elif (CFG_CS0_WIDTH == 32)
  281. #define CFG_CS0_PS MCFCSM_CSCR_PS_32
  282. #else
  283. #error "CFG_CS0_WIDTH: Fault - wrong bus with for CS0"
  284. #endif
  285. MCFCSM_CSCR0 = MCFCSM_CSCR_WS(CFG_CS0_WS)
  286. | CFG_CS0_PS | MCFCSM_CSCR_AA;
  287. #if (CFG_CS0_RO != 0)
  288. MCFCSM_CSMR0 = MCFCSM_CSMR_BAM(CFG_CS0_SIZE - 1)
  289. | MCFCSM_CSMR_WP | MCFCSM_CSMR_V;
  290. #else
  291. MCFCSM_CSMR0 = MCFCSM_CSMR_BAM(CFG_CS0_SIZE - 1) | MCFCSM_CSMR_V;
  292. #endif
  293. #else
  294. #waring "Chip Select 0 are not initialized/used"
  295. #endif
  296. #if defined(CFG_CS1_BASE) & defined(CFG_CS1_SIZE) & \
  297. defined(CFG_CS1_WIDTH) & defined(CFG_CS1_RO) & \
  298. defined(CFG_CS1_WS)
  299. MCFCSM_CSAR1 = (CFG_CS1_BASE >> 16) & 0xFFFF;
  300. #if (CFG_CS1_WIDTH == 8)
  301. #define CFG_CS1_PS MCFCSM_CSCR_PS_8
  302. #elif (CFG_CS1_WIDTH == 16)
  303. #define CFG_CS1_PS MCFCSM_CSCR_PS_16
  304. #elif (CFG_CS1_WIDTH == 32)
  305. #define CFG_CS1_PS MCFCSM_CSCR_PS_32
  306. #else
  307. #error "CFG_CS1_WIDTH: Fault - wrong bus with for CS1"
  308. #endif
  309. MCFCSM_CSCR1 = MCFCSM_CSCR_WS(CFG_CS1_WS)
  310. | CFG_CS1_PS | MCFCSM_CSCR_AA;
  311. #if (CFG_CS1_RO != 0)
  312. MCFCSM_CSMR1 = MCFCSM_CSMR_BAM(CFG_CS1_SIZE - 1)
  313. | MCFCSM_CSMR_WP | MCFCSM_CSMR_V;
  314. #else
  315. MCFCSM_CSMR1 = MCFCSM_CSMR_BAM(CFG_CS1_SIZE - 1)
  316. | MCFCSM_CSMR_V;
  317. #endif
  318. #else
  319. #warning "Chip Select 1 are not initialized/used"
  320. #endif
  321. #if defined(CFG_CS2_BASE) & defined(CFG_CS2_SIZE) & \
  322. defined(CFG_CS2_WIDTH) & defined(CFG_CS2_RO) & \
  323. defined(CFG_CS2_WS)
  324. MCFCSM_CSAR2 = (CFG_CS2_BASE >> 16) & 0xFFFF;
  325. #if (CFG_CS2_WIDTH == 8)
  326. #define CFG_CS2_PS MCFCSM_CSCR_PS_8
  327. #elif (CFG_CS2_WIDTH == 16)
  328. #define CFG_CS2_PS MCFCSM_CSCR_PS_16
  329. #elif (CFG_CS2_WIDTH == 32)
  330. #define CFG_CS2_PS MCFCSM_CSCR_PS_32
  331. #else
  332. #error "CFG_CS2_WIDTH: Fault - wrong bus with for CS2"
  333. #endif
  334. MCFCSM_CSCR2 = MCFCSM_CSCR_WS(CFG_CS2_WS)
  335. | CFG_CS2_PS | MCFCSM_CSCR_AA;
  336. #if (CFG_CS2_RO != 0)
  337. MCFCSM_CSMR2 = MCFCSM_CSMR_BAM(CFG_CS2_SIZE - 1)
  338. | MCFCSM_CSMR_WP | MCFCSM_CSMR_V;
  339. #else
  340. MCFCSM_CSMR2 = MCFCSM_CSMR_BAM(CFG_CS2_SIZE - 1)
  341. | MCFCSM_CSMR_V;
  342. #endif
  343. #else
  344. #warning "Chip Select 2 are not initialized/used"
  345. #endif
  346. #if defined(CFG_CS3_BASE) & defined(CFG_CS3_SIZE) & \
  347. defined(CFG_CS3_WIDTH) & defined(CFG_CS3_RO) & \
  348. defined(CFG_CS3_WS)
  349. MCFCSM_CSAR3 = (CFG_CS3_BASE >> 16) & 0xFFFF;
  350. #if (CFG_CS3_WIDTH == 8)
  351. #define CFG_CS3_PS MCFCSM_CSCR_PS_8
  352. #elif (CFG_CS3_WIDTH == 16)
  353. #define CFG_CS3_PS MCFCSM_CSCR_PS_16
  354. #elif (CFG_CS3_WIDTH == 32)
  355. #define CFG_CS3_PS MCFCSM_CSCR_PS_32
  356. #else
  357. #error "CFG_CS3_WIDTH: Fault - wrong bus with for CS1"
  358. #endif
  359. MCFCSM_CSCR3 = MCFCSM_CSCR_WS(CFG_CS3_WS)
  360. | CFG_CS3_PS | MCFCSM_CSCR_AA;
  361. #if (CFG_CS3_RO != 0)
  362. MCFCSM_CSMR3 = MCFCSM_CSMR_BAM(CFG_CS3_SIZE - 1)
  363. | MCFCSM_CSMR_WP | MCFCSM_CSMR_V;
  364. #else
  365. MCFCSM_CSMR3 = MCFCSM_CSMR_BAM(CFG_CS3_SIZE - 1)
  366. | MCFCSM_CSMR_V;
  367. #endif
  368. #else
  369. #warning "Chip Select 3 are not initialized/used"
  370. #endif
  371. #endif /* CONFIG_MONITOR_IS_IN_RAM */
  372. /* defer enabling cache until boot (see do_go) */
  373. /* icache_enable(); */
  374. }
  375. /*
  376. * initialize higher level parts of CPU like timers
  377. */
  378. int cpu_init_r(void)
  379. {
  380. return (0);
  381. }
  382. void uart_port_conf(void)
  383. {
  384. /* Setup Ports: */
  385. switch (CFG_UART_PORT) {
  386. case 0:
  387. MCFGPIO_PUAPAR &= 0xFc;
  388. MCFGPIO_PUAPAR |= 0x03;
  389. break;
  390. case 1:
  391. MCFGPIO_PUAPAR &= 0xF3;
  392. MCFGPIO_PUAPAR |= 0x0C;
  393. break;
  394. case 2:
  395. MCFGPIO_PASPAR &= 0xFF0F;
  396. MCFGPIO_PASPAR |= 0x00A0;
  397. break;
  398. }
  399. }
  400. #endif
  401. #if defined(CONFIG_M5249)
  402. /*
  403. * Breath some life into the CPU...
  404. *
  405. * Set up the memory map,
  406. * initialize a bunch of registers,
  407. * initialize the UPM's
  408. */
  409. void cpu_init_f(void)
  410. {
  411. /*
  412. * NOTE: by setting the GPIO_FUNCTION registers, we ensure that the UART pins
  413. * (UART0: gpio 30,27, UART1: gpio 31, 28) will be used as UART pins
  414. * which is their primary function.
  415. * ~Jeremy
  416. */
  417. mbar2_writeLong(MCFSIM_GPIO_FUNC, CFG_GPIO_FUNC);
  418. mbar2_writeLong(MCFSIM_GPIO1_FUNC, CFG_GPIO1_FUNC);
  419. mbar2_writeLong(MCFSIM_GPIO_EN, CFG_GPIO_EN);
  420. mbar2_writeLong(MCFSIM_GPIO1_EN, CFG_GPIO1_EN);
  421. mbar2_writeLong(MCFSIM_GPIO_OUT, CFG_GPIO_OUT);
  422. mbar2_writeLong(MCFSIM_GPIO1_OUT, CFG_GPIO1_OUT);
  423. /*
  424. * dBug Compliance:
  425. * You can verify these values by using dBug's 'ird'
  426. * (Internal Register Display) command
  427. * ~Jeremy
  428. *
  429. */
  430. mbar_writeByte(MCFSIM_MPARK, 0x30); /* 5249 Internal Core takes priority over DMA */
  431. mbar_writeByte(MCFSIM_SYPCR, 0x00);
  432. mbar_writeByte(MCFSIM_SWIVR, 0x0f);
  433. mbar_writeByte(MCFSIM_SWSR, 0x00);
  434. mbar_writeLong(MCFSIM_IMR, 0xfffffbff);
  435. mbar_writeByte(MCFSIM_SWDICR, 0x00);
  436. mbar_writeByte(MCFSIM_TIMER1ICR, 0x00);
  437. mbar_writeByte(MCFSIM_TIMER2ICR, 0x88);
  438. mbar_writeByte(MCFSIM_I2CICR, 0x00);
  439. mbar_writeByte(MCFSIM_UART1ICR, 0x00);
  440. mbar_writeByte(MCFSIM_UART2ICR, 0x00);
  441. mbar_writeByte(MCFSIM_ICR6, 0x00);
  442. mbar_writeByte(MCFSIM_ICR7, 0x00);
  443. mbar_writeByte(MCFSIM_ICR8, 0x00);
  444. mbar_writeByte(MCFSIM_ICR9, 0x00);
  445. mbar_writeByte(MCFSIM_QSPIICR, 0x00);
  446. mbar2_writeLong(MCFSIM_GPIO_INT_EN, 0x00000080);
  447. mbar2_writeByte(MCFSIM_INTBASE, 0x40); /* Base interrupts at 64 */
  448. mbar2_writeByte(MCFSIM_SPURVEC, 0x00);
  449. mbar2_writeLong(MCFSIM_IDECONFIG1, 0x00000020); /* Enable a 1 cycle pre-drive cycle on CS1 */
  450. /* Setup interrupt priorities for gpio7 */
  451. /* mbar2_writeLong(MCFSIM_INTLEV5, 0x70000000); */
  452. /* IDE Config registers */
  453. mbar2_writeLong(MCFSIM_IDECONFIG1, 0x00000020);
  454. mbar2_writeLong(MCFSIM_IDECONFIG2, 0x00000000);
  455. /*
  456. * Setup chip selects...
  457. */
  458. mbar_writeShort(MCFSIM_CSAR1, CFG_CSAR1);
  459. mbar_writeShort(MCFSIM_CSCR1, CFG_CSCR1);
  460. mbar_writeLong(MCFSIM_CSMR1, CFG_CSMR1);
  461. mbar_writeShort(MCFSIM_CSAR0, CFG_CSAR0);
  462. mbar_writeShort(MCFSIM_CSCR0, CFG_CSCR0);
  463. mbar_writeLong(MCFSIM_CSMR0, CFG_CSMR0);
  464. /* enable instruction cache now */
  465. icache_enable();
  466. }
  467. /*
  468. * initialize higher level parts of CPU like timers
  469. */
  470. int cpu_init_r(void)
  471. {
  472. return (0);
  473. }
  474. void uart_port_conf(void)
  475. {
  476. /* Setup Ports: */
  477. switch (CFG_UART_PORT) {
  478. case 0:
  479. break;
  480. case 1:
  481. break;
  482. }
  483. }
  484. #endif /* #if defined(CONFIG_M5249) */