xref: /rk3399_rockchip-uboot/board/freescale/mx53evk/mx53evk.c (revision f7a364745e20c63feaa2a4d2926e92fc2bd7bdc7)
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>
2994391fbcSLiu Hui-R64343 #include <asm/arch/iomux.h>
3094391fbcSLiu Hui-R64343 #include <asm/errno.h>
3194391fbcSLiu Hui-R64343 #include <netdev.h>
3294391fbcSLiu Hui-R64343 #include <i2c.h>
3394391fbcSLiu Hui-R64343 #include <mmc.h>
3494391fbcSLiu Hui-R64343 #include <fsl_esdhc.h>
3594391fbcSLiu Hui-R64343 #include <fsl_pmic.h>
36*f7a36474SStefano Babic #include <asm/gpio.h>
3794391fbcSLiu Hui-R64343 #include <mc13892.h>
3894391fbcSLiu Hui-R64343 
3994391fbcSLiu Hui-R64343 DECLARE_GLOBAL_DATA_PTR;
4094391fbcSLiu Hui-R64343 
4194391fbcSLiu Hui-R64343 u32 get_board_rev(void)
4294391fbcSLiu Hui-R64343 {
4394391fbcSLiu Hui-R64343 	return get_cpu_rev();
4494391fbcSLiu Hui-R64343 }
4594391fbcSLiu Hui-R64343 
4694391fbcSLiu Hui-R64343 int dram_init(void)
4794391fbcSLiu Hui-R64343 {
4894391fbcSLiu Hui-R64343 	/* dram_init must store complete ramsize in gd->ram_size */
49a55d23ccSAlbert ARIBAUD 	gd->ram_size = get_ram_size((void *)CONFIG_SYS_SDRAM_BASE,
5094391fbcSLiu Hui-R64343 				PHYS_SDRAM_1_SIZE);
5194391fbcSLiu Hui-R64343 	return 0;
5294391fbcSLiu Hui-R64343 }
5394391fbcSLiu Hui-R64343 
5494391fbcSLiu Hui-R64343 static void setup_iomux_uart(void)
5594391fbcSLiu Hui-R64343 {
5694391fbcSLiu Hui-R64343 	/* UART1 RXD */
5794391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_CSI0_D11, IOMUX_CONFIG_ALT2);
5894391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_CSI0_D11,
5994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
6094391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
6194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
6294391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
6394391fbcSLiu Hui-R64343 	mxc_iomux_set_input(MX53_UART1_IPP_UART_RXD_MUX_SELECT_INPUT, 0x1);
6494391fbcSLiu Hui-R64343 
6594391fbcSLiu Hui-R64343 	/* UART1 TXD */
6694391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_CSI0_D10, IOMUX_CONFIG_ALT2);
6794391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_CSI0_D10,
6894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
6994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
7094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU |
7194391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
7294391fbcSLiu Hui-R64343 }
7394391fbcSLiu Hui-R64343 
7494391fbcSLiu Hui-R64343 static void setup_i2c(unsigned int port_number)
7594391fbcSLiu Hui-R64343 {
7694391fbcSLiu Hui-R64343 	switch (port_number) {
7794391fbcSLiu Hui-R64343 	case 0:
7894391fbcSLiu Hui-R64343 		/* i2c1 SDA */
7994391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_CSI0_D8,
8094391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
8194391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C1_IPP_SDA_IN_SELECT_INPUT,
8294391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
8394391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_CSI0_D8,
8494391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
8594391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
8694391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
8794391fbcSLiu Hui-R64343 		/* i2c1 SCL */
8894391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_CSI0_D9,
8994391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT5 | IOMUX_CONFIG_SION);
9094391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C1_IPP_SCL_IN_SELECT_INPUT,
9194391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
9294391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_CSI0_D9,
9394391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
9494391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
9594391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
9694391fbcSLiu Hui-R64343 		break;
9794391fbcSLiu Hui-R64343 	case 1:
9894391fbcSLiu Hui-R64343 		/* i2c2 SDA */
9994391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_KEY_ROW3,
10094391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT4 | IOMUX_CONFIG_SION);
10194391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C2_IPP_SDA_IN_SELECT_INPUT,
10294391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
10394391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_KEY_ROW3,
10494391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
10594391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
10694391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
10794391fbcSLiu Hui-R64343 
10894391fbcSLiu Hui-R64343 		/* i2c2 SCL */
10994391fbcSLiu Hui-R64343 		mxc_request_iomux(MX53_PIN_KEY_COL3,
11094391fbcSLiu Hui-R64343 				IOMUX_CONFIG_ALT4 | IOMUX_CONFIG_SION);
11194391fbcSLiu Hui-R64343 		mxc_iomux_set_input(MX53_I2C2_IPP_SCL_IN_SELECT_INPUT,
11294391fbcSLiu Hui-R64343 				INPUT_CTL_PATH0);
11394391fbcSLiu Hui-R64343 		mxc_iomux_set_pad(MX53_PIN_KEY_COL3,
11494391fbcSLiu Hui-R64343 				PAD_CTL_SRE_FAST | PAD_CTL_DRV_HIGH |
11594391fbcSLiu Hui-R64343 				PAD_CTL_100K_PU | PAD_CTL_HYS_ENABLE |
11694391fbcSLiu Hui-R64343 				PAD_CTL_ODE_OPENDRAIN_ENABLE);
11794391fbcSLiu Hui-R64343 		break;
11894391fbcSLiu Hui-R64343 	default:
11994391fbcSLiu Hui-R64343 		printf("Warning: Wrong I2C port number\n");
12094391fbcSLiu Hui-R64343 		break;
12194391fbcSLiu Hui-R64343 	}
12294391fbcSLiu Hui-R64343 }
12394391fbcSLiu Hui-R64343 
12494391fbcSLiu Hui-R64343 void power_init(void)
12594391fbcSLiu Hui-R64343 {
12694391fbcSLiu Hui-R64343 	unsigned int val;
12794391fbcSLiu Hui-R64343 
12894391fbcSLiu Hui-R64343 	/* Set VDDA to 1.25V */
12994391fbcSLiu Hui-R64343 	val = pmic_reg_read(REG_SW_2);
13094391fbcSLiu Hui-R64343 	val &= ~SWX_OUT_MASK;
13194391fbcSLiu Hui-R64343 	val |= SWX_OUT_1_25;
13294391fbcSLiu Hui-R64343 	pmic_reg_write(REG_SW_2, val);
13394391fbcSLiu Hui-R64343 
13494391fbcSLiu Hui-R64343 	/*
13594391fbcSLiu Hui-R64343 	 * Need increase VCC and VDDA to 1.3V
13694391fbcSLiu Hui-R64343 	 * according to MX53 IC TO2 datasheet.
13794391fbcSLiu Hui-R64343 	 */
13894391fbcSLiu Hui-R64343 	if (is_soc_rev(CHIP_REV_2_0) == 0) {
13994391fbcSLiu Hui-R64343 		/* Set VCC to 1.3V for TO2 */
14094391fbcSLiu Hui-R64343 		val = pmic_reg_read(REG_SW_1);
14194391fbcSLiu Hui-R64343 		val &= ~SWX_OUT_MASK;
14294391fbcSLiu Hui-R64343 		val |= SWX_OUT_1_30;
14394391fbcSLiu Hui-R64343 		pmic_reg_write(REG_SW_1, val);
14494391fbcSLiu Hui-R64343 
14594391fbcSLiu Hui-R64343 		/* Set VDDA to 1.3V for TO2 */
14694391fbcSLiu Hui-R64343 		val = pmic_reg_read(REG_SW_2);
14794391fbcSLiu Hui-R64343 		val &= ~SWX_OUT_MASK;
14894391fbcSLiu Hui-R64343 		val |= SWX_OUT_1_30;
14994391fbcSLiu Hui-R64343 		pmic_reg_write(REG_SW_2, val);
15094391fbcSLiu Hui-R64343 	}
15194391fbcSLiu Hui-R64343 }
15294391fbcSLiu Hui-R64343 
15394391fbcSLiu Hui-R64343 static void setup_iomux_fec(void)
15494391fbcSLiu Hui-R64343 {
15594391fbcSLiu Hui-R64343 	/*FEC_MDIO*/
15694391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_MDIO, IOMUX_CONFIG_ALT0);
15794391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_MDIO,
15894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
15994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
16094391fbcSLiu Hui-R64343 				PAD_CTL_22K_PU | PAD_CTL_ODE_OPENDRAIN_ENABLE);
16194391fbcSLiu Hui-R64343 	mxc_iomux_set_input(MX53_FEC_FEC_MDI_SELECT_INPUT, 0x1);
16294391fbcSLiu Hui-R64343 
16394391fbcSLiu Hui-R64343 	/*FEC_MDC*/
16494391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_MDC, IOMUX_CONFIG_ALT0);
16594391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_MDC, PAD_CTL_DRV_HIGH);
16694391fbcSLiu Hui-R64343 
16794391fbcSLiu Hui-R64343 	/* FEC RXD1 */
16894391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RXD1, IOMUX_CONFIG_ALT0);
16994391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RXD1,
17094391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
17194391fbcSLiu Hui-R64343 
17294391fbcSLiu Hui-R64343 	/* FEC RXD0 */
17394391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RXD0, IOMUX_CONFIG_ALT0);
17494391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RXD0,
17594391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
17694391fbcSLiu Hui-R64343 
17794391fbcSLiu Hui-R64343 	 /* FEC TXD1 */
17894391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TXD1, IOMUX_CONFIG_ALT0);
17994391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TXD1, PAD_CTL_DRV_HIGH);
18094391fbcSLiu Hui-R64343 
18194391fbcSLiu Hui-R64343 	/* FEC TXD0 */
18294391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TXD0, IOMUX_CONFIG_ALT0);
18394391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TXD0, PAD_CTL_DRV_HIGH);
18494391fbcSLiu Hui-R64343 
18594391fbcSLiu Hui-R64343 	/* FEC TX_EN */
18694391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_TX_EN, IOMUX_CONFIG_ALT0);
18794391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_TX_EN, PAD_CTL_DRV_HIGH);
18894391fbcSLiu Hui-R64343 
18994391fbcSLiu Hui-R64343 	/* FEC TX_CLK */
19094391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_REF_CLK, IOMUX_CONFIG_ALT0);
19194391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_REF_CLK,
19294391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
19394391fbcSLiu Hui-R64343 
19494391fbcSLiu Hui-R64343 	/* FEC RX_ER */
19594391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_RX_ER, IOMUX_CONFIG_ALT0);
19694391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_RX_ER,
19794391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
19894391fbcSLiu Hui-R64343 
19994391fbcSLiu Hui-R64343 	/* FEC CRS */
20094391fbcSLiu Hui-R64343 	mxc_request_iomux(MX53_PIN_FEC_CRS_DV, IOMUX_CONFIG_ALT0);
20194391fbcSLiu Hui-R64343 	mxc_iomux_set_pad(MX53_PIN_FEC_CRS_DV,
20294391fbcSLiu Hui-R64343 			PAD_CTL_HYS_ENABLE | PAD_CTL_PKE_ENABLE);
20394391fbcSLiu Hui-R64343 }
20494391fbcSLiu Hui-R64343 
20594391fbcSLiu Hui-R64343 #ifdef CONFIG_FSL_ESDHC
20694391fbcSLiu Hui-R64343 struct fsl_esdhc_cfg esdhc_cfg[2] = {
20794391fbcSLiu Hui-R64343 	{MMC_SDHC1_BASE_ADDR, 1},
20894391fbcSLiu Hui-R64343 	{MMC_SDHC3_BASE_ADDR, 1},
20994391fbcSLiu Hui-R64343 };
21094391fbcSLiu Hui-R64343 
21194391fbcSLiu Hui-R64343 int board_mmc_getcd(u8 *cd, struct mmc *mmc)
21294391fbcSLiu Hui-R64343 {
21394391fbcSLiu Hui-R64343 	struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv;
21494391fbcSLiu Hui-R64343 
21594391fbcSLiu Hui-R64343 	if (cfg->esdhc_base == MMC_SDHC1_BASE_ADDR)
216*f7a36474SStefano Babic 		*cd = gpio_get_value(77); /*GPIO3_13*/
21794391fbcSLiu Hui-R64343 	else
218*f7a36474SStefano Babic 		*cd = gpio_get_value(75); /*GPIO3_11*/
21994391fbcSLiu Hui-R64343 
22094391fbcSLiu Hui-R64343 	return 0;
22194391fbcSLiu Hui-R64343 }
22294391fbcSLiu Hui-R64343 
22394391fbcSLiu Hui-R64343 int board_mmc_init(bd_t *bis)
22494391fbcSLiu Hui-R64343 {
22594391fbcSLiu Hui-R64343 	u32 index;
22694391fbcSLiu Hui-R64343 	s32 status = 0;
22794391fbcSLiu Hui-R64343 
22894391fbcSLiu Hui-R64343 	for (index = 0; index < CONFIG_SYS_FSL_ESDHC_NUM; index++) {
22994391fbcSLiu Hui-R64343 		switch (index) {
23094391fbcSLiu Hui-R64343 		case 0:
23194391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_CMD, IOMUX_CONFIG_ALT0);
23294391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_CLK, IOMUX_CONFIG_ALT0);
23394391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA0,
23494391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
23594391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA1,
23694391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
23794391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA2,
23894391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
23994391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_SD1_DATA3,
24094391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT0);
24194391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_EIM_DA13,
24294391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT1);
24394391fbcSLiu Hui-R64343 
24494391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_CMD,
24594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
24694391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
24794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
24894391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_CLK,
24994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
25094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
25194391fbcSLiu Hui-R64343 				PAD_CTL_DRV_HIGH);
25294391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA0,
25394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
25494391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
25594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
25694391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA1,
25794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
25894391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
25994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
26094391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA2,
26194391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
26294391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
26394391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
26494391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_SD1_DATA3,
26594391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
26694391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
26794391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
26894391fbcSLiu Hui-R64343 			break;
26994391fbcSLiu Hui-R64343 		case 1:
27094391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_RESET_B,
27194391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT2);
27294391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_IORDY,
27394391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT2);
27494391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA8,
27594391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
27694391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA9,
27794391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
27894391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA10,
27994391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28094391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA11,
28194391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28294391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA0,
28394391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28494391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA1,
28594391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28694391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA2,
28794391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
28894391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_ATA_DATA3,
28994391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT4);
29094391fbcSLiu Hui-R64343 			mxc_request_iomux(MX53_PIN_EIM_DA11,
29194391fbcSLiu Hui-R64343 						IOMUX_CONFIG_ALT1);
29294391fbcSLiu Hui-R64343 
29394391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_RESET_B,
29494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
29594391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
29694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_100K_PU);
29794391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_IORDY,
29894391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
29994391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU |
30094391fbcSLiu Hui-R64343 				PAD_CTL_DRV_HIGH);
30194391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA8,
30294391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
30394391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
30494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
30594391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA9,
30694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
30794391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
30894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
30994391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA10,
31094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
31194391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
31294391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
31394391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA11,
31494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
31594391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
31694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
31794391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA0,
31894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
31994391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
32094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32194391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA1,
32294391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
32394391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
32494391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32594391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA2,
32694391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
32794391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
32894391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
32994391fbcSLiu Hui-R64343 			mxc_iomux_set_pad(MX53_PIN_ATA_DATA3,
33094391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_DRV_HIGH |
33194391fbcSLiu Hui-R64343 				PAD_CTL_PUE_PULL | PAD_CTL_PKE_ENABLE |
33294391fbcSLiu Hui-R64343 				PAD_CTL_HYS_ENABLE | PAD_CTL_47K_PU);
33394391fbcSLiu Hui-R64343 
33494391fbcSLiu Hui-R64343 			break;
33594391fbcSLiu Hui-R64343 		default:
33694391fbcSLiu Hui-R64343 			printf("Warning: you configured more ESDHC controller"
33794391fbcSLiu Hui-R64343 				"(%d) as supported by the board(2)\n",
33894391fbcSLiu Hui-R64343 				CONFIG_SYS_FSL_ESDHC_NUM);
33994391fbcSLiu Hui-R64343 			return status;
34094391fbcSLiu Hui-R64343 		}
34194391fbcSLiu Hui-R64343 		status |= fsl_esdhc_initialize(bis, &esdhc_cfg[index]);
34294391fbcSLiu Hui-R64343 	}
34394391fbcSLiu Hui-R64343 
34494391fbcSLiu Hui-R64343 	return status;
34594391fbcSLiu Hui-R64343 }
34694391fbcSLiu Hui-R64343 #endif
34794391fbcSLiu Hui-R64343 
34894391fbcSLiu Hui-R64343 int board_early_init_f(void)
34994391fbcSLiu Hui-R64343 {
35094391fbcSLiu Hui-R64343 	setup_iomux_uart();
35194391fbcSLiu Hui-R64343 	setup_iomux_fec();
35294391fbcSLiu Hui-R64343 
35394391fbcSLiu Hui-R64343 	return 0;
35494391fbcSLiu Hui-R64343 }
35594391fbcSLiu Hui-R64343 
35694391fbcSLiu Hui-R64343 int board_init(void)
35794391fbcSLiu Hui-R64343 {
35894391fbcSLiu Hui-R64343 	gd->bd->bi_arch_number = MACH_TYPE_MX53_EVK;
35994391fbcSLiu Hui-R64343 	/* address of boot parameters */
36094391fbcSLiu Hui-R64343 	gd->bd->bi_boot_params = PHYS_SDRAM_1 + 0x100;
36194391fbcSLiu Hui-R64343 
36294391fbcSLiu Hui-R64343 	return 0;
36394391fbcSLiu Hui-R64343 }
36494391fbcSLiu Hui-R64343 
36594391fbcSLiu Hui-R64343 int board_late_init(void)
36694391fbcSLiu Hui-R64343 {
36794391fbcSLiu Hui-R64343 	setup_i2c(1);
36894391fbcSLiu Hui-R64343 	power_init();
36994391fbcSLiu Hui-R64343 
37094391fbcSLiu Hui-R64343 	return 0;
37194391fbcSLiu Hui-R64343 }
37294391fbcSLiu Hui-R64343 
37394391fbcSLiu Hui-R64343 int checkboard(void)
37494391fbcSLiu Hui-R64343 {
37551958904SJason Liu 	puts("Board: MX53EVK\n");
37694391fbcSLiu Hui-R64343 
37794391fbcSLiu Hui-R64343 	return 0;
37894391fbcSLiu Hui-R64343 }
379