mx6ul_14x14_evk.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2015 Freescale Semiconductor, Inc.
  4. */
  5. #include <asm/arch/clock.h>
  6. #include <asm/arch/iomux.h>
  7. #include <asm/arch/imx-regs.h>
  8. #include <asm/arch/crm_regs.h>
  9. #include <asm/arch/mx6ul_pins.h>
  10. #include <asm/arch/mx6-pins.h>
  11. #include <asm/arch/sys_proto.h>
  12. #include <asm/gpio.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/io.h>
  17. #include <common.h>
  18. #include <fsl_esdhc.h>
  19. #include <i2c.h>
  20. #include <miiphy.h>
  21. #include <linux/sizes.h>
  22. #include <mmc.h>
  23. #include <netdev.h>
  24. #include <power/pmic.h>
  25. #include <power/pfuze3000_pmic.h>
  26. #include "../common/pfuze.h"
  27. #include <usb.h>
  28. #include <usb/ehci-ci.h>
  29. DECLARE_GLOBAL_DATA_PTR;
  30. #define UART_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE | \
  31. PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \
  32. PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST | PAD_CTL_HYS)
  33. #define USDHC_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE | \
  34. PAD_CTL_PUS_22K_UP | PAD_CTL_SPEED_LOW | \
  35. PAD_CTL_DSE_80ohm | PAD_CTL_SRE_FAST | PAD_CTL_HYS)
  36. #define USDHC_DAT3_CD_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE | \
  37. PAD_CTL_PUS_100K_DOWN | PAD_CTL_SPEED_LOW | \
  38. PAD_CTL_DSE_80ohm | PAD_CTL_SRE_FAST | PAD_CTL_HYS)
  39. #define I2C_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE | \
  40. PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \
  41. PAD_CTL_DSE_40ohm | PAD_CTL_HYS | \
  42. PAD_CTL_ODE)
  43. #define ENET_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_PUE | \
  44. PAD_CTL_SPEED_HIGH | \
  45. PAD_CTL_DSE_48ohm | PAD_CTL_SRE_FAST)
  46. #define LCD_PAD_CTRL (PAD_CTL_HYS | PAD_CTL_PUS_100K_UP | PAD_CTL_PUE | \
  47. PAD_CTL_PKE | PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm)
  48. #define MDIO_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_PUE | \
  49. PAD_CTL_DSE_48ohm | PAD_CTL_SRE_FAST | PAD_CTL_ODE)
  50. #define ENET_CLK_PAD_CTRL (PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST)
  51. #define IOX_SDI IMX_GPIO_NR(5, 10)
  52. #define IOX_STCP IMX_GPIO_NR(5, 7)
  53. #define IOX_SHCP IMX_GPIO_NR(5, 11)
  54. #define IOX_OE IMX_GPIO_NR(5, 8)
  55. static iomux_v3_cfg_t const iox_pads[] = {
  56. /* IOX_SDI */
  57. MX6_PAD_BOOT_MODE0__GPIO5_IO10 | MUX_PAD_CTRL(NO_PAD_CTRL),
  58. /* IOX_SHCP */
  59. MX6_PAD_BOOT_MODE1__GPIO5_IO11 | MUX_PAD_CTRL(NO_PAD_CTRL),
  60. /* IOX_STCP */
  61. MX6_PAD_SNVS_TAMPER7__GPIO5_IO07 | MUX_PAD_CTRL(NO_PAD_CTRL),
  62. /* IOX_nOE */
  63. MX6_PAD_SNVS_TAMPER8__GPIO5_IO08 | MUX_PAD_CTRL(NO_PAD_CTRL),
  64. };
  65. /*
  66. * HDMI_nRST --> Q0
  67. * ENET1_nRST --> Q1
  68. * ENET2_nRST --> Q2
  69. * CAN1_2_STBY --> Q3
  70. * BT_nPWD --> Q4
  71. * CSI_RST --> Q5
  72. * CSI_PWDN --> Q6
  73. * LCD_nPWREN --> Q7
  74. */
  75. enum qn {
  76. HDMI_NRST,
  77. ENET1_NRST,
  78. ENET2_NRST,
  79. CAN1_2_STBY,
  80. BT_NPWD,
  81. CSI_RST,
  82. CSI_PWDN,
  83. LCD_NPWREN,
  84. };
  85. enum qn_func {
  86. qn_reset,
  87. qn_enable,
  88. qn_disable,
  89. };
  90. enum qn_level {
  91. qn_low = 0,
  92. qn_high = 1,
  93. };
  94. static enum qn_level seq[3][2] = {
  95. {0, 1}, {1, 1}, {0, 0}
  96. };
  97. static enum qn_func qn_output[8] = {
  98. qn_reset, qn_reset, qn_reset, qn_enable, qn_disable, qn_reset,
  99. qn_disable, qn_disable
  100. };
  101. static void iox74lv_init(void)
  102. {
  103. int i;
  104. gpio_direction_output(IOX_OE, 0);
  105. for (i = 7; i >= 0; i--) {
  106. gpio_direction_output(IOX_SHCP, 0);
  107. gpio_direction_output(IOX_SDI, seq[qn_output[i]][0]);
  108. udelay(500);
  109. gpio_direction_output(IOX_SHCP, 1);
  110. udelay(500);
  111. }
  112. gpio_direction_output(IOX_STCP, 0);
  113. udelay(500);
  114. /*
  115. * shift register will be output to pins
  116. */
  117. gpio_direction_output(IOX_STCP, 1);
  118. for (i = 7; i >= 0; i--) {
  119. gpio_direction_output(IOX_SHCP, 0);
  120. gpio_direction_output(IOX_SDI, seq[qn_output[i]][1]);
  121. udelay(500);
  122. gpio_direction_output(IOX_SHCP, 1);
  123. udelay(500);
  124. }
  125. gpio_direction_output(IOX_STCP, 0);
  126. udelay(500);
  127. /*
  128. * shift register will be output to pins
  129. */
  130. gpio_direction_output(IOX_STCP, 1);
  131. };
  132. #ifdef CONFIG_SYS_I2C_MXC
  133. #define PC MUX_PAD_CTRL(I2C_PAD_CTRL)
  134. /* I2C1 for PMIC and EEPROM */
  135. static struct i2c_pads_info i2c_pad_info1 = {
  136. .scl = {
  137. .i2c_mode = MX6_PAD_UART4_TX_DATA__I2C1_SCL | PC,
  138. .gpio_mode = MX6_PAD_UART4_TX_DATA__GPIO1_IO28 | PC,
  139. .gp = IMX_GPIO_NR(1, 28),
  140. },
  141. .sda = {
  142. .i2c_mode = MX6_PAD_UART4_RX_DATA__I2C1_SDA | PC,
  143. .gpio_mode = MX6_PAD_UART4_RX_DATA__GPIO1_IO29 | PC,
  144. .gp = IMX_GPIO_NR(1, 29),
  145. },
  146. };
  147. #ifdef CONFIG_POWER
  148. #define I2C_PMIC 0
  149. int power_init_board(void)
  150. {
  151. if (is_mx6ul_9x9_evk()) {
  152. struct pmic *pfuze;
  153. int ret;
  154. unsigned int reg, rev_id;
  155. ret = power_pfuze3000_init(I2C_PMIC);
  156. if (ret)
  157. return ret;
  158. pfuze = pmic_get("PFUZE3000");
  159. ret = pmic_probe(pfuze);
  160. if (ret)
  161. return ret;
  162. pmic_reg_read(pfuze, PFUZE3000_DEVICEID, &reg);
  163. pmic_reg_read(pfuze, PFUZE3000_REVID, &rev_id);
  164. printf("PMIC: PFUZE3000 DEV_ID=0x%x REV_ID=0x%x\n",
  165. reg, rev_id);
  166. /* disable Low Power Mode during standby mode */
  167. pmic_reg_write(pfuze, PFUZE3000_LDOGCTL, 0x1);
  168. /* SW1B step ramp up time from 2us to 4us/25mV */
  169. reg = 0x40;
  170. pmic_reg_write(pfuze, PFUZE3000_SW1BCONF, reg);
  171. /* SW1B mode to APS/PFM */
  172. reg = 0xc;
  173. pmic_reg_write(pfuze, PFUZE3000_SW1BMODE, reg);
  174. /* SW1B standby voltage set to 0.975V */
  175. reg = 0xb;
  176. pmic_reg_write(pfuze, PFUZE3000_SW1BSTBY, reg);
  177. }
  178. return 0;
  179. }
  180. #endif
  181. #endif
  182. int dram_init(void)
  183. {
  184. gd->ram_size = imx_ddr_size();
  185. return 0;
  186. }
  187. static iomux_v3_cfg_t const uart1_pads[] = {
  188. MX6_PAD_UART1_TX_DATA__UART1_DCE_TX | MUX_PAD_CTRL(UART_PAD_CTRL),
  189. MX6_PAD_UART1_RX_DATA__UART1_DCE_RX | MUX_PAD_CTRL(UART_PAD_CTRL),
  190. };
  191. #ifndef CONFIG_SPL_BUILD
  192. static iomux_v3_cfg_t const usdhc1_pads[] = {
  193. MX6_PAD_SD1_CLK__USDHC1_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  194. MX6_PAD_SD1_CMD__USDHC1_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  195. MX6_PAD_SD1_DATA0__USDHC1_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  196. MX6_PAD_SD1_DATA1__USDHC1_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  197. MX6_PAD_SD1_DATA2__USDHC1_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  198. MX6_PAD_SD1_DATA3__USDHC1_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  199. /* VSELECT */
  200. MX6_PAD_GPIO1_IO05__USDHC1_VSELECT | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  201. /* CD */
  202. MX6_PAD_UART1_RTS_B__GPIO1_IO19 | MUX_PAD_CTRL(NO_PAD_CTRL),
  203. /* RST_B */
  204. MX6_PAD_GPIO1_IO09__GPIO1_IO09 | MUX_PAD_CTRL(NO_PAD_CTRL),
  205. };
  206. #endif
  207. /*
  208. * mx6ul_14x14_evk board default supports sd card. If want to use
  209. * EMMC, need to do board rework for sd2.
  210. * Introduce CONFIG_MX6UL_14X14_EVK_EMMC_REWORK, if sd2 reworked to support
  211. * emmc, need to define this macro.
  212. */
  213. #if defined(CONFIG_MX6UL_14X14_EVK_EMMC_REWORK)
  214. static iomux_v3_cfg_t const usdhc2_emmc_pads[] = {
  215. MX6_PAD_NAND_RE_B__USDHC2_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  216. MX6_PAD_NAND_WE_B__USDHC2_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  217. MX6_PAD_NAND_DATA00__USDHC2_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  218. MX6_PAD_NAND_DATA01__USDHC2_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  219. MX6_PAD_NAND_DATA02__USDHC2_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  220. MX6_PAD_NAND_DATA03__USDHC2_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  221. MX6_PAD_NAND_DATA04__USDHC2_DATA4 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  222. MX6_PAD_NAND_DATA05__USDHC2_DATA5 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  223. MX6_PAD_NAND_DATA06__USDHC2_DATA6 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  224. MX6_PAD_NAND_DATA07__USDHC2_DATA7 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  225. /*
  226. * RST_B
  227. */
  228. MX6_PAD_NAND_ALE__GPIO4_IO10 | MUX_PAD_CTRL(NO_PAD_CTRL),
  229. };
  230. #else
  231. static iomux_v3_cfg_t const usdhc2_pads[] = {
  232. MX6_PAD_NAND_RE_B__USDHC2_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  233. MX6_PAD_NAND_WE_B__USDHC2_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  234. MX6_PAD_NAND_DATA00__USDHC2_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  235. MX6_PAD_NAND_DATA01__USDHC2_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  236. MX6_PAD_NAND_DATA02__USDHC2_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  237. MX6_PAD_NAND_DATA03__USDHC2_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
  238. };
  239. /*
  240. * The evk board uses DAT3 to detect CD card plugin,
  241. * in u-boot we mux the pin to GPIO when doing board_mmc_getcd.
  242. */
  243. static iomux_v3_cfg_t const usdhc2_cd_pad =
  244. MX6_PAD_NAND_DATA03__GPIO4_IO05 | MUX_PAD_CTRL(USDHC_DAT3_CD_PAD_CTRL);
  245. static iomux_v3_cfg_t const usdhc2_dat3_pad =
  246. MX6_PAD_NAND_DATA03__USDHC2_DATA3 |
  247. MUX_PAD_CTRL(USDHC_DAT3_CD_PAD_CTRL);
  248. #endif
  249. static void setup_iomux_uart(void)
  250. {
  251. imx_iomux_v3_setup_multiple_pads(uart1_pads, ARRAY_SIZE(uart1_pads));
  252. }
  253. #ifdef CONFIG_FSL_QSPI
  254. #define QSPI_PAD_CTRL1 \
  255. (PAD_CTL_SRE_FAST | PAD_CTL_SPEED_MED | \
  256. PAD_CTL_PKE | PAD_CTL_PUE | PAD_CTL_PUS_47K_UP | PAD_CTL_DSE_120ohm)
  257. static iomux_v3_cfg_t const quadspi_pads[] = {
  258. MX6_PAD_NAND_WP_B__QSPI_A_SCLK | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  259. MX6_PAD_NAND_READY_B__QSPI_A_DATA00 | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  260. MX6_PAD_NAND_CE0_B__QSPI_A_DATA01 | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  261. MX6_PAD_NAND_CE1_B__QSPI_A_DATA02 | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  262. MX6_PAD_NAND_CLE__QSPI_A_DATA03 | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  263. MX6_PAD_NAND_DQS__QSPI_A_SS0_B | MUX_PAD_CTRL(QSPI_PAD_CTRL1),
  264. };
  265. static int board_qspi_init(void)
  266. {
  267. /* Set the iomux */
  268. imx_iomux_v3_setup_multiple_pads(quadspi_pads,
  269. ARRAY_SIZE(quadspi_pads));
  270. /* Set the clock */
  271. enable_qspi_clk(0);
  272. return 0;
  273. }
  274. #endif
  275. #ifdef CONFIG_FSL_ESDHC
  276. static struct fsl_esdhc_cfg usdhc_cfg[2] = {
  277. {USDHC1_BASE_ADDR, 0, 4},
  278. #if defined(CONFIG_MX6UL_14X14_EVK_EMMC_REWORK)
  279. {USDHC2_BASE_ADDR, 0, 8},
  280. #else
  281. {USDHC2_BASE_ADDR, 0, 4},
  282. #endif
  283. };
  284. #define USDHC1_CD_GPIO IMX_GPIO_NR(1, 19)
  285. #define USDHC1_PWR_GPIO IMX_GPIO_NR(1, 9)
  286. #define USDHC2_CD_GPIO IMX_GPIO_NR(4, 5)
  287. #define USDHC2_PWR_GPIO IMX_GPIO_NR(4, 10)
  288. int board_mmc_getcd(struct mmc *mmc)
  289. {
  290. struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
  291. int ret = 0;
  292. switch (cfg->esdhc_base) {
  293. case USDHC1_BASE_ADDR:
  294. ret = !gpio_get_value(USDHC1_CD_GPIO);
  295. break;
  296. case USDHC2_BASE_ADDR:
  297. #if defined(CONFIG_MX6UL_14X14_EVK_EMMC_REWORK)
  298. ret = 1;
  299. #else
  300. imx_iomux_v3_setup_pad(usdhc2_cd_pad);
  301. gpio_direction_input(USDHC2_CD_GPIO);
  302. /*
  303. * Since it is the DAT3 pin, this pin is pulled to
  304. * low voltage if no card
  305. */
  306. ret = gpio_get_value(USDHC2_CD_GPIO);
  307. imx_iomux_v3_setup_pad(usdhc2_dat3_pad);
  308. #endif
  309. break;
  310. }
  311. return ret;
  312. }
  313. int board_mmc_init(bd_t *bis)
  314. {
  315. #ifdef CONFIG_SPL_BUILD
  316. #if defined(CONFIG_MX6UL_14X14_EVK_EMMC_REWORK)
  317. imx_iomux_v3_setup_multiple_pads(usdhc2_emmc_pads,
  318. ARRAY_SIZE(usdhc2_emmc_pads));
  319. #else
  320. imx_iomux_v3_setup_multiple_pads(usdhc2_pads, ARRAY_SIZE(usdhc2_pads));
  321. #endif
  322. gpio_direction_output(USDHC2_PWR_GPIO, 0);
  323. udelay(500);
  324. gpio_direction_output(USDHC2_PWR_GPIO, 1);
  325. usdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC2_CLK);
  326. return fsl_esdhc_initialize(bis, &usdhc_cfg[1]);
  327. #else
  328. int i, ret;
  329. /*
  330. * According to the board_mmc_init() the following map is done:
  331. * (U-Boot device node) (Physical Port)
  332. * mmc0 USDHC1
  333. * mmc1 USDHC2
  334. */
  335. for (i = 0; i < CONFIG_SYS_FSL_USDHC_NUM; i++) {
  336. switch (i) {
  337. case 0:
  338. imx_iomux_v3_setup_multiple_pads(
  339. usdhc1_pads, ARRAY_SIZE(usdhc1_pads));
  340. gpio_direction_input(USDHC1_CD_GPIO);
  341. usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
  342. gpio_direction_output(USDHC1_PWR_GPIO, 0);
  343. udelay(500);
  344. gpio_direction_output(USDHC1_PWR_GPIO, 1);
  345. break;
  346. case 1:
  347. #if defined(CONFIG_MX6UL_14X14_EVK_EMMC_REWORK)
  348. imx_iomux_v3_setup_multiple_pads(
  349. usdhc2_emmc_pads, ARRAY_SIZE(usdhc2_emmc_pads));
  350. #else
  351. imx_iomux_v3_setup_multiple_pads(
  352. usdhc2_pads, ARRAY_SIZE(usdhc2_pads));
  353. #endif
  354. gpio_direction_output(USDHC2_PWR_GPIO, 0);
  355. udelay(500);
  356. gpio_direction_output(USDHC2_PWR_GPIO, 1);
  357. usdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC2_CLK);
  358. break;
  359. default:
  360. printf("Warning: you configured more USDHC controllers (%d) than supported by the board\n", i + 1);
  361. return -EINVAL;
  362. }
  363. ret = fsl_esdhc_initialize(bis, &usdhc_cfg[i]);
  364. if (ret) {
  365. printf("Warning: failed to initialize mmc dev %d\n", i);
  366. return ret;
  367. }
  368. }
  369. #endif
  370. return 0;
  371. }
  372. #endif
  373. #ifdef CONFIG_USB_EHCI_MX6
  374. #define USB_OTHERREGS_OFFSET 0x800
  375. #define UCTRL_PWR_POL (1 << 9)
  376. static iomux_v3_cfg_t const usb_otg_pads[] = {
  377. MX6_PAD_GPIO1_IO00__ANATOP_OTG1_ID | MUX_PAD_CTRL(NO_PAD_CTRL),
  378. };
  379. /* At default the 3v3 enables the MIC2026 for VBUS power */
  380. static void setup_usb(void)
  381. {
  382. imx_iomux_v3_setup_multiple_pads(usb_otg_pads,
  383. ARRAY_SIZE(usb_otg_pads));
  384. }
  385. int board_usb_phy_mode(int port)
  386. {
  387. if (port == 1)
  388. return USB_INIT_HOST;
  389. else
  390. return usb_phy_mode(port);
  391. }
  392. int board_ehci_hcd_init(int port)
  393. {
  394. u32 *usbnc_usb_ctrl;
  395. if (port > 1)
  396. return -EINVAL;
  397. usbnc_usb_ctrl = (u32 *)(USB_BASE_ADDR + USB_OTHERREGS_OFFSET +
  398. port * 4);
  399. /* Set Power polarity */
  400. setbits_le32(usbnc_usb_ctrl, UCTRL_PWR_POL);
  401. return 0;
  402. }
  403. #endif
  404. #ifdef CONFIG_FEC_MXC
  405. /*
  406. * pin conflicts for fec1 and fec2, GPIO1_IO06 and GPIO1_IO07 can only
  407. * be used for ENET1 or ENET2, cannot be used for both.
  408. */
  409. static iomux_v3_cfg_t const fec1_pads[] = {
  410. MX6_PAD_GPIO1_IO06__ENET1_MDIO | MUX_PAD_CTRL(MDIO_PAD_CTRL),
  411. MX6_PAD_GPIO1_IO07__ENET1_MDC | MUX_PAD_CTRL(ENET_PAD_CTRL),
  412. MX6_PAD_ENET1_TX_DATA0__ENET1_TDATA00 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  413. MX6_PAD_ENET1_TX_DATA1__ENET1_TDATA01 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  414. MX6_PAD_ENET1_TX_EN__ENET1_TX_EN | MUX_PAD_CTRL(ENET_PAD_CTRL),
  415. MX6_PAD_ENET1_TX_CLK__ENET1_REF_CLK1 | MUX_PAD_CTRL(ENET_CLK_PAD_CTRL),
  416. MX6_PAD_ENET1_RX_DATA0__ENET1_RDATA00 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  417. MX6_PAD_ENET1_RX_DATA1__ENET1_RDATA01 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  418. MX6_PAD_ENET1_RX_ER__ENET1_RX_ER | MUX_PAD_CTRL(ENET_PAD_CTRL),
  419. MX6_PAD_ENET1_RX_EN__ENET1_RX_EN | MUX_PAD_CTRL(ENET_PAD_CTRL),
  420. };
  421. static iomux_v3_cfg_t const fec2_pads[] = {
  422. MX6_PAD_GPIO1_IO06__ENET2_MDIO | MUX_PAD_CTRL(MDIO_PAD_CTRL),
  423. MX6_PAD_GPIO1_IO07__ENET2_MDC | MUX_PAD_CTRL(ENET_PAD_CTRL),
  424. MX6_PAD_ENET2_TX_DATA0__ENET2_TDATA00 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  425. MX6_PAD_ENET2_TX_DATA1__ENET2_TDATA01 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  426. MX6_PAD_ENET2_TX_CLK__ENET2_REF_CLK2 | MUX_PAD_CTRL(ENET_CLK_PAD_CTRL),
  427. MX6_PAD_ENET2_TX_EN__ENET2_TX_EN | MUX_PAD_CTRL(ENET_PAD_CTRL),
  428. MX6_PAD_ENET2_RX_DATA0__ENET2_RDATA00 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  429. MX6_PAD_ENET2_RX_DATA1__ENET2_RDATA01 | MUX_PAD_CTRL(ENET_PAD_CTRL),
  430. MX6_PAD_ENET2_RX_EN__ENET2_RX_EN | MUX_PAD_CTRL(ENET_PAD_CTRL),
  431. MX6_PAD_ENET2_RX_ER__ENET2_RX_ER | MUX_PAD_CTRL(ENET_PAD_CTRL),
  432. };
  433. static void setup_iomux_fec(int fec_id)
  434. {
  435. if (fec_id == 0)
  436. imx_iomux_v3_setup_multiple_pads(fec1_pads,
  437. ARRAY_SIZE(fec1_pads));
  438. else
  439. imx_iomux_v3_setup_multiple_pads(fec2_pads,
  440. ARRAY_SIZE(fec2_pads));
  441. }
  442. int board_eth_init(bd_t *bis)
  443. {
  444. setup_iomux_fec(CONFIG_FEC_ENET_DEV);
  445. return fecmxc_initialize_multi(bis, CONFIG_FEC_ENET_DEV,
  446. CONFIG_FEC_MXC_PHYADDR, IMX_FEC_BASE);
  447. }
  448. static int setup_fec(int fec_id)
  449. {
  450. struct iomuxc *const iomuxc_regs = (struct iomuxc *)IOMUXC_BASE_ADDR;
  451. int ret;
  452. if (fec_id == 0) {
  453. /*
  454. * Use 50M anatop loopback REF_CLK1 for ENET1,
  455. * clear gpr1[13], set gpr1[17].
  456. */
  457. clrsetbits_le32(&iomuxc_regs->gpr[1], IOMUX_GPR1_FEC1_MASK,
  458. IOMUX_GPR1_FEC1_CLOCK_MUX1_SEL_MASK);
  459. } else {
  460. /*
  461. * Use 50M anatop loopback REF_CLK2 for ENET2,
  462. * clear gpr1[14], set gpr1[18].
  463. */
  464. clrsetbits_le32(&iomuxc_regs->gpr[1], IOMUX_GPR1_FEC2_MASK,
  465. IOMUX_GPR1_FEC2_CLOCK_MUX1_SEL_MASK);
  466. }
  467. ret = enable_fec_anatop_clock(fec_id, ENET_50MHZ);
  468. if (ret)
  469. return ret;
  470. enable_enet_clk(1);
  471. return 0;
  472. }
  473. int board_phy_config(struct phy_device *phydev)
  474. {
  475. phy_write(phydev, MDIO_DEVAD_NONE, 0x1f, 0x8190);
  476. if (phydev->drv->config)
  477. phydev->drv->config(phydev);
  478. return 0;
  479. }
  480. #endif
  481. #ifdef CONFIG_VIDEO_MXS
  482. static iomux_v3_cfg_t const lcd_pads[] = {
  483. MX6_PAD_LCD_CLK__LCDIF_CLK | MUX_PAD_CTRL(LCD_PAD_CTRL),
  484. MX6_PAD_LCD_ENABLE__LCDIF_ENABLE | MUX_PAD_CTRL(LCD_PAD_CTRL),
  485. MX6_PAD_LCD_HSYNC__LCDIF_HSYNC | MUX_PAD_CTRL(LCD_PAD_CTRL),
  486. MX6_PAD_LCD_VSYNC__LCDIF_VSYNC | MUX_PAD_CTRL(LCD_PAD_CTRL),
  487. MX6_PAD_LCD_DATA00__LCDIF_DATA00 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  488. MX6_PAD_LCD_DATA01__LCDIF_DATA01 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  489. MX6_PAD_LCD_DATA02__LCDIF_DATA02 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  490. MX6_PAD_LCD_DATA03__LCDIF_DATA03 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  491. MX6_PAD_LCD_DATA04__LCDIF_DATA04 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  492. MX6_PAD_LCD_DATA05__LCDIF_DATA05 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  493. MX6_PAD_LCD_DATA06__LCDIF_DATA06 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  494. MX6_PAD_LCD_DATA07__LCDIF_DATA07 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  495. MX6_PAD_LCD_DATA08__LCDIF_DATA08 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  496. MX6_PAD_LCD_DATA09__LCDIF_DATA09 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  497. MX6_PAD_LCD_DATA10__LCDIF_DATA10 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  498. MX6_PAD_LCD_DATA11__LCDIF_DATA11 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  499. MX6_PAD_LCD_DATA12__LCDIF_DATA12 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  500. MX6_PAD_LCD_DATA13__LCDIF_DATA13 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  501. MX6_PAD_LCD_DATA14__LCDIF_DATA14 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  502. MX6_PAD_LCD_DATA15__LCDIF_DATA15 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  503. MX6_PAD_LCD_DATA16__LCDIF_DATA16 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  504. MX6_PAD_LCD_DATA17__LCDIF_DATA17 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  505. MX6_PAD_LCD_DATA18__LCDIF_DATA18 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  506. MX6_PAD_LCD_DATA19__LCDIF_DATA19 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  507. MX6_PAD_LCD_DATA20__LCDIF_DATA20 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  508. MX6_PAD_LCD_DATA21__LCDIF_DATA21 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  509. MX6_PAD_LCD_DATA22__LCDIF_DATA22 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  510. MX6_PAD_LCD_DATA23__LCDIF_DATA23 | MUX_PAD_CTRL(LCD_PAD_CTRL),
  511. /* LCD_RST */
  512. MX6_PAD_SNVS_TAMPER9__GPIO5_IO09 | MUX_PAD_CTRL(NO_PAD_CTRL),
  513. /* Use GPIO for Brightness adjustment, duty cycle = period. */
  514. MX6_PAD_GPIO1_IO08__GPIO1_IO08 | MUX_PAD_CTRL(NO_PAD_CTRL),
  515. };
  516. static int setup_lcd(void)
  517. {
  518. enable_lcdif_clock(LCDIF1_BASE_ADDR, 1);
  519. imx_iomux_v3_setup_multiple_pads(lcd_pads, ARRAY_SIZE(lcd_pads));
  520. /* Reset the LCD */
  521. gpio_direction_output(IMX_GPIO_NR(5, 9) , 0);
  522. udelay(500);
  523. gpio_direction_output(IMX_GPIO_NR(5, 9) , 1);
  524. /* Set Brightness to high */
  525. gpio_direction_output(IMX_GPIO_NR(1, 8) , 1);
  526. return 0;
  527. }
  528. #endif
  529. int board_early_init_f(void)
  530. {
  531. setup_iomux_uart();
  532. return 0;
  533. }
  534. int board_init(void)
  535. {
  536. /* Address of boot parameters */
  537. gd->bd->bi_boot_params = PHYS_SDRAM + 0x100;
  538. imx_iomux_v3_setup_multiple_pads(iox_pads, ARRAY_SIZE(iox_pads));
  539. iox74lv_init();
  540. #ifdef CONFIG_SYS_I2C_MXC
  541. setup_i2c(0, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info1);
  542. #endif
  543. #ifdef CONFIG_FEC_MXC
  544. setup_fec(CONFIG_FEC_ENET_DEV);
  545. #endif
  546. #ifdef CONFIG_USB_EHCI_MX6
  547. setup_usb();
  548. #endif
  549. #ifdef CONFIG_FSL_QSPI
  550. board_qspi_init();
  551. #endif
  552. #ifdef CONFIG_VIDEO_MXS
  553. setup_lcd();
  554. #endif
  555. return 0;
  556. }
  557. #ifdef CONFIG_CMD_BMODE
  558. static const struct boot_mode board_boot_modes[] = {
  559. /* 4 bit bus width */
  560. {"sd1", MAKE_CFGVAL(0x42, 0x20, 0x00, 0x00)},
  561. {"sd2", MAKE_CFGVAL(0x40, 0x28, 0x00, 0x00)},
  562. {"qspi1", MAKE_CFGVAL(0x10, 0x00, 0x00, 0x00)},
  563. {NULL, 0},
  564. };
  565. #endif
  566. int board_late_init(void)
  567. {
  568. #ifdef CONFIG_CMD_BMODE
  569. add_board_boot_modes(board_boot_modes);
  570. #endif
  571. #ifdef CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
  572. env_set("board_name", "EVK");
  573. if (is_mx6ul_9x9_evk())
  574. env_set("board_rev", "9X9");
  575. else
  576. env_set("board_rev", "14X14");
  577. #endif
  578. return 0;
  579. }
  580. int checkboard(void)
  581. {
  582. if (is_mx6ul_9x9_evk())
  583. puts("Board: MX6UL 9x9 EVK\n");
  584. else
  585. puts("Board: MX6UL 14x14 EVK\n");
  586. return 0;
  587. }
  588. #ifdef CONFIG_SPL_BUILD
  589. #include <linux/libfdt.h>
  590. #include <spl.h>
  591. #include <asm/arch/mx6-ddr.h>
  592. static struct mx6ul_iomux_grp_regs mx6_grp_ioregs = {
  593. .grp_addds = 0x00000030,
  594. .grp_ddrmode_ctl = 0x00020000,
  595. .grp_b0ds = 0x00000030,
  596. .grp_ctlds = 0x00000030,
  597. .grp_b1ds = 0x00000030,
  598. .grp_ddrpke = 0x00000000,
  599. .grp_ddrmode = 0x00020000,
  600. #ifdef CONFIG_TARGET_MX6UL_9X9_EVK
  601. .grp_ddr_type = 0x00080000,
  602. #else
  603. .grp_ddr_type = 0x000c0000,
  604. #endif
  605. };
  606. #ifdef CONFIG_TARGET_MX6UL_9X9_EVK
  607. static struct mx6ul_iomux_ddr_regs mx6_ddr_ioregs = {
  608. .dram_dqm0 = 0x00000030,
  609. .dram_dqm1 = 0x00000030,
  610. .dram_ras = 0x00000030,
  611. .dram_cas = 0x00000030,
  612. .dram_odt0 = 0x00000000,
  613. .dram_odt1 = 0x00000000,
  614. .dram_sdba2 = 0x00000000,
  615. .dram_sdclk_0 = 0x00000030,
  616. .dram_sdqs0 = 0x00003030,
  617. .dram_sdqs1 = 0x00003030,
  618. .dram_reset = 0x00000030,
  619. };
  620. static struct mx6_mmdc_calibration mx6_mmcd_calib = {
  621. .p0_mpwldectrl0 = 0x00000000,
  622. .p0_mpdgctrl0 = 0x20000000,
  623. .p0_mprddlctl = 0x4040484f,
  624. .p0_mpwrdlctl = 0x40405247,
  625. .mpzqlp2ctl = 0x1b4700c7,
  626. };
  627. static struct mx6_lpddr2_cfg mem_ddr = {
  628. .mem_speed = 800,
  629. .density = 2,
  630. .width = 16,
  631. .banks = 4,
  632. .rowaddr = 14,
  633. .coladdr = 10,
  634. .trcd_lp = 1500,
  635. .trppb_lp = 1500,
  636. .trpab_lp = 2000,
  637. .trasmin = 4250,
  638. };
  639. struct mx6_ddr_sysinfo ddr_sysinfo = {
  640. .dsize = 0,
  641. .cs_density = 18,
  642. .ncs = 1,
  643. .cs1_mirror = 0,
  644. .walat = 0,
  645. .ralat = 5,
  646. .mif3_mode = 3,
  647. .bi_on = 1,
  648. .rtt_wr = 0, /* LPDDR2 does not need rtt_wr rtt_nom */
  649. .rtt_nom = 0,
  650. .sde_to_rst = 0, /* LPDDR2 does not need this field */
  651. .rst_to_cke = 0x10, /* JEDEC value for LPDDR2: 200us */
  652. .ddr_type = DDR_TYPE_LPDDR2,
  653. .refsel = 0, /* Refresh cycles at 64KHz */
  654. .refr = 3, /* 4 refresh commands per refresh cycle */
  655. };
  656. #else
  657. static struct mx6ul_iomux_ddr_regs mx6_ddr_ioregs = {
  658. .dram_dqm0 = 0x00000030,
  659. .dram_dqm1 = 0x00000030,
  660. .dram_ras = 0x00000030,
  661. .dram_cas = 0x00000030,
  662. .dram_odt0 = 0x00000030,
  663. .dram_odt1 = 0x00000030,
  664. .dram_sdba2 = 0x00000000,
  665. .dram_sdclk_0 = 0x00000030,
  666. .dram_sdqs0 = 0x00000030,
  667. .dram_sdqs1 = 0x00000030,
  668. .dram_reset = 0x00000030,
  669. };
  670. static struct mx6_mmdc_calibration mx6_mmcd_calib = {
  671. .p0_mpwldectrl0 = 0x00000000,
  672. .p0_mpdgctrl0 = 0x41570155,
  673. .p0_mprddlctl = 0x4040474A,
  674. .p0_mpwrdlctl = 0x40405550,
  675. };
  676. struct mx6_ddr_sysinfo ddr_sysinfo = {
  677. .dsize = 0,
  678. .cs_density = 20,
  679. .ncs = 1,
  680. .cs1_mirror = 0,
  681. .rtt_wr = 2,
  682. .rtt_nom = 1, /* RTT_Nom = RZQ/2 */
  683. .walat = 0, /* Write additional latency */
  684. .ralat = 5, /* Read additional latency */
  685. .mif3_mode = 3, /* Command prediction working mode */
  686. .bi_on = 1, /* Bank interleaving enabled */
  687. .sde_to_rst = 0x10, /* 14 cycles, 200us (JEDEC default) */
  688. .rst_to_cke = 0x23, /* 33 cycles, 500us (JEDEC default) */
  689. .ddr_type = DDR_TYPE_DDR3,
  690. .refsel = 0, /* Refresh cycles at 64KHz */
  691. .refr = 1, /* 2 refresh commands per refresh cycle */
  692. };
  693. static struct mx6_ddr3_cfg mem_ddr = {
  694. .mem_speed = 800,
  695. .density = 4,
  696. .width = 16,
  697. .banks = 8,
  698. .rowaddr = 15,
  699. .coladdr = 10,
  700. .pagesz = 2,
  701. .trcd = 1375,
  702. .trcmin = 4875,
  703. .trasmin = 3500,
  704. };
  705. #endif
  706. static void ccgr_init(void)
  707. {
  708. struct mxc_ccm_reg *ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR;
  709. writel(0xFFFFFFFF, &ccm->CCGR0);
  710. writel(0xFFFFFFFF, &ccm->CCGR1);
  711. writel(0xFFFFFFFF, &ccm->CCGR2);
  712. writel(0xFFFFFFFF, &ccm->CCGR3);
  713. writel(0xFFFFFFFF, &ccm->CCGR4);
  714. writel(0xFFFFFFFF, &ccm->CCGR5);
  715. writel(0xFFFFFFFF, &ccm->CCGR6);
  716. writel(0xFFFFFFFF, &ccm->CCGR7);
  717. }
  718. static void spl_dram_init(void)
  719. {
  720. mx6ul_dram_iocfg(mem_ddr.width, &mx6_ddr_ioregs, &mx6_grp_ioregs);
  721. mx6_dram_cfg(&ddr_sysinfo, &mx6_mmcd_calib, &mem_ddr);
  722. }
  723. void board_init_f(ulong dummy)
  724. {
  725. ccgr_init();
  726. /* setup AIPS and disable watchdog */
  727. arch_cpu_init();
  728. /* iomux and setup of i2c */
  729. board_early_init_f();
  730. /* setup GP timer */
  731. timer_init();
  732. /* UART clocks enabled and gd valid - init serial console */
  733. preloader_console_init();
  734. /* DDR initialization */
  735. spl_dram_init();
  736. /* Clear the BSS. */
  737. memset(__bss_start, 0, __bss_end - __bss_start);
  738. /* load/boot image from boot device */
  739. board_init_r(NULL, 0);
  740. }
  741. #endif