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