mx53loco.c 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479
  1. /*
  2. * Copyright (C) 2011 Freescale Semiconductor, Inc.
  3. * Jason Liu <r64343@freescale.com>
  4. *
  5. * See file CREDITS for list of people who contributed to this
  6. * project.
  7. *
  8. * This program is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU General Public License as
  10. * published by the Free Software Foundation; either version 2 of
  11. * the License, or (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program; if not, write to the Free Software
  20. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  21. * MA 02111-1307 USA
  22. */
  23. #include <common.h>
  24. #include <asm/io.h>
  25. #include <asm/arch/imx-regs.h>
  26. #include <asm/arch/mx5x_pins.h>
  27. #include <asm/arch/sys_proto.h>
  28. #include <asm/arch/crm_regs.h>
  29. #include <asm/arch/clock.h>
  30. #include <asm/arch/iomux.h>
  31. #include <asm/arch/clock.h>
  32. #include <asm/errno.h>
  33. #include <asm/imx-common/mx5_video.h>
  34. #include <netdev.h>
  35. #include <i2c.h>
  36. #include <mmc.h>
  37. #include <fsl_esdhc.h>
  38. #include <asm/gpio.h>
  39. #include <power/pmic.h>
  40. #include <dialog_pmic.h>
  41. #include <fsl_pmic.h>
  42. #include <linux/fb.h>
  43. #include <ipu_pixfmt.h>
  44. #define MX53LOCO_LCD_POWER IMX_GPIO_NR(3, 24)
  45. DECLARE_GLOBAL_DATA_PTR;
  46. int dram_init(void)
  47. {
  48. u32 size1, size2;
  49. size1 = get_ram_size((void *)PHYS_SDRAM_1, PHYS_SDRAM_1_SIZE);
  50. size2 = get_ram_size((void *)PHYS_SDRAM_2, PHYS_SDRAM_2_SIZE);
  51. gd->ram_size = size1 + size2;
  52. return 0;
  53. }
  54. void dram_init_banksize(void)
  55. {
  56. gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
  57. gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
  58. gd->bd->bi_dram[1].start = PHYS_SDRAM_2;
  59. gd->bd->bi_dram[1].size = PHYS_SDRAM_2_SIZE;
  60. }
  61. u32 get_board_rev(void)
  62. {
  63. struct iim_regs *iim = (struct iim_regs *)IMX_IIM_BASE;
  64. struct fuse_bank *bank = &iim->bank[0];
  65. struct fuse_bank0_regs *fuse =
  66. (struct fuse_bank0_regs *)bank->fuse_regs;
  67. int rev = readl(&fuse->gp[6]);
  68. if (!i2c_probe(CONFIG_SYS_DIALOG_PMIC_I2C_ADDR))
  69. rev = 0;
  70. return (get_cpu_rev() & ~(0xF << 8)) | (rev & 0xF) << 8;
  71. }
  72. static void setup_iomux_uart(void)
  73. {
  74. /* UART1 RXD */
  75. mxc_request_iomux(MX53_PIN_CSI0_D11, IOMUX_CONFIG_ALT2);
  76. mxc_iomux_set_pad(MX53_PIN_CSI0_D11,
  77. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  78. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  79. PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
  80. PAD_CTL_ODE_OPENDRAIN_ENABLE);
  81. mxc_iomux_set_input(MX53_UART1_IPP_UART_RXD_MUX_SELECT_INPUT, 0x1);
  82. /* UART1 TXD */
  83. mxc_request_iomux(MX53_PIN_CSI0_D10, IOMUX_CONFIG_ALT2);
  84. mxc_iomux_set_pad(MX53_PIN_CSI0_D10,
  85. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  86. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  87. PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
  88. PAD_CTL_ODE_OPENDRAIN_ENABLE);
  89. }
  90. #ifdef CONFIG_USB_EHCI_MX5
  91. int board_ehci_hcd_init(int port)
  92. {
  93. /* request VBUS power enable pin, GPIO7_8 */
  94. mxc_request_iomux(MX53_PIN_ATA_DA_2, IOMUX_CONFIG_ALT1);
  95. gpio_direction_output(IOMUX_TO_GPIO(MX53_PIN_ATA_DA_2), 1);
  96. return 0;
  97. }
  98. #endif
  99. static void setup_iomux_fec(void)
  100. {
  101. /*FEC_MDIO*/
  102. mxc_request_iomux(MX53_PIN_FEC_MDIO, IOMUX_CONFIG_ALT0);
  103. mxc_iomux_set_pad(MX53_PIN_FEC_MDIO,
  104. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  105. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  106. PAD_CTL_22K_PU | PAD_CTL_ODE_OPENDRAIN_ENABLE);
  107. mxc_iomux_set_input(MX53_FEC_FEC_MDI_SELECT_INPUT, 0x1);
  108. /*FEC_MDC*/
  109. mxc_request_iomux(MX53_PIN_FEC_MDC, IOMUX_CONFIG_ALT0);
  110. mxc_iomux_set_pad(MX53_PIN_FEC_MDC, PAD_CTL_DRV_HIGH);
  111. /* FEC RXD1 */
  112. mxc_request_iomux(MX53_PIN_FEC_RXD1, IOMUX_CONFIG_ALT0);
  113. mxc_iomux_set_pad(MX53_PIN_FEC_RXD1,
  114. PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
  115. /* FEC RXD0 */
  116. mxc_request_iomux(MX53_PIN_FEC_RXD0, IOMUX_CONFIG_ALT0);
  117. mxc_iomux_set_pad(MX53_PIN_FEC_RXD0,
  118. PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
  119. /* FEC TXD1 */
  120. mxc_request_iomux(MX53_PIN_FEC_TXD1, IOMUX_CONFIG_ALT0);
  121. mxc_iomux_set_pad(MX53_PIN_FEC_TXD1, PAD_CTL_DRV_HIGH);
  122. /* FEC TXD0 */
  123. mxc_request_iomux(MX53_PIN_FEC_TXD0, IOMUX_CONFIG_ALT0);
  124. mxc_iomux_set_pad(MX53_PIN_FEC_TXD0, PAD_CTL_DRV_HIGH);
  125. /* FEC TX_EN */
  126. mxc_request_iomux(MX53_PIN_FEC_TX_EN, IOMUX_CONFIG_ALT0);
  127. mxc_iomux_set_pad(MX53_PIN_FEC_TX_EN, PAD_CTL_DRV_HIGH);
  128. /* FEC TX_CLK */
  129. mxc_request_iomux(MX53_PIN_FEC_REF_CLK, IOMUX_CONFIG_ALT0);
  130. mxc_iomux_set_pad(MX53_PIN_FEC_REF_CLK,
  131. PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
  132. /* FEC RX_ER */
  133. mxc_request_iomux(MX53_PIN_FEC_RX_ER, IOMUX_CONFIG_ALT0);
  134. mxc_iomux_set_pad(MX53_PIN_FEC_RX_ER,
  135. PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
  136. /* FEC CRS */
  137. mxc_request_iomux(MX53_PIN_FEC_CRS_DV, IOMUX_CONFIG_ALT0);
  138. mxc_iomux_set_pad(MX53_PIN_FEC_CRS_DV,
  139. PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
  140. }
  141. #ifdef CONFIG_FSL_ESDHC
  142. struct fsl_esdhc_cfg esdhc_cfg[2] = {
  143. {MMC_SDHC1_BASE_ADDR},
  144. {MMC_SDHC3_BASE_ADDR},
  145. };
  146. int board_mmc_getcd(struct mmc *mmc)
  147. {
  148. struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
  149. int ret;
  150. mxc_request_iomux(MX53_PIN_EIM_DA11, IOMUX_CONFIG_ALT1);
  151. gpio_direction_input(IMX_GPIO_NR(3, 11));
  152. mxc_request_iomux(MX53_PIN_EIM_DA13, IOMUX_CONFIG_ALT1);
  153. gpio_direction_input(IMX_GPIO_NR(3, 13));
  154. if (cfg->esdhc_base == MMC_SDHC1_BASE_ADDR)
  155. ret = !gpio_get_value(IMX_GPIO_NR(3, 13));
  156. else
  157. ret = !gpio_get_value(IMX_GPIO_NR(3, 11));
  158. return ret;
  159. }
  160. int board_mmc_init(bd_t *bis)
  161. {
  162. u32 index;
  163. s32 status = 0;
  164. esdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
  165. esdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK);
  166. for (index = 0; index < CONFIG_SYS_FSL_ESDHC_NUM; index++) {
  167. switch (index) {
  168. case 0:
  169. mxc_request_iomux(MX53_PIN_SD1_CMD, IOMUX_CONFIG_ALT0);
  170. mxc_request_iomux(MX53_PIN_SD1_CLK, IOMUX_CONFIG_ALT0);
  171. mxc_request_iomux(MX53_PIN_SD1_DATA0,
  172. IOMUX_CONFIG_ALT0);
  173. mxc_request_iomux(MX53_PIN_SD1_DATA1,
  174. IOMUX_CONFIG_ALT0);
  175. mxc_request_iomux(MX53_PIN_SD1_DATA2,
  176. IOMUX_CONFIG_ALT0);
  177. mxc_request_iomux(MX53_PIN_SD1_DATA3,
  178. IOMUX_CONFIG_ALT0);
  179. mxc_request_iomux(MX53_PIN_EIM_DA13,
  180. IOMUX_CONFIG_ALT1);
  181. mxc_iomux_set_pad(MX53_PIN_SD1_CMD,
  182. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  183. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  184. PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
  185. mxc_iomux_set_pad(MX53_PIN_SD1_CLK,
  186. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  187. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
  188. PAD_CTL_DRV_HIGH);
  189. mxc_iomux_set_pad(MX53_PIN_SD1_DATA0,
  190. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  191. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  192. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  193. mxc_iomux_set_pad(MX53_PIN_SD1_DATA1,
  194. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  195. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  196. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  197. mxc_iomux_set_pad(MX53_PIN_SD1_DATA2,
  198. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  199. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  200. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  201. mxc_iomux_set_pad(MX53_PIN_SD1_DATA3,
  202. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  203. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  204. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  205. break;
  206. case 1:
  207. mxc_request_iomux(MX53_PIN_ATA_RESET_B,
  208. IOMUX_CONFIG_ALT2);
  209. mxc_request_iomux(MX53_PIN_ATA_IORDY,
  210. IOMUX_CONFIG_ALT2);
  211. mxc_request_iomux(MX53_PIN_ATA_DATA8,
  212. IOMUX_CONFIG_ALT4);
  213. mxc_request_iomux(MX53_PIN_ATA_DATA9,
  214. IOMUX_CONFIG_ALT4);
  215. mxc_request_iomux(MX53_PIN_ATA_DATA10,
  216. IOMUX_CONFIG_ALT4);
  217. mxc_request_iomux(MX53_PIN_ATA_DATA11,
  218. IOMUX_CONFIG_ALT4);
  219. mxc_request_iomux(MX53_PIN_ATA_DATA0,
  220. IOMUX_CONFIG_ALT4);
  221. mxc_request_iomux(MX53_PIN_ATA_DATA1,
  222. IOMUX_CONFIG_ALT4);
  223. mxc_request_iomux(MX53_PIN_ATA_DATA2,
  224. IOMUX_CONFIG_ALT4);
  225. mxc_request_iomux(MX53_PIN_ATA_DATA3,
  226. IOMUX_CONFIG_ALT4);
  227. mxc_request_iomux(MX53_PIN_EIM_DA11,
  228. IOMUX_CONFIG_ALT1);
  229. mxc_iomux_set_pad(MX53_PIN_ATA_RESET_B,
  230. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  231. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  232. PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
  233. mxc_iomux_set_pad(MX53_PIN_ATA_IORDY,
  234. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  235. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
  236. PAD_CTL_DRV_HIGH);
  237. mxc_iomux_set_pad(MX53_PIN_ATA_DATA8,
  238. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  239. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  240. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  241. mxc_iomux_set_pad(MX53_PIN_ATA_DATA9,
  242. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  243. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  244. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  245. mxc_iomux_set_pad(MX53_PIN_ATA_DATA10,
  246. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  247. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  248. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  249. mxc_iomux_set_pad(MX53_PIN_ATA_DATA11,
  250. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  251. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  252. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  253. mxc_iomux_set_pad(MX53_PIN_ATA_DATA0,
  254. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  255. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  256. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  257. mxc_iomux_set_pad(MX53_PIN_ATA_DATA1,
  258. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  259. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  260. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  261. mxc_iomux_set_pad(MX53_PIN_ATA_DATA2,
  262. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  263. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  264. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  265. mxc_iomux_set_pad(MX53_PIN_ATA_DATA3,
  266. PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
  267. PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
  268. PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
  269. break;
  270. default:
  271. printf("Warning: you configured more ESDHC controller"
  272. "(%d) as supported by the board(2)\n",
  273. CONFIG_SYS_FSL_ESDHC_NUM);
  274. return status;
  275. }
  276. status |= fsl_esdhc_initialize(bis, &esdhc_cfg[index]);
  277. }
  278. return status;
  279. }
  280. #endif
  281. static void setup_iomux_i2c(void)
  282. {
  283. /* I2C1 SDA */
  284. mxc_request_iomux(MX53_PIN_CSI0_D8,
  285. IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
  286. mxc_iomux_set_input(MX53_I2C1_IPP_SDA_IN_SELECT_INPUT,
  287. INPUT_CTL_PATH0);
  288. mxc_iomux_set_pad(MX53_PIN_CSI0_D8,
  289. PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
  290. PAD_CTL_100K_PU | PAD_CTL_PKE_ENABLE |
  291. PAD_CTL_PUE_PULL |
  292. PAD_CTL_ODE_OPENDRAIN_ENABLE);
  293. /* I2C1 SCL */
  294. mxc_request_iomux(MX53_PIN_CSI0_D9,
  295. IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
  296. mxc_iomux_set_input(MX53_I2C1_IPP_SCL_IN_SELECT_INPUT,
  297. INPUT_CTL_PATH0);
  298. mxc_iomux_set_pad(MX53_PIN_CSI0_D9,
  299. PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
  300. PAD_CTL_100K_PU | PAD_CTL_PKE_ENABLE |
  301. PAD_CTL_PUE_PULL |
  302. PAD_CTL_ODE_OPENDRAIN_ENABLE);
  303. }
  304. static int power_init(void)
  305. {
  306. unsigned int val;
  307. int ret = -1;
  308. struct pmic *p;
  309. int retval;
  310. if (!i2c_probe(CONFIG_SYS_DIALOG_PMIC_I2C_ADDR)) {
  311. retval = pmic_dialog_init(I2C_PMIC);
  312. if (retval)
  313. return retval;
  314. p = pmic_get("DIALOG_PMIC");
  315. if (!p)
  316. return -ENODEV;
  317. /* Set VDDA to 1.25V */
  318. val = DA9052_BUCKCORE_BCOREEN | DA_BUCKCORE_VBCORE_1_250V;
  319. ret = pmic_reg_write(p, DA9053_BUCKCORE_REG, val);
  320. ret |= pmic_reg_read(p, DA9053_SUPPLY_REG, &val);
  321. val |= DA9052_SUPPLY_VBCOREGO;
  322. ret |= pmic_reg_write(p, DA9053_SUPPLY_REG, val);
  323. /* Set Vcc peripheral to 1.30V */
  324. ret |= pmic_reg_write(p, DA9053_BUCKPRO_REG, 0x62);
  325. ret |= pmic_reg_write(p, DA9053_SUPPLY_REG, 0x62);
  326. }
  327. if (!i2c_probe(CONFIG_SYS_FSL_PMIC_I2C_ADDR)) {
  328. retval = pmic_init(I2C_PMIC);
  329. if (retval)
  330. return retval;
  331. p = pmic_get("DIALOG_PMIC");
  332. if (!p)
  333. return -ENODEV;
  334. /* Set VDDGP to 1.25V for 1GHz on SW1 */
  335. pmic_reg_read(p, REG_SW_0, &val);
  336. val = (val & ~SWx_VOLT_MASK_MC34708) | SWx_1_250V_MC34708;
  337. ret = pmic_reg_write(p, REG_SW_0, val);
  338. /* Set VCC as 1.30V on SW2 */
  339. pmic_reg_read(p, REG_SW_1, &val);
  340. val = (val & ~SWx_VOLT_MASK_MC34708) | SWx_1_300V_MC34708;
  341. ret |= pmic_reg_write(p, REG_SW_1, val);
  342. /* Set global reset timer to 4s */
  343. pmic_reg_read(p, REG_POWER_CTL2, &val);
  344. val = (val & ~TIMER_MASK_MC34708) | TIMER_4S_MC34708;
  345. ret |= pmic_reg_write(p, REG_POWER_CTL2, val);
  346. /* Set VUSBSEL and VUSBEN for USB PHY supply*/
  347. pmic_reg_read(p, REG_MODE_0, &val);
  348. val |= (VUSBSEL_MC34708 | VUSBEN_MC34708);
  349. ret |= pmic_reg_write(p, REG_MODE_0, val);
  350. /* Set SWBST to 5V in auto mode */
  351. val = SWBST_AUTO;
  352. ret |= pmic_reg_write(p, SWBST_CTRL, val);
  353. }
  354. return ret;
  355. }
  356. static void clock_1GHz(void)
  357. {
  358. int ret;
  359. u32 ref_clk = MXC_HCLK;
  360. /*
  361. * After increasing voltage to 1.25V, we can switch
  362. * CPU clock to 1GHz and DDR to 400MHz safely
  363. */
  364. ret = mxc_set_clock(ref_clk, 1000, MXC_ARM_CLK);
  365. if (ret)
  366. printf("CPU: Switch CPU clock to 1GHZ failed\n");
  367. ret = mxc_set_clock(ref_clk, 400, MXC_PERIPH_CLK);
  368. ret |= mxc_set_clock(ref_clk, 400, MXC_DDR_CLK);
  369. if (ret)
  370. printf("CPU: Switch DDR clock to 400MHz failed\n");
  371. }
  372. int board_early_init_f(void)
  373. {
  374. setup_iomux_uart();
  375. setup_iomux_fec();
  376. setup_iomux_lcd();
  377. return 0;
  378. }
  379. int print_cpuinfo(void)
  380. {
  381. u32 cpurev;
  382. cpurev = get_cpu_rev();
  383. printf("CPU: Freescale i.MX%x family rev%d.%d at %d MHz\n",
  384. (cpurev & 0xFF000) >> 12,
  385. (cpurev & 0x000F0) >> 4,
  386. (cpurev & 0x0000F) >> 0,
  387. mxc_get_clock(MXC_ARM_CLK) / 1000000);
  388. printf("Reset cause: %s\n", get_reset_cause());
  389. return 0;
  390. }
  391. /*
  392. * Do not overwrite the console
  393. * Use always serial for U-Boot console
  394. */
  395. int overwrite_console(void)
  396. {
  397. return 1;
  398. }
  399. int board_init(void)
  400. {
  401. gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
  402. mxc_set_sata_internal_clock();
  403. setup_iomux_i2c();
  404. if (!power_init())
  405. clock_1GHz();
  406. print_cpuinfo();
  407. lcd_enable();
  408. return 0;
  409. }
  410. int checkboard(void)
  411. {
  412. puts("Board: MX53 LOCO\n");
  413. return 0;
  414. }