pfla02.c 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2017 Stefano Babic <sbabic@denx.de>
  4. */
  5. #include <common.h>
  6. #include <asm/io.h>
  7. #include <asm/arch/clock.h>
  8. #include <asm/arch/imx-regs.h>
  9. #include <asm/arch/iomux.h>
  10. #include <asm/arch/crm_regs.h>
  11. #include <asm/arch/iomux.h>
  12. #include <asm/arch/mx6-pins.h>
  13. #include <asm/mach-imx/iomux-v3.h>
  14. #include <asm/mach-imx/boot_mode.h>
  15. #include <asm/mach-imx/mxc_i2c.h>
  16. #include <asm/mach-imx/spi.h>
  17. #include <linux/errno.h>
  18. #include <asm/gpio.h>
  19. #include <mmc.h>
  20. #include <i2c.h>
  21. #include <fsl_esdhc.h>
  22. #include <nand.h>
  23. #include <miiphy.h>
  24. #include <netdev.h>
  25. #include <asm/arch/sys_proto.h>
  26. #include <asm/sections.h>
  27. DECLARE_GLOBAL_DATA_PTR;
  28. #define UART_PAD_CTRL (PAD_CTL_PUS_100K_UP | \
  29. PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | \
  30. PAD_CTL_SRE_FAST | PAD_CTL_HYS)
  31. #define USDHC_PAD_CTRL (PAD_CTL_PUS_47K_UP | \
  32. PAD_CTL_SPEED_LOW | PAD_CTL_DSE_80ohm | \
  33. PAD_CTL_SRE_FAST | PAD_CTL_HYS)
  34. #define ENET_PAD_CTRL (PAD_CTL_PUS_100K_UP | \
  35. PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS)
  36. #define SPI_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_SPEED_MED | \
  37. PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST)
  38. #define I2C_PAD_CTRL (PAD_CTL_PUS_100K_UP | \
  39. PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS | \
  40. PAD_CTL_ODE | PAD_CTL_SRE_FAST)
  41. #define I2C_PAD MUX_PAD_CTRL(I2C_PAD_CTRL)
  42. #define ASRC_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_PUS_100K_UP | \
  43. PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST)
  44. #define NAND_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \
  45. PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST)
  46. #define ENET_PHY_RESET_GPIO IMX_GPIO_NR(1, 14)
  47. #define USDHC2_CD_GPIO IMX_GPIO_NR(1, 4)
  48. #define GREEN_LED IMX_GPIO_NR(2, 31)
  49. #define RED_LED IMX_GPIO_NR(1, 30)
  50. #define IMX6Q_DRIVE_STRENGTH 0x30
  51. int dram_init(void)
  52. {
  53. gd->ram_size = imx_ddr_size();
  54. return 0;
  55. }
  56. static iomux_v3_cfg_t const uart4_pads[] = {
  57. IOMUX_PADS(PAD_KEY_COL0__UART4_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL)),
  58. IOMUX_PADS(PAD_KEY_ROW0__UART4_RX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL)),
  59. };
  60. static iomux_v3_cfg_t const enet_pads[] = {
  61. IOMUX_PADS(PAD_ENET_MDIO__ENET_MDIO | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  62. IOMUX_PADS(PAD_ENET_MDC__ENET_MDC | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  63. IOMUX_PADS(PAD_RGMII_TXC__RGMII_TXC | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  64. IOMUX_PADS(PAD_RGMII_TD0__RGMII_TD0 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  65. IOMUX_PADS(PAD_RGMII_TD1__RGMII_TD1 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  66. IOMUX_PADS(PAD_RGMII_TD2__RGMII_TD2 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  67. IOMUX_PADS(PAD_RGMII_TD3__RGMII_TD3 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  68. IOMUX_PADS(PAD_RGMII_TX_CTL__RGMII_TX_CTL |
  69. MUX_PAD_CTRL(ENET_PAD_CTRL)),
  70. IOMUX_PADS(PAD_ENET_REF_CLK__ENET_TX_CLK |
  71. MUX_PAD_CTRL(ENET_PAD_CTRL)),
  72. IOMUX_PADS(PAD_RGMII_RXC__RGMII_RXC | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  73. IOMUX_PADS(PAD_RGMII_RD0__RGMII_RD0 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  74. IOMUX_PADS(PAD_RGMII_RD1__RGMII_RD1 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  75. IOMUX_PADS(PAD_RGMII_RD2__RGMII_RD2 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  76. IOMUX_PADS(PAD_RGMII_RD3__RGMII_RD3 | MUX_PAD_CTRL(ENET_PAD_CTRL)),
  77. IOMUX_PADS(PAD_RGMII_RX_CTL__RGMII_RX_CTL |
  78. MUX_PAD_CTRL(ENET_PAD_CTRL)),
  79. IOMUX_PADS(PAD_SD2_DAT1__GPIO1_IO14 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  80. };
  81. static iomux_v3_cfg_t const ecspi3_pads[] = {
  82. IOMUX_PADS(PAD_DISP0_DAT0__ECSPI3_SCLK | MUX_PAD_CTRL(SPI_PAD_CTRL)),
  83. IOMUX_PADS(PAD_DISP0_DAT1__ECSPI3_MOSI | MUX_PAD_CTRL(SPI_PAD_CTRL)),
  84. IOMUX_PADS(PAD_DISP0_DAT2__ECSPI3_MISO | MUX_PAD_CTRL(SPI_PAD_CTRL)),
  85. IOMUX_PADS(PAD_DISP0_DAT3__GPIO4_IO24 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  86. };
  87. static iomux_v3_cfg_t const gpios_pads[] = {
  88. IOMUX_PADS(PAD_SD4_DAT3__GPIO2_IO11 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  89. IOMUX_PADS(PAD_SD4_DAT4__GPIO2_IO12 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  90. IOMUX_PADS(PAD_SD4_DAT5__GPIO2_IO13 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  91. IOMUX_PADS(PAD_SD4_DAT6__GPIO2_IO14 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  92. IOMUX_PADS(PAD_SD4_DAT7__GPIO2_IO15 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  93. IOMUX_PADS(PAD_EIM_EB3__GPIO2_IO31 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  94. IOMUX_PADS(PAD_ENET_TXD0__GPIO1_IO30 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  95. IOMUX_PADS(PAD_SD4_DAT3__GPIO2_IO11 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  96. };
  97. #ifdef CONFIG_CMD_NAND
  98. /* NAND */
  99. static iomux_v3_cfg_t const nfc_pads[] = {
  100. IOMUX_PADS(PAD_NANDF_CLE__NAND_CLE | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  101. IOMUX_PADS(PAD_NANDF_ALE__NAND_ALE | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  102. IOMUX_PADS(PAD_NANDF_WP_B__NAND_WP_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  103. IOMUX_PADS(PAD_NANDF_RB0__NAND_READY_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  104. IOMUX_PADS(PAD_NANDF_CS0__NAND_CE0_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  105. IOMUX_PADS(PAD_NANDF_CS1__NAND_CE1_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  106. IOMUX_PADS(PAD_NANDF_CS2__NAND_CE2_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  107. IOMUX_PADS(PAD_NANDF_CS3__NAND_CE3_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  108. IOMUX_PADS(PAD_SD4_CMD__NAND_RE_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  109. IOMUX_PADS(PAD_SD4_CLK__NAND_WE_B | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  110. IOMUX_PADS(PAD_NANDF_D0__NAND_DATA00 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  111. IOMUX_PADS(PAD_NANDF_D1__NAND_DATA01 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  112. IOMUX_PADS(PAD_NANDF_D2__NAND_DATA02 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  113. IOMUX_PADS(PAD_NANDF_D3__NAND_DATA03 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  114. IOMUX_PADS(PAD_NANDF_D4__NAND_DATA04 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  115. IOMUX_PADS(PAD_NANDF_D5__NAND_DATA05 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  116. IOMUX_PADS(PAD_NANDF_D6__NAND_DATA06 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  117. IOMUX_PADS(PAD_NANDF_D7__NAND_DATA07 | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  118. IOMUX_PADS(PAD_SD4_DAT0__NAND_DQS | MUX_PAD_CTRL(NAND_PAD_CTRL)),
  119. };
  120. #endif
  121. static struct i2c_pads_info i2c_pad_info = {
  122. .scl = {
  123. .i2c_mode = MX6Q_PAD_EIM_D21__I2C1_SCL | I2C_PAD,
  124. .gpio_mode = MX6Q_PAD_EIM_D21__GPIO3_IO21 | I2C_PAD,
  125. .gp = IMX_GPIO_NR(3, 21)
  126. },
  127. .sda = {
  128. .i2c_mode = MX6Q_PAD_EIM_D28__I2C1_SDA | I2C_PAD,
  129. .gpio_mode = MX6Q_PAD_EIM_D28__GPIO3_IO28 | I2C_PAD,
  130. .gp = IMX_GPIO_NR(3, 28)
  131. }
  132. };
  133. static struct fsl_esdhc_cfg usdhc_cfg[] = {
  134. {USDHC3_BASE_ADDR,
  135. .max_bus_width = 4},
  136. {.esdhc_base = USDHC2_BASE_ADDR,
  137. .max_bus_width = 4},
  138. };
  139. #if !defined(CONFIG_SPL_BUILD)
  140. static iomux_v3_cfg_t const usdhc2_pads[] = {
  141. IOMUX_PADS(PAD_SD2_CLK__SD2_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  142. IOMUX_PADS(PAD_SD2_CMD__SD2_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  143. IOMUX_PADS(PAD_SD2_DAT0__SD2_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  144. IOMUX_PADS(PAD_SD2_DAT1__SD2_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  145. IOMUX_PADS(PAD_SD2_DAT2__SD2_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  146. IOMUX_PADS(PAD_SD2_DAT3__SD2_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  147. IOMUX_PADS(PAD_EIM_BCLK__GPIO6_IO31 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  148. IOMUX_PADS(PAD_GPIO_4__GPIO1_IO04 | MUX_PAD_CTRL(NO_PAD_CTRL)),
  149. };
  150. #endif
  151. static iomux_v3_cfg_t const usdhc3_pads[] = {
  152. IOMUX_PADS(PAD_SD3_CLK__SD3_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  153. IOMUX_PADS(PAD_SD3_CMD__SD3_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  154. IOMUX_PADS(PAD_SD3_DAT0__SD3_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  155. IOMUX_PADS(PAD_SD3_DAT1__SD3_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  156. IOMUX_PADS(PAD_SD3_DAT2__SD3_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  157. IOMUX_PADS(PAD_SD3_DAT3__SD3_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  158. IOMUX_PADS(PAD_SD3_DAT4__SD3_DATA4 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  159. IOMUX_PADS(PAD_SD3_DAT5__SD3_DATA5 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  160. IOMUX_PADS(PAD_SD3_DAT6__SD3_DATA6 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  161. IOMUX_PADS(PAD_SD3_DAT7__SD3_DATA7 | MUX_PAD_CTRL(USDHC_PAD_CTRL)),
  162. };
  163. int board_mmc_get_env_dev(int devno)
  164. {
  165. return devno - 1;
  166. }
  167. int board_mmc_getcd(struct mmc *mmc)
  168. {
  169. struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
  170. int ret = 0;
  171. switch (cfg->esdhc_base) {
  172. case USDHC2_BASE_ADDR:
  173. ret = !gpio_get_value(USDHC2_CD_GPIO);
  174. ret = 1;
  175. break;
  176. case USDHC3_BASE_ADDR:
  177. ret = 1;
  178. break;
  179. }
  180. return ret;
  181. }
  182. #ifndef CONFIG_SPL_BUILD
  183. int board_mmc_init(bd_t *bis)
  184. {
  185. int ret;
  186. int i;
  187. for (i = 0; i < CONFIG_SYS_FSL_USDHC_NUM; i++) {
  188. switch (i) {
  189. case 0:
  190. SETUP_IOMUX_PADS(usdhc3_pads);
  191. usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK);
  192. break;
  193. case 1:
  194. SETUP_IOMUX_PADS(usdhc2_pads);
  195. gpio_direction_input(USDHC2_CD_GPIO);
  196. usdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC2_CLK);
  197. break;
  198. default:
  199. printf("Warning: you configured more USDHC controllers"
  200. "(%d) then supported by the board (%d)\n",
  201. i + 1, CONFIG_SYS_FSL_USDHC_NUM);
  202. return -EINVAL;
  203. }
  204. ret = fsl_esdhc_initialize(bis, &usdhc_cfg[i]);
  205. if (ret)
  206. return ret;
  207. }
  208. return 0;
  209. }
  210. #endif
  211. static void setup_iomux_uart(void)
  212. {
  213. SETUP_IOMUX_PADS(uart4_pads);
  214. }
  215. static void setup_iomux_enet(void)
  216. {
  217. SETUP_IOMUX_PADS(enet_pads);
  218. gpio_direction_output(ENET_PHY_RESET_GPIO, 0);
  219. mdelay(10);
  220. gpio_set_value(ENET_PHY_RESET_GPIO, 1);
  221. mdelay(30);
  222. }
  223. static void setup_spi(void)
  224. {
  225. gpio_request(IMX_GPIO_NR(4, 24), "spi_cs0");
  226. gpio_direction_output(IMX_GPIO_NR(4, 24), 1);
  227. SETUP_IOMUX_PADS(ecspi3_pads);
  228. enable_spi_clk(true, 2);
  229. }
  230. static void setup_gpios(void)
  231. {
  232. SETUP_IOMUX_PADS(gpios_pads);
  233. }
  234. #ifdef CONFIG_CMD_NAND
  235. static void setup_gpmi_nand(void)
  236. {
  237. struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
  238. /* config gpmi nand iomux */
  239. SETUP_IOMUX_PADS(nfc_pads);
  240. /* gate ENFC_CLK_ROOT clock first,before clk source switch */
  241. clrbits_le32(&mxc_ccm->CCGR2, MXC_CCM_CCGR2_IOMUX_IPT_CLK_IO_MASK);
  242. /* config gpmi and bch clock to 100 MHz */
  243. clrsetbits_le32(&mxc_ccm->cs2cdr,
  244. MXC_CCM_CS2CDR_ENFC_CLK_PODF_MASK |
  245. MXC_CCM_CS2CDR_ENFC_CLK_PRED_MASK |
  246. MXC_CCM_CS2CDR_ENFC_CLK_SEL_MASK,
  247. MXC_CCM_CS2CDR_ENFC_CLK_PODF(0) |
  248. MXC_CCM_CS2CDR_ENFC_CLK_PRED(3) |
  249. MXC_CCM_CS2CDR_ENFC_CLK_SEL(3));
  250. /* enable ENFC_CLK_ROOT clock */
  251. setbits_le32(&mxc_ccm->CCGR2, MXC_CCM_CCGR2_IOMUX_IPT_CLK_IO_MASK);
  252. /* enable gpmi and bch clock gating */
  253. setbits_le32(&mxc_ccm->CCGR4,
  254. MXC_CCM_CCGR4_RAWNAND_U_BCH_INPUT_APB_MASK |
  255. MXC_CCM_CCGR4_RAWNAND_U_GPMI_BCH_INPUT_BCH_MASK |
  256. MXC_CCM_CCGR4_RAWNAND_U_GPMI_BCH_INPUT_GPMI_IO_MASK |
  257. MXC_CCM_CCGR4_RAWNAND_U_GPMI_INPUT_APB_MASK |
  258. MXC_CCM_CCGR4_PL301_MX6QPER1_BCH_OFFSET);
  259. /* enable apbh clock gating */
  260. setbits_le32(&mxc_ccm->CCGR0, MXC_CCM_CCGR0_APBHDMA_MASK);
  261. }
  262. #endif
  263. /*
  264. * Board revision is coded in 4 GPIOs
  265. */
  266. u32 get_board_rev(void)
  267. {
  268. u32 rev;
  269. int i;
  270. for (i = 0, rev = 0; i < 4; i++)
  271. rev |= (gpio_get_value(IMX_GPIO_NR(2, 12 + i)) << i);
  272. return 16 - rev;
  273. }
  274. int board_spi_cs_gpio(unsigned bus, unsigned cs)
  275. {
  276. if (bus != 2 || (cs != 0))
  277. return -EINVAL;
  278. return IMX_GPIO_NR(4, 24);
  279. }
  280. int board_eth_init(bd_t *bis)
  281. {
  282. setup_iomux_enet();
  283. return cpu_eth_init(bis);
  284. }
  285. int board_early_init_f(void)
  286. {
  287. setup_iomux_uart();
  288. return 0;
  289. }
  290. int board_init(void)
  291. {
  292. /* address of boot parameters */
  293. gd->bd->bi_boot_params = PHYS_SDRAM + 0x100;
  294. #ifdef CONFIG_SYS_I2C_MXC
  295. setup_i2c(0, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info);
  296. #endif
  297. #ifdef CONFIG_MXC_SPI
  298. setup_spi();
  299. #endif
  300. setup_gpios();
  301. #ifdef CONFIG_CMD_NAND
  302. setup_gpmi_nand();
  303. #endif
  304. return 0;
  305. }
  306. #ifdef CONFIG_CMD_BMODE
  307. /*
  308. * BOOT_CFG1, BOOT_CFG2, BOOT_CFG3, BOOT_CFG4
  309. * see Table 8-11 and Table 5-9
  310. * BOOT_CFG1[7] = 1 (boot from NAND)
  311. * BOOT_CFG1[5] = 0 - raw NAND
  312. * BOOT_CFG1[4] = 0 - default pad settings
  313. * BOOT_CFG1[3:2] = 00 - devices = 1
  314. * BOOT_CFG1[1:0] = 00 - Row Address Cycles = 3
  315. * BOOT_CFG2[4:3] = 00 - Boot Search Count = 2
  316. * BOOT_CFG2[2:1] = 01 - Pages In Block = 64
  317. * BOOT_CFG2[0] = 0 - Reset time 12ms
  318. */
  319. static const struct boot_mode board_boot_modes[] = {
  320. /* NAND: 64pages per block, 3 row addr cycles, 2 copies of FCB/DBBT */
  321. {"nand", MAKE_CFGVAL(0x80, 0x02, 0x00, 0x00)},
  322. {"mmc0", MAKE_CFGVAL(0x40, 0x20, 0x00, 0x00)},
  323. {NULL, 0},
  324. };
  325. #endif
  326. int board_late_init(void)
  327. {
  328. char buf[10];
  329. #ifdef CONFIG_CMD_BMODE
  330. add_board_boot_modes(board_boot_modes);
  331. #endif
  332. snprintf(buf, sizeof(buf), "%d", get_board_rev());
  333. env_set("board_rev", buf);
  334. return 0;
  335. }
  336. #ifdef CONFIG_SPL_BUILD
  337. #include <asm/arch/mx6-ddr.h>
  338. #include <spl.h>
  339. #include <linux/libfdt.h>
  340. #define MX6_PHYFLEX_ERR006282 IMX_GPIO_NR(2, 11)
  341. static void phyflex_err006282_workaround(void)
  342. {
  343. /*
  344. * Boards beginning with 1362.2 have the SD4_DAT3 pin connected
  345. * to the CMIC. If this pin isn't toggled within 10s the boards
  346. * reset. The pin is unconnected on older boards, so we do not
  347. * need a check for older boards before applying this fixup.
  348. */
  349. gpio_direction_output(MX6_PHYFLEX_ERR006282, 0);
  350. mdelay(2);
  351. gpio_direction_output(MX6_PHYFLEX_ERR006282, 1);
  352. mdelay(2);
  353. gpio_set_value(MX6_PHYFLEX_ERR006282, 0);
  354. gpio_direction_input(MX6_PHYFLEX_ERR006282);
  355. }
  356. static const struct mx6dq_iomux_ddr_regs mx6_ddr_ioregs = {
  357. .dram_sdclk_0 = 0x00000030,
  358. .dram_sdclk_1 = 0x00000030,
  359. .dram_cas = 0x00000030,
  360. .dram_ras = 0x00000030,
  361. .dram_reset = 0x00000030,
  362. .dram_sdcke0 = 0x00003000,
  363. .dram_sdcke1 = 0x00003000,
  364. .dram_sdba2 = 0x00000030,
  365. .dram_sdodt0 = 0x00000030,
  366. .dram_sdodt1 = 0x00000030,
  367. .dram_sdqs0 = 0x00000028,
  368. .dram_sdqs1 = 0x00000028,
  369. .dram_sdqs2 = 0x00000028,
  370. .dram_sdqs3 = 0x00000028,
  371. .dram_sdqs4 = 0x00000028,
  372. .dram_sdqs5 = 0x00000028,
  373. .dram_sdqs6 = 0x00000028,
  374. .dram_sdqs7 = 0x00000028,
  375. .dram_dqm0 = 0x00000028,
  376. .dram_dqm1 = 0x00000028,
  377. .dram_dqm2 = 0x00000028,
  378. .dram_dqm3 = 0x00000028,
  379. .dram_dqm4 = 0x00000028,
  380. .dram_dqm5 = 0x00000028,
  381. .dram_dqm6 = 0x00000028,
  382. .dram_dqm7 = 0x00000028,
  383. };
  384. static const struct mx6dq_iomux_grp_regs mx6_grp_ioregs = {
  385. .grp_ddr_type = 0x000C0000,
  386. .grp_ddrmode_ctl = 0x00020000,
  387. .grp_ddrpke = 0x00000000,
  388. .grp_addds = IMX6Q_DRIVE_STRENGTH,
  389. .grp_ctlds = IMX6Q_DRIVE_STRENGTH,
  390. .grp_ddrmode = 0x00020000,
  391. .grp_b0ds = 0x00000028,
  392. .grp_b1ds = 0x00000028,
  393. .grp_b2ds = 0x00000028,
  394. .grp_b3ds = 0x00000028,
  395. .grp_b4ds = 0x00000028,
  396. .grp_b5ds = 0x00000028,
  397. .grp_b6ds = 0x00000028,
  398. .grp_b7ds = 0x00000028,
  399. };
  400. static const struct mx6_mmdc_calibration mx6_mmcd_calib = {
  401. .p0_mpwldectrl0 = 0x00110011,
  402. .p0_mpwldectrl1 = 0x00240024,
  403. .p1_mpwldectrl0 = 0x00260038,
  404. .p1_mpwldectrl1 = 0x002C0038,
  405. .p0_mpdgctrl0 = 0x03400350,
  406. .p0_mpdgctrl1 = 0x03440340,
  407. .p1_mpdgctrl0 = 0x034C0354,
  408. .p1_mpdgctrl1 = 0x035C033C,
  409. .p0_mprddlctl = 0x322A2A2A,
  410. .p1_mprddlctl = 0x302C2834,
  411. .p0_mpwrdlctl = 0x34303834,
  412. .p1_mpwrdlctl = 0x422A3E36,
  413. };
  414. /* Index in RAM Chip array */
  415. enum {
  416. RAM_MT64K,
  417. RAM_MT128K,
  418. RAM_MT256K
  419. };
  420. static struct mx6_ddr3_cfg mt41k_xx[] = {
  421. /* MT41K64M16JT-125 (1Gb density) */
  422. {
  423. .mem_speed = 1600,
  424. .density = 1,
  425. .width = 16,
  426. .banks = 8,
  427. .rowaddr = 13,
  428. .coladdr = 10,
  429. .pagesz = 2,
  430. .trcd = 1375,
  431. .trcmin = 4875,
  432. .trasmin = 3500,
  433. .SRT = 1,
  434. },
  435. /* MT41K256M16JT-125 (2Gb density) */
  436. {
  437. .mem_speed = 1600,
  438. .density = 2,
  439. .width = 16,
  440. .banks = 8,
  441. .rowaddr = 14,
  442. .coladdr = 10,
  443. .pagesz = 2,
  444. .trcd = 1375,
  445. .trcmin = 4875,
  446. .trasmin = 3500,
  447. .SRT = 1,
  448. },
  449. /* MT41K256M16JT-125 (4Gb density) */
  450. {
  451. .mem_speed = 1600,
  452. .density = 4,
  453. .width = 16,
  454. .banks = 8,
  455. .rowaddr = 15,
  456. .coladdr = 10,
  457. .pagesz = 2,
  458. .trcd = 1375,
  459. .trcmin = 4875,
  460. .trasmin = 3500,
  461. .SRT = 1,
  462. }
  463. };
  464. static void ccgr_init(void)
  465. {
  466. struct mxc_ccm_reg *ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
  467. writel(0x00C03F3F, &ccm->CCGR0);
  468. writel(0x0030FC03, &ccm->CCGR1);
  469. writel(0x0FFFC000, &ccm->CCGR2);
  470. writel(0x3FF00000, &ccm->CCGR3);
  471. writel(0x00FFF300, &ccm->CCGR4);
  472. writel(0x0F0000C3, &ccm->CCGR5);
  473. writel(0x000003FF, &ccm->CCGR6);
  474. }
  475. static void spl_dram_init(struct mx6_ddr_sysinfo *sysinfo,
  476. struct mx6_ddr3_cfg *mem_ddr)
  477. {
  478. mx6dq_dram_iocfg(64, &mx6_ddr_ioregs, &mx6_grp_ioregs);
  479. mx6_dram_cfg(sysinfo, &mx6_mmcd_calib, mem_ddr);
  480. }
  481. int board_mmc_init(bd_t *bis)
  482. {
  483. if (spl_boot_device() == BOOT_DEVICE_SPI)
  484. printf("MMC SEtup, Boot SPI");
  485. SETUP_IOMUX_PADS(usdhc3_pads);
  486. usdhc_cfg[0].esdhc_base = USDHC3_BASE_ADDR;
  487. usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK);
  488. usdhc_cfg[0].max_bus_width = 4;
  489. gd->arch.sdhc_clk = usdhc_cfg[0].sdhc_clk;
  490. return fsl_esdhc_initialize(bis, &usdhc_cfg[0]);
  491. }
  492. void board_boot_order(u32 *spl_boot_list)
  493. {
  494. spl_boot_list[0] = spl_boot_device();
  495. printf("Boot device %x\n", spl_boot_list[0]);
  496. switch (spl_boot_list[0]) {
  497. case BOOT_DEVICE_SPI:
  498. spl_boot_list[1] = BOOT_DEVICE_UART;
  499. break;
  500. case BOOT_DEVICE_MMC1:
  501. spl_boot_list[1] = BOOT_DEVICE_SPI;
  502. spl_boot_list[2] = BOOT_DEVICE_UART;
  503. break;
  504. default:
  505. printf("Boot device %x\n", spl_boot_list[0]);
  506. }
  507. }
  508. /*
  509. * This is used because get_ram_size() does not
  510. * take care of cache, resulting a wrong size
  511. * pfla02 has just 1, 2 or 4 GB option
  512. * Function checks for mirrors in the first CS
  513. */
  514. #define RAM_TEST_PATTERN 0xaa5555aa
  515. #define MIN_BANK_SIZE (512 * 1024 * 1024)
  516. static unsigned int pfla02_detect_chiptype(void)
  517. {
  518. u32 *p, *p1;
  519. unsigned int offset = MIN_BANK_SIZE;
  520. int i;
  521. for (i = 0; i < 2; i++) {
  522. p = (u32 *)PHYS_SDRAM;
  523. p1 = (u32 *)(PHYS_SDRAM + (i + 1) * offset);
  524. *p1 = 0;
  525. *p = RAM_TEST_PATTERN;
  526. /*
  527. * This is required to detect mirroring
  528. * else we read back values from cache
  529. */
  530. flush_dcache_all();
  531. if (*p == *p1)
  532. return i;
  533. }
  534. return RAM_MT256K;
  535. }
  536. void board_init_f(ulong dummy)
  537. {
  538. unsigned int ramchip;
  539. struct mx6_ddr_sysinfo sysinfo = {
  540. /* width of data bus:0=16,1=32,2=64 */
  541. .dsize = 2,
  542. /* config for full 4GB range so that get_mem_size() works */
  543. .cs_density = 32, /* 512 MB */
  544. /* single chip select */
  545. #if IS_ENABLED(CONFIG_SPL_DRAM_1_BANK)
  546. .ncs = 1,
  547. #else
  548. .ncs = 2,
  549. #endif
  550. .cs1_mirror = 1,
  551. .rtt_wr = 1 /*DDR3_RTT_60_OHM*/, /* RTT_Wr = RZQ/4 */
  552. .rtt_nom = 1 /*DDR3_RTT_60_OHM*/, /* RTT_Nom = RZQ/4 */
  553. .walat = 1, /* Write additional latency */
  554. .ralat = 5, /* Read additional latency */
  555. .mif3_mode = 3, /* Command prediction working mode */
  556. .bi_on = 1, /* Bank interleaving enabled */
  557. .sde_to_rst = 0x10, /* 14 cycles, 200us (JEDEC default) */
  558. .rst_to_cke = 0x23, /* 33 cycles, 500us (JEDEC default) */
  559. .ddr_type = DDR_TYPE_DDR3,
  560. .refsel = 1, /* Refresh cycles at 32KHz */
  561. .refr = 7, /* 8 refresh commands per refresh cycle */
  562. };
  563. #ifdef CONFIG_CMD_NAND
  564. /* Enable NAND */
  565. setup_gpmi_nand();
  566. #endif
  567. /* setup clock gating */
  568. ccgr_init();
  569. /* setup AIPS and disable watchdog */
  570. arch_cpu_init();
  571. /* setup AXI */
  572. gpr_init();
  573. board_early_init_f();
  574. /* setup GP timer */
  575. timer_init();
  576. /* UART clocks enabled and gd valid - init serial console */
  577. preloader_console_init();
  578. setup_spi();
  579. setup_gpios();
  580. /* DDR initialization */
  581. spl_dram_init(&sysinfo, &mt41k_xx[RAM_MT256K]);
  582. ramchip = pfla02_detect_chiptype();
  583. debug("Detected chip %d\n", ramchip);
  584. #if !IS_ENABLED(CONFIG_SPL_DRAM_1_BANK)
  585. switch (ramchip) {
  586. case RAM_MT64K:
  587. sysinfo.cs_density = 6;
  588. break;
  589. case RAM_MT128K:
  590. sysinfo.cs_density = 10;
  591. break;
  592. case RAM_MT256K:
  593. sysinfo.cs_density = 18;
  594. break;
  595. }
  596. #endif
  597. spl_dram_init(&sysinfo, &mt41k_xx[ramchip]);
  598. /* Clear the BSS. */
  599. memset(__bss_start, 0, __bss_end - __bss_start);
  600. phyflex_err006282_workaround();
  601. /* load/boot image from boot device */
  602. board_init_r(NULL, 0);
  603. }
  604. #endif