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