mx53ard.c 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329
  1. /*
  2. * (C) Copyright 2011 Freescale Semiconductor, Inc.
  3. *
  4. * See file CREDITS for list of people who contributed to this
  5. * project.
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation; either version 2 of
  10. * the License, or (at your option) any later version.
  11. *
  12. * This program is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  15. * GNU General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License
  18. * along with this program; if not, write to the Free Software
  19. * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
  20. * MA 02111-1307 USA
  21. */
  22. #include <common.h>
  23. #include <asm/io.h>
  24. #include <asm/arch/imx-regs.h>
  25. #include <asm/arch/sys_proto.h>
  26. #include <asm/arch/crm_regs.h>
  27. #include <asm/arch/clock.h>
  28. #include <asm/arch/iomux-mx53.h>
  29. #include <asm/errno.h>
  30. #include <netdev.h>
  31. #include <mmc.h>
  32. #include <fsl_esdhc.h>
  33. #include <asm/gpio.h>
  34. #define ETHERNET_INT IMX_GPIO_NR(2, 31)
  35. DECLARE_GLOBAL_DATA_PTR;
  36. int dram_init(void)
  37. {
  38. u32 size1, size2;
  39. size1 = get_ram_size((void *)PHYS_SDRAM_1, PHYS_SDRAM_1_SIZE);
  40. size2 = get_ram_size((void *)PHYS_SDRAM_2, PHYS_SDRAM_2_SIZE);
  41. gd->ram_size = size1 + size2;
  42. return 0;
  43. }
  44. void dram_init_banksize(void)
  45. {
  46. gd->bd->bi_dram[0].start = PHYS_SDRAM_1;
  47. gd->bd->bi_dram[0].size = PHYS_SDRAM_1_SIZE;
  48. gd->bd->bi_dram[1].start = PHYS_SDRAM_2;
  49. gd->bd->bi_dram[1].size = PHYS_SDRAM_2_SIZE;
  50. }
  51. #ifdef CONFIG_NAND_MXC
  52. static void setup_iomux_nand(void)
  53. {
  54. static const iomux_v3_cfg_t nand_pads[] = {
  55. NEW_PAD_CTRL(MX53_PAD_NANDF_CS0__EMI_NANDF_CS_0,
  56. PAD_CTL_DSE_HIGH),
  57. NEW_PAD_CTRL(MX53_PAD_NANDF_CS1__EMI_NANDF_CS_1,
  58. PAD_CTL_DSE_HIGH),
  59. NEW_PAD_CTRL(MX53_PAD_NANDF_RB0__EMI_NANDF_RB_0,
  60. PAD_CTL_PUS_100K_UP),
  61. NEW_PAD_CTRL(MX53_PAD_NANDF_CLE__EMI_NANDF_CLE,
  62. PAD_CTL_DSE_HIGH),
  63. NEW_PAD_CTRL(MX53_PAD_NANDF_ALE__EMI_NANDF_ALE,
  64. PAD_CTL_DSE_HIGH),
  65. NEW_PAD_CTRL(MX53_PAD_NANDF_WP_B__EMI_NANDF_WP_B,
  66. PAD_CTL_PUS_100K_UP),
  67. NEW_PAD_CTRL(MX53_PAD_NANDF_RE_B__EMI_NANDF_RE_B,
  68. PAD_CTL_DSE_HIGH),
  69. NEW_PAD_CTRL(MX53_PAD_NANDF_WE_B__EMI_NANDF_WE_B,
  70. PAD_CTL_DSE_HIGH),
  71. NEW_PAD_CTRL(MX53_PAD_EIM_DA0__EMI_NAND_WEIM_DA_0,
  72. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  73. NEW_PAD_CTRL(MX53_PAD_EIM_DA1__EMI_NAND_WEIM_DA_1,
  74. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  75. NEW_PAD_CTRL(MX53_PAD_EIM_DA2__EMI_NAND_WEIM_DA_2,
  76. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  77. NEW_PAD_CTRL(MX53_PAD_EIM_DA3__EMI_NAND_WEIM_DA_3,
  78. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  79. NEW_PAD_CTRL(MX53_PAD_EIM_DA4__EMI_NAND_WEIM_DA_4,
  80. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  81. NEW_PAD_CTRL(MX53_PAD_EIM_DA5__EMI_NAND_WEIM_DA_5,
  82. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  83. NEW_PAD_CTRL(MX53_PAD_EIM_DA6__EMI_NAND_WEIM_DA_6,
  84. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  85. NEW_PAD_CTRL(MX53_PAD_EIM_DA7__EMI_NAND_WEIM_DA_7,
  86. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  87. };
  88. u32 i, reg;
  89. reg = __raw_readl(M4IF_BASE_ADDR + 0xc);
  90. reg &= ~M4IF_GENP_WEIM_MM_MASK;
  91. __raw_writel(reg, M4IF_BASE_ADDR + 0xc);
  92. for (i = 0x4; i < 0x94; i += 0x18) {
  93. reg = __raw_readl(WEIM_BASE_ADDR + i);
  94. reg &= ~WEIM_GCR2_MUX16_BYP_GRANT_MASK;
  95. __raw_writel(reg, WEIM_BASE_ADDR + i);
  96. }
  97. imx_iomux_v3_setup_multiple_pads(nand_pads, ARRAY_SIZE(nand_pads));
  98. }
  99. #else
  100. static void setup_iomux_nand(void)
  101. {
  102. }
  103. #endif
  104. #define UART_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_DSE_HIGH | \
  105. PAD_CTL_PUS_100K_UP | PAD_CTL_ODE)
  106. static void setup_iomux_uart(void)
  107. {
  108. static const iomux_v3_cfg_t uart_pads[] = {
  109. NEW_PAD_CTRL(MX53_PAD_PATA_DMACK__UART1_RXD_MUX, UART_PAD_CTRL),
  110. NEW_PAD_CTRL(MX53_PAD_PATA_DIOW__UART1_TXD_MUX, UART_PAD_CTRL),
  111. };
  112. imx_iomux_v3_setup_multiple_pads(uart_pads, ARRAY_SIZE(uart_pads));
  113. }
  114. #ifdef CONFIG_FSL_ESDHC
  115. struct fsl_esdhc_cfg esdhc_cfg[2] = {
  116. {MMC_SDHC1_BASE_ADDR},
  117. {MMC_SDHC2_BASE_ADDR},
  118. };
  119. int board_mmc_getcd(struct mmc *mmc)
  120. {
  121. struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
  122. int ret;
  123. imx_iomux_v3_setup_pad(MX53_PAD_GPIO_1__GPIO1_1);
  124. gpio_direction_input(IMX_GPIO_NR(1, 1));
  125. imx_iomux_v3_setup_pad(MX53_PAD_GPIO_4__GPIO1_4);
  126. gpio_direction_input(IMX_GPIO_NR(1, 4));
  127. if (cfg->esdhc_base == MMC_SDHC1_BASE_ADDR)
  128. ret = !gpio_get_value(IMX_GPIO_NR(1, 1));
  129. else
  130. ret = !gpio_get_value(IMX_GPIO_NR(1, 4));
  131. return ret;
  132. }
  133. #define SD_CMD_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_DSE_HIGH | \
  134. PAD_CTL_PUS_100K_UP)
  135. #define SD_CLK_PAD_CTRL (PAD_CTL_PUS_47K_UP | PAD_CTL_DSE_HIGH)
  136. #define SD_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_PUS_47K_UP | \
  137. PAD_CTL_DSE_HIGH)
  138. int board_mmc_init(bd_t *bis)
  139. {
  140. static const iomux_v3_cfg_t sd1_pads[] = {
  141. NEW_PAD_CTRL(MX53_PAD_SD1_CMD__ESDHC1_CMD, SD_CMD_PAD_CTRL),
  142. NEW_PAD_CTRL(MX53_PAD_SD1_CLK__ESDHC1_CLK, SD_CLK_PAD_CTRL),
  143. NEW_PAD_CTRL(MX53_PAD_SD1_DATA0__ESDHC1_DAT0, SD_PAD_CTRL),
  144. NEW_PAD_CTRL(MX53_PAD_SD1_DATA1__ESDHC1_DAT1, SD_PAD_CTRL),
  145. NEW_PAD_CTRL(MX53_PAD_SD1_DATA2__ESDHC1_DAT2, SD_PAD_CTRL),
  146. NEW_PAD_CTRL(MX53_PAD_SD1_DATA3__ESDHC1_DAT3, SD_PAD_CTRL),
  147. };
  148. static const iomux_v3_cfg_t sd2_pads[] = {
  149. NEW_PAD_CTRL(MX53_PAD_SD2_CMD__ESDHC2_CMD, SD_CMD_PAD_CTRL),
  150. NEW_PAD_CTRL(MX53_PAD_SD2_CLK__ESDHC2_CLK, SD_CLK_PAD_CTRL),
  151. NEW_PAD_CTRL(MX53_PAD_SD2_DATA0__ESDHC2_DAT0, SD_PAD_CTRL),
  152. NEW_PAD_CTRL(MX53_PAD_SD2_DATA1__ESDHC2_DAT1, SD_PAD_CTRL),
  153. NEW_PAD_CTRL(MX53_PAD_SD2_DATA2__ESDHC2_DAT2, SD_PAD_CTRL),
  154. NEW_PAD_CTRL(MX53_PAD_SD2_DATA3__ESDHC2_DAT3, SD_PAD_CTRL),
  155. NEW_PAD_CTRL(MX53_PAD_PATA_DATA12__ESDHC2_DAT4, SD_PAD_CTRL),
  156. NEW_PAD_CTRL(MX53_PAD_PATA_DATA13__ESDHC2_DAT5, SD_PAD_CTRL),
  157. NEW_PAD_CTRL(MX53_PAD_PATA_DATA14__ESDHC2_DAT6, SD_PAD_CTRL),
  158. NEW_PAD_CTRL(MX53_PAD_PATA_DATA15__ESDHC2_DAT7, SD_PAD_CTRL),
  159. };
  160. u32 index;
  161. s32 status = 0;
  162. esdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
  163. esdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC2_CLK);
  164. for (index = 0; index < CONFIG_SYS_FSL_ESDHC_NUM; index++) {
  165. switch (index) {
  166. case 0:
  167. imx_iomux_v3_setup_multiple_pads(sd1_pads,
  168. ARRAY_SIZE(sd1_pads));
  169. break;
  170. case 1:
  171. imx_iomux_v3_setup_multiple_pads(sd2_pads,
  172. ARRAY_SIZE(sd2_pads));
  173. break;
  174. default:
  175. printf("Warning: you configured more ESDHC controller"
  176. "(%d) as supported by the board(2)\n",
  177. CONFIG_SYS_FSL_ESDHC_NUM);
  178. return status;
  179. }
  180. status |= fsl_esdhc_initialize(bis, &esdhc_cfg[index]);
  181. }
  182. return status;
  183. }
  184. #endif
  185. static void weim_smc911x_iomux(void)
  186. {
  187. static const iomux_v3_cfg_t weim_smc911x_pads[] = {
  188. /* Data bus */
  189. NEW_PAD_CTRL(MX53_PAD_EIM_D16__EMI_WEIM_D_16,
  190. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  191. NEW_PAD_CTRL(MX53_PAD_EIM_D17__EMI_WEIM_D_17,
  192. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  193. NEW_PAD_CTRL(MX53_PAD_EIM_D18__EMI_WEIM_D_18,
  194. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  195. NEW_PAD_CTRL(MX53_PAD_EIM_D19__EMI_WEIM_D_19,
  196. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  197. NEW_PAD_CTRL(MX53_PAD_EIM_D20__EMI_WEIM_D_20,
  198. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  199. NEW_PAD_CTRL(MX53_PAD_EIM_D21__EMI_WEIM_D_21,
  200. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  201. NEW_PAD_CTRL(MX53_PAD_EIM_D22__EMI_WEIM_D_22,
  202. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  203. NEW_PAD_CTRL(MX53_PAD_EIM_D23__EMI_WEIM_D_23,
  204. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  205. NEW_PAD_CTRL(MX53_PAD_EIM_D24__EMI_WEIM_D_24,
  206. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  207. NEW_PAD_CTRL(MX53_PAD_EIM_D25__EMI_WEIM_D_25,
  208. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  209. NEW_PAD_CTRL(MX53_PAD_EIM_D26__EMI_WEIM_D_26,
  210. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  211. NEW_PAD_CTRL(MX53_PAD_EIM_D27__EMI_WEIM_D_27,
  212. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  213. NEW_PAD_CTRL(MX53_PAD_EIM_D28__EMI_WEIM_D_28,
  214. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  215. NEW_PAD_CTRL(MX53_PAD_EIM_D29__EMI_WEIM_D_29,
  216. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  217. NEW_PAD_CTRL(MX53_PAD_EIM_D30__EMI_WEIM_D_30,
  218. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  219. NEW_PAD_CTRL(MX53_PAD_EIM_D31__EMI_WEIM_D_31,
  220. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  221. /* Address lines */
  222. NEW_PAD_CTRL(MX53_PAD_EIM_DA0__EMI_NAND_WEIM_DA_0,
  223. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  224. NEW_PAD_CTRL(MX53_PAD_EIM_DA1__EMI_NAND_WEIM_DA_1,
  225. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  226. NEW_PAD_CTRL(MX53_PAD_EIM_DA2__EMI_NAND_WEIM_DA_2,
  227. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  228. NEW_PAD_CTRL(MX53_PAD_EIM_DA3__EMI_NAND_WEIM_DA_3,
  229. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  230. NEW_PAD_CTRL(MX53_PAD_EIM_DA4__EMI_NAND_WEIM_DA_4,
  231. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  232. NEW_PAD_CTRL(MX53_PAD_EIM_DA5__EMI_NAND_WEIM_DA_5,
  233. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  234. NEW_PAD_CTRL(MX53_PAD_EIM_DA6__EMI_NAND_WEIM_DA_6,
  235. PAD_CTL_PKE | PAD_CTL_DSE_HIGH),
  236. /* other EIM signals for ethernet */
  237. MX53_PAD_EIM_OE__EMI_WEIM_OE,
  238. MX53_PAD_EIM_RW__EMI_WEIM_RW,
  239. MX53_PAD_EIM_CS1__EMI_WEIM_CS_1,
  240. };
  241. /* ETHERNET_INT as GPIO2_31 */
  242. imx_iomux_v3_setup_pad(MX53_PAD_EIM_EB3__GPIO2_31);
  243. gpio_direction_input(ETHERNET_INT);
  244. /* WEIM bus */
  245. imx_iomux_v3_setup_multiple_pads(weim_smc911x_pads,
  246. ARRAY_SIZE(weim_smc911x_pads));
  247. }
  248. static void weim_cs1_settings(void)
  249. {
  250. struct weim *weim_regs = (struct weim *)WEIM_BASE_ADDR;
  251. writel(MX53ARD_CS1GCR1, &weim_regs->cs1gcr1);
  252. writel(0x0, &weim_regs->cs1gcr2);
  253. writel(MX53ARD_CS1RCR1, &weim_regs->cs1rcr1);
  254. writel(MX53ARD_CS1RCR2, &weim_regs->cs1rcr2);
  255. writel(MX53ARD_CS1WCR1, &weim_regs->cs1wcr1);
  256. writel(0x0, &weim_regs->cs1wcr2);
  257. writel(0x0, &weim_regs->wcr);
  258. set_chipselect_size(CS0_64M_CS1_64M);
  259. }
  260. int board_early_init_f(void)
  261. {
  262. setup_iomux_nand();
  263. setup_iomux_uart();
  264. return 0;
  265. }
  266. int board_init(void)
  267. {
  268. /* address of boot parameters */
  269. gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
  270. return 0;
  271. }
  272. int board_eth_init(bd_t *bis)
  273. {
  274. int rc = -ENODEV;
  275. weim_smc911x_iomux();
  276. weim_cs1_settings();
  277. #ifdef CONFIG_SMC911X
  278. rc = smc911x_initialize(0, CONFIG_SMC911X_BASE);
  279. #endif
  280. return rc;
  281. }
  282. int checkboard(void)
  283. {
  284. puts("Board: MX53ARD\n");
  285. return 0;
  286. }