xref: /rk3399_rockchip-uboot/board/freescale/mx53evk/mx53evk.c (revision a2ac1b3a7d8e685e8fe3805b3169f3dac5c06cf8)
194391fbcSLiu Hui-R64343 /*
294391fbcSLiu Hui-R64343  * (C) Copyright 2010 Freescale Semiconductor, Inc.
394391fbcSLiu Hui-R64343  *
494391fbcSLiu Hui-R64343  * See file CREDITS for list of people who contributed to this
594391fbcSLiu Hui-R64343  * project.
694391fbcSLiu Hui-R64343  *
794391fbcSLiu Hui-R64343  * This program is free software; you can redistribute it and/or
894391fbcSLiu Hui-R64343  * modify it under the terms of the GNU General Public License as
994391fbcSLiu Hui-R64343  * published by the Free Software Foundation; either version 2 of
1094391fbcSLiu Hui-R64343  * the License, or (at your option) any later version.
1194391fbcSLiu Hui-R64343  *
1294391fbcSLiu Hui-R64343  * This program is distributed in the hope that it will be useful,
1394391fbcSLiu Hui-R64343  * but WITHOUT ANY WARRANTY; without even the implied warranty of
1494391fbcSLiu Hui-R64343  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
1594391fbcSLiu Hui-R64343  * GNU General Public License for more details.
1694391fbcSLiu Hui-R64343  *
1794391fbcSLiu Hui-R64343  * You should have received a copy of the GNU General Public License
1894391fbcSLiu Hui-R64343  * along with this program; if not, write to the Free Software
1994391fbcSLiu Hui-R64343  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
2094391fbcSLiu Hui-R64343  * MA 02111-1307 USA
2194391fbcSLiu Hui-R64343  */
2294391fbcSLiu Hui-R64343 
2394391fbcSLiu Hui-R64343 #include <common.h>
2494391fbcSLiu Hui-R64343 #include <asm/io.h>
2594391fbcSLiu Hui-R64343 #include <asm/arch/imx-regs.h>
2694391fbcSLiu Hui-R64343 #include <asm/arch/mx5x_pins.h>
2794391fbcSLiu Hui-R64343 #include <asm/arch/sys_proto.h>
2894391fbcSLiu Hui-R64343 #include <asm/arch/crm_regs.h>
29*a2ac1b3aSBenoît Thébaudeau #include <asm/arch/clock.h>
3094391fbcSLiu Hui-R64343 #include <asm/arch/iomux.h>
3194391fbcSLiu Hui-R64343 #include <asm/errno.h>
320aff384bSTroy Kisky #include <asm/imx-common/boot_mode.h>
3394391fbcSLiu Hui-R64343 #include <netdev.h>
3494391fbcSLiu Hui-R64343 #include <i2c.h>
3594391fbcSLiu Hui-R64343 #include <mmc.h>
3694391fbcSLiu Hui-R64343 #include <fsl_esdhc.h>
37bba1b6cfSStefano Babic #include <pmic.h>
3894391fbcSLiu Hui-R64343 #include <fsl_pmic.h>
39f7a36474SStefano Babic #include <asm/gpio.h>
4094391fbcSLiu Hui-R64343 #include <mc13892.h>
4194391fbcSLiu Hui-R64343 
4294391fbcSLiu Hui-R64343 DECLARE_GLOBAL_DATA_PTR;
4394391fbcSLiu Hui-R64343 
4494391fbcSLiu Hui-R64343 int dram_init(void)
4594391fbcSLiu Hui-R64343 {
4694391fbcSLiu Hui-R64343 	/* dram_init must store complete ramsize in gd->ram_size */
47a55d23ccSAlbert ARIBAUD 	gd->ram_size = get_ram_size((void *)CONFIG_SYS_SDRAM_BASE,
4894391fbcSLiu Hui-R64343 				PHYS_SDRAM_1_SIZE);
4994391fbcSLiu Hui-R64343 	return 0;
5094391fbcSLiu Hui-R64343 }
5194391fbcSLiu Hui-R64343 
5294391fbcSLiu Hui-R64343 static void setup_iomux_uart(void)
5394391fbcSLiu Hui-R64343 {
5494391fbcSLiu Hui-R64343 	/* UART1 RXD */
5594391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_CSI0_D11, IOMUX_CONFIG_ALT2);
5694391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_CSI0_D11,
5794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
5894391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
5994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
6094391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
6194391fbcSLiu Hui-R64343 	mxc_iomux_set_input(MX53_UART1_IPP_UART_RXD_MUX_SELECT_INPUT, 0x1);
6294391fbcSLiu Hui-R64343 
6394391fbcSLiu Hui-R64343 	/* UART1 TXD */
6494391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_CSI0_D10, IOMUX_CONFIG_ALT2);
6594391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_CSI0_D10,
6694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
6794391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
6894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
6994391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
7094391fbcSLiu Hui-R64343 }
7194391fbcSLiu Hui-R64343 
7294391fbcSLiu Hui-R64343 static void setup_i2c(unsigned int port_number)
7394391fbcSLiu Hui-R64343 {
7494391fbcSLiu Hui-R64343 	switch (port_number) {
7594391fbcSLiu Hui-R64343 	case 0:
7694391fbcSLiu Hui-R64343 		/* i2c1 SDA */
7794391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_CSI0_D8,
7894391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
7994391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C1_IPP_SDA_IN_SELECT_INPUT,
8094391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
8194391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_CSI0_D8,
8294391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
8394391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
8494391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
8594391fbcSLiu Hui-R64343 		/* i2c1 SCL */
8694391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_CSI0_D9,
8794391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
8894391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C1_IPP_SCL_IN_SELECT_INPUT,
8994391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
9094391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_CSI0_D9,
9194391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
9294391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
9394391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
9494391fbcSLiu Hui-R64343 		break;
9594391fbcSLiu Hui-R64343 	case 1:
9694391fbcSLiu Hui-R64343 		/* i2c2 SDA */
9794391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_KEY_ROW3,
9894391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT4 | IOMUX_CONFIG_SION);
9994391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C2_IPP_SDA_IN_SELECT_INPUT,
10094391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
10194391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_KEY_ROW3,
10294391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
10394391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
10494391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
10594391fbcSLiu Hui-R64343 
10694391fbcSLiu Hui-R64343 		/* i2c2 SCL */
10794391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_KEY_COL3,
10894391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT4 | IOMUX_CONFIG_SION);
10994391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C2_IPP_SCL_IN_SELECT_INPUT,
11094391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
11194391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_KEY_COL3,
11294391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
11394391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
11494391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
11594391fbcSLiu Hui-R64343 		break;
11694391fbcSLiu Hui-R64343 	default:
11794391fbcSLiu Hui-R64343 		printf("Warning: Wrong I2C port number\n");
11894391fbcSLiu Hui-R64343 		break;
11994391fbcSLiu Hui-R64343 	}
12094391fbcSLiu Hui-R64343 }
12194391fbcSLiu Hui-R64343 
12294391fbcSLiu Hui-R64343 void power_init(void)
12394391fbcSLiu Hui-R64343 {
12494391fbcSLiu Hui-R64343 	unsigned int val;
125bba1b6cfSStefano Babic 	struct pmic *p;
126bba1b6cfSStefano Babic 
127bba1b6cfSStefano Babic 	pmic_init();
128bba1b6cfSStefano Babic 	p = get_pmic();
12994391fbcSLiu Hui-R64343 
13094391fbcSLiu Hui-R64343 	/* Set VDDA to 1.25V */
131bba1b6cfSStefano Babic 	pmic_reg_read(p, REG_SW_2, &val);
13294391fbcSLiu Hui-R64343 	val &= ~SWX_OUT_MASK;
13394391fbcSLiu Hui-R64343 	val |= SWX_OUT_1_25;
134bba1b6cfSStefano Babic 	pmic_reg_write(p, REG_SW_2, val);
13594391fbcSLiu Hui-R64343 
13694391fbcSLiu Hui-R64343 	/*
13794391fbcSLiu Hui-R64343 	 * Need increase VCC and VDDA to 1.3V
13894391fbcSLiu Hui-R64343 	 * according to MX53 IC TO2 datasheet.
13994391fbcSLiu Hui-R64343 	 */
14094391fbcSLiu Hui-R64343 	if (is_soc_rev(CHIP_REV_2_0) == 0) {
14194391fbcSLiu Hui-R64343 		/* Set VCC to 1.3V for TO2 */
142bba1b6cfSStefano Babic 		pmic_reg_read(p, REG_SW_1, &val);
14394391fbcSLiu Hui-R64343 		val &= ~SWX_OUT_MASK;
14494391fbcSLiu Hui-R64343 		val |= SWX_OUT_1_30;
145bba1b6cfSStefano Babic 		pmic_reg_write(p, REG_SW_1, val);
14694391fbcSLiu Hui-R64343 
14794391fbcSLiu Hui-R64343 		/* Set VDDA to 1.3V for TO2 */
148bba1b6cfSStefano Babic 		pmic_reg_read(p, REG_SW_2, &val);
14994391fbcSLiu Hui-R64343 		val &= ~SWX_OUT_MASK;
15094391fbcSLiu Hui-R64343 		val |= SWX_OUT_1_30;
151bba1b6cfSStefano Babic 		pmic_reg_write(p, REG_SW_2, val);
15294391fbcSLiu Hui-R64343 	}
15394391fbcSLiu Hui-R64343 }
15494391fbcSLiu Hui-R64343 
15594391fbcSLiu Hui-R64343 static void setup_iomux_fec(void)
15694391fbcSLiu Hui-R64343 {
15794391fbcSLiu Hui-R64343 	/*FEC_MDIO*/
15894391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_MDIO, IOMUX_CONFIG_ALT0);
15994391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_MDIO,
16094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
16194391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
16294391fbcSLiu Hui-R64343 				PAD_CTL_22K_PU | PAD_CTL_ODE_OPENDRAIN_ENABLE);
16394391fbcSLiu Hui-R64343 	mxc_iomux_set_input(MX53_FEC_FEC_MDI_SELECT_INPUT, 0x1);
16494391fbcSLiu Hui-R64343 
16594391fbcSLiu Hui-R64343 	/*FEC_MDC*/
16694391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_MDC, IOMUX_CONFIG_ALT0);
16794391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_MDC, PAD_CTL_DRV_HIGH);
16894391fbcSLiu Hui-R64343 
16994391fbcSLiu Hui-R64343 	/* FEC RXD1 */
17094391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RXD1, IOMUX_CONFIG_ALT0);
17194391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RXD1,
17294391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
17394391fbcSLiu Hui-R64343 
17494391fbcSLiu Hui-R64343 	/* FEC RXD0 */
17594391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RXD0, IOMUX_CONFIG_ALT0);
17694391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RXD0,
17794391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
17894391fbcSLiu Hui-R64343 
17994391fbcSLiu Hui-R64343 	 /* FEC TXD1 */
18094391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TXD1, IOMUX_CONFIG_ALT0);
18194391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TXD1, PAD_CTL_DRV_HIGH);
18294391fbcSLiu Hui-R64343 
18394391fbcSLiu Hui-R64343 	/* FEC TXD0 */
18494391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TXD0, IOMUX_CONFIG_ALT0);
18594391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TXD0, PAD_CTL_DRV_HIGH);
18694391fbcSLiu Hui-R64343 
18794391fbcSLiu Hui-R64343 	/* FEC TX_EN */
18894391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TX_EN, IOMUX_CONFIG_ALT0);
18994391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TX_EN, PAD_CTL_DRV_HIGH);
19094391fbcSLiu Hui-R64343 
19194391fbcSLiu Hui-R64343 	/* FEC TX_CLK */
19294391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_REF_CLK, IOMUX_CONFIG_ALT0);
19394391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_REF_CLK,
19494391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
19594391fbcSLiu Hui-R64343 
19694391fbcSLiu Hui-R64343 	/* FEC RX_ER */
19794391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RX_ER, IOMUX_CONFIG_ALT0);
19894391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RX_ER,
19994391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
20094391fbcSLiu Hui-R64343 
20194391fbcSLiu Hui-R64343 	/* FEC CRS */
20294391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_CRS_DV, IOMUX_CONFIG_ALT0);
20394391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_CRS_DV,
20494391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
20594391fbcSLiu Hui-R64343 }
20694391fbcSLiu Hui-R64343 
20794391fbcSLiu Hui-R64343 #ifdef CONFIG_FSL_ESDHC
20894391fbcSLiu Hui-R64343 struct fsl_esdhc_cfg esdhc_cfg[2] = {
20916e43f35SBenoît Thébaudeau 	{MMC_SDHC1_BASE_ADDR},
21016e43f35SBenoît Thébaudeau 	{MMC_SDHC3_BASE_ADDR},
21194391fbcSLiu Hui-R64343 };
21294391fbcSLiu Hui-R64343 
213314284b1SThierry Reding int board_mmc_getcd(struct mmc *mmc)
21494391fbcSLiu Hui-R64343 {
21594391fbcSLiu Hui-R64343 	struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
216314284b1SThierry Reding 	int ret;
21794391fbcSLiu Hui-R64343 
218a146dca5SFabio Estevam 	mxc_request_iomux(MX53_PIN_EIM_DA11, IOMUX_CONFIG_ALT1);
21992550708SAshok Kumar Reddy 	gpio_direction_input(IMX_GPIO_NR(3, 11));
220a146dca5SFabio Estevam 	mxc_request_iomux(MX53_PIN_EIM_DA13, IOMUX_CONFIG_ALT1);
22192550708SAshok Kumar Reddy 	gpio_direction_input(IMX_GPIO_NR(3, 13));
222a146dca5SFabio Estevam 
22394391fbcSLiu Hui-R64343 	if (cfg->esdhc_base == MMC_SDHC1_BASE_ADDR)
22492550708SAshok Kumar Reddy 		ret = !gpio_get_value(IMX_GPIO_NR(3, 13));
22594391fbcSLiu Hui-R64343 	else
22692550708SAshok Kumar Reddy 		ret = !gpio_get_value(IMX_GPIO_NR(3, 11));
22794391fbcSLiu Hui-R64343 
228314284b1SThierry Reding 	return ret;
22994391fbcSLiu Hui-R64343 }
23094391fbcSLiu Hui-R64343 
23194391fbcSLiu Hui-R64343 int board_mmc_init(bd_t *bis)
23294391fbcSLiu Hui-R64343 {
23394391fbcSLiu Hui-R64343 	u32 index;
23494391fbcSLiu Hui-R64343 	s32 status = 0;
23594391fbcSLiu Hui-R64343 
236*a2ac1b3aSBenoît Thébaudeau 	esdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK);
237*a2ac1b3aSBenoît Thébaudeau 	esdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK);
238*a2ac1b3aSBenoît Thébaudeau 
23994391fbcSLiu Hui-R64343 	for (index = 0; index < CONFIG_SYS_FSL_ESDHC_NUM; index++) {
24094391fbcSLiu Hui-R64343 		switch (index) {
24194391fbcSLiu Hui-R64343 		case 0:
24294391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_CMD, IOMUX_CONFIG_ALT0);
24394391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_CLK, IOMUX_CONFIG_ALT0);
24494391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA0,
24594391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
24694391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA1,
24794391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
24894391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA2,
24994391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
25094391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA3,
25194391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
25294391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_EIM_DA13,
25394391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT1);
25494391fbcSLiu Hui-R64343 
25594391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_CMD,
25694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
25794391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
25894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
25994391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_CLK,
26094391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
26194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
26294391fbcSLiu Hui-R64343 				PAD_CTL_DRV_HIGH);
26394391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA0,
26494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
26594391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
26694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
26794391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA1,
26894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
26994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
27094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
27194391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA2,
27294391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
27394391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
27494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
27594391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA3,
27694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
27794391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
27894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
27994391fbcSLiu Hui-R64343 			break;
28094391fbcSLiu Hui-R64343 		case 1:
28194391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_RESET_B,
28294391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT2);
28394391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_IORDY,
28494391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT2);
28594391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA8,
28694391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28794391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA9,
28894391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28994391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA10,
29094391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29194391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA11,
29294391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29394391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA0,
29494391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29594391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA1,
29694391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29794391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA2,
29894391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29994391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA3,
30094391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
30194391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_EIM_DA11,
30294391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT1);
30394391fbcSLiu Hui-R64343 
30494391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_RESET_B,
30594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
30694391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
30794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
30894391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_IORDY,
30994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
31094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
31194391fbcSLiu Hui-R64343 				PAD_CTL_DRV_HIGH);
31294391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA8,
31394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
31494391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
31594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
31694391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA9,
31794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
31894391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
31994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32094391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA10,
32194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
32294391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
32394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32494391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA11,
32594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
32694391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
32794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32894391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA0,
32994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
33094391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
33194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
33294391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA1,
33394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
33494391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
33594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
33694391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA2,
33794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
33894391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
33994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
34094391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA3,
34194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
34294391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
34394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
34494391fbcSLiu Hui-R64343 
34594391fbcSLiu Hui-R64343 			break;
34694391fbcSLiu Hui-R64343 		default:
34794391fbcSLiu Hui-R64343 			printf("Warning: you configured more ESDHC controller"
34894391fbcSLiu Hui-R64343 				"(%d) as supported by the board(2)\n",
34994391fbcSLiu Hui-R64343 				CONFIG_SYS_FSL_ESDHC_NUM);
35094391fbcSLiu Hui-R64343 			return status;
35194391fbcSLiu Hui-R64343 		}
35294391fbcSLiu Hui-R64343 		status |= fsl_esdhc_initialize(bis, &esdhc_cfg[index]);
35394391fbcSLiu Hui-R64343 	}
35494391fbcSLiu Hui-R64343 
35594391fbcSLiu Hui-R64343 	return status;
35694391fbcSLiu Hui-R64343 }
35794391fbcSLiu Hui-R64343 #endif
35894391fbcSLiu Hui-R64343 
35994391fbcSLiu Hui-R64343 int board_early_init_f(void)
36094391fbcSLiu Hui-R64343 {
36194391fbcSLiu Hui-R64343 	setup_iomux_uart();
36294391fbcSLiu Hui-R64343 	setup_iomux_fec();
36394391fbcSLiu Hui-R64343 
36494391fbcSLiu Hui-R64343 	return 0;
36594391fbcSLiu Hui-R64343 }
36694391fbcSLiu Hui-R64343 
36794391fbcSLiu Hui-R64343 int board_init(void)
36894391fbcSLiu Hui-R64343 {
36994391fbcSLiu Hui-R64343 	/* address of boot parameters */
37094391fbcSLiu Hui-R64343 	gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
37194391fbcSLiu Hui-R64343 
37294391fbcSLiu Hui-R64343 	return 0;
37394391fbcSLiu Hui-R64343 }
37494391fbcSLiu Hui-R64343 
3750aff384bSTroy Kisky #ifdef CONFIG_CMD_BMODE
3760aff384bSTroy Kisky static const struct boot_mode board_boot_modes[] = {
3770aff384bSTroy Kisky 	/* 4 bit bus width */
3780aff384bSTroy Kisky 	{"mmc0",	MAKE_CFGVAL(0x40, 0x20, 0x00, 0x12)},
3790aff384bSTroy Kisky 	{"mmc1",	MAKE_CFGVAL(0x40, 0x20, 0x08, 0x12)},
3800aff384bSTroy Kisky 	{NULL,		0},
3810aff384bSTroy Kisky };
3820aff384bSTroy Kisky #endif
3830aff384bSTroy Kisky 
38494391fbcSLiu Hui-R64343 int board_late_init(void)
38594391fbcSLiu Hui-R64343 {
38694391fbcSLiu Hui-R64343 	setup_i2c(1);
38794391fbcSLiu Hui-R64343 	power_init();
38894391fbcSLiu Hui-R64343 
3890aff384bSTroy Kisky #ifdef CONFIG_CMD_BMODE
3900aff384bSTroy Kisky 	add_board_boot_modes(board_boot_modes);
3910aff384bSTroy Kisky #endif
39294391fbcSLiu Hui-R64343 	return 0;
39394391fbcSLiu Hui-R64343 }
39494391fbcSLiu Hui-R64343 
39594391fbcSLiu Hui-R64343 int checkboard(void)
39694391fbcSLiu Hui-R64343 {
39751958904SJason Liu 	puts("Board: MX53EVK\n");
39894391fbcSLiu Hui-R64343 
39994391fbcSLiu Hui-R64343 	return 0;
40094391fbcSLiu Hui-R64343 }
401