diff options
Diffstat (limited to 'board/wandboard/wandboard.c')
| -rw-r--r-- | board/wandboard/wandboard.c | 109 | 
1 files changed, 95 insertions, 14 deletions
| diff --git a/board/wandboard/wandboard.c b/board/wandboard/wandboard.c index ac7b89aae..bb983528b 100644 --- a/board/wandboard/wandboard.c +++ b/board/wandboard/wandboard.c @@ -16,6 +16,7 @@  #include <asm/arch/sys_proto.h>  #include <asm/gpio.h>  #include <asm/imx-common/iomux-v3.h> +#include <asm/imx-common/boot_mode.h>  #include <asm/io.h>  #include <asm/sizes.h>  #include <common.h> @@ -26,18 +27,19 @@  DECLARE_GLOBAL_DATA_PTR; -#define UART_PAD_CTRL  (PAD_CTL_PKE | PAD_CTL_PUE |		\ -	PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED |		\ -	PAD_CTL_DSE_40ohm   | PAD_CTL_SRE_FAST  | PAD_CTL_HYS) +#define UART_PAD_CTRL  (PAD_CTL_PUS_100K_UP |			\ +	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm |			\ +	PAD_CTL_SRE_FAST  | PAD_CTL_HYS) -#define USDHC_PAD_CTRL (PAD_CTL_PKE | PAD_CTL_PUE |		\ -	PAD_CTL_PUS_47K_UP  | PAD_CTL_SPEED_LOW |		\ -	PAD_CTL_DSE_80ohm   | PAD_CTL_SRE_FAST  | PAD_CTL_HYS) +#define USDHC_PAD_CTRL (PAD_CTL_PUS_47K_UP |			\ +	PAD_CTL_SPEED_LOW | PAD_CTL_DSE_80ohm |			\ +	PAD_CTL_SRE_FAST  | PAD_CTL_HYS) -#define ENET_PAD_CTRL  (PAD_CTL_PKE | PAD_CTL_PUE |		\ -	PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED   |		\ -	PAD_CTL_DSE_40ohm   | PAD_CTL_HYS) +#define ENET_PAD_CTRL  (PAD_CTL_PUS_100K_UP |			\ +	PAD_CTL_SPEED_MED | PAD_CTL_DSE_40ohm | PAD_CTL_HYS) +#define USDHC1_CD_GPIO		IMX_GPIO_NR(1, 2) +#define USDHC3_CD_GPIO		IMX_GPIO_NR(3, 9)  #define ETH_PHY_RESET		IMX_GPIO_NR(3, 29)  int dram_init(void) @@ -52,6 +54,17 @@ static iomux_v3_cfg_t const uart1_pads[] = {  	MX6_PAD_CSI0_DAT11__UART1_RXD | MUX_PAD_CTRL(UART_PAD_CTRL),  }; +iomux_v3_cfg_t const usdhc1_pads[] = { +	MX6_PAD_SD1_CLK__USDHC1_CLK   | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	MX6_PAD_SD1_CMD__USDHC1_CMD   | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	MX6_PAD_SD1_DAT0__USDHC1_DAT0 | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	MX6_PAD_SD1_DAT1__USDHC1_DAT1 | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	MX6_PAD_SD1_DAT2__USDHC1_DAT2 | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	MX6_PAD_SD1_DAT3__USDHC1_DAT3 | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	/* Carrier MicroSD Card Detect */ +	MX6_PAD_GPIO_2__GPIO_1_2      | MUX_PAD_CTRL(NO_PAD_CTRL), +}; +  static iomux_v3_cfg_t const usdhc3_pads[] = {  	MX6_PAD_SD3_CLK__USDHC3_CLK   | MUX_PAD_CTRL(USDHC_PAD_CTRL),  	MX6_PAD_SD3_CMD__USDHC3_CMD   | MUX_PAD_CTRL(USDHC_PAD_CTRL), @@ -59,6 +72,8 @@ static iomux_v3_cfg_t const usdhc3_pads[] = {  	MX6_PAD_SD3_DAT1__USDHC3_DAT1 | MUX_PAD_CTRL(USDHC_PAD_CTRL),  	MX6_PAD_SD3_DAT2__USDHC3_DAT2 | MUX_PAD_CTRL(USDHC_PAD_CTRL),  	MX6_PAD_SD3_DAT3__USDHC3_DAT3 | MUX_PAD_CTRL(USDHC_PAD_CTRL), +	/* SOM MicroSD Card Detect */ +	MX6_PAD_EIM_DA9__GPIO_3_9     | MUX_PAD_CTRL(NO_PAD_CTRL),  };  static iomux_v3_cfg_t const enet_pads[] = { @@ -96,18 +111,66 @@ static void setup_iomux_enet(void)  	gpio_set_value(ETH_PHY_RESET, 1);  } -static struct fsl_esdhc_cfg usdhc_cfg[1] = { +static struct fsl_esdhc_cfg usdhc_cfg[2] = {  	{USDHC3_BASE_ADDR}, +	{USDHC1_BASE_ADDR},  }; +int board_mmc_getcd(struct mmc *mmc) +{ +	struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv; +	int ret = 0; + +	switch (cfg->esdhc_base) { +	case USDHC1_BASE_ADDR: +		ret = !gpio_get_value(USDHC1_CD_GPIO); +		break; +	case USDHC3_BASE_ADDR: +		ret = !gpio_get_value(USDHC3_CD_GPIO); +		break; +	} + +	return ret; +} +  int board_mmc_init(bd_t *bis)  { -	imx_iomux_v3_setup_multiple_pads(usdhc3_pads, ARRAY_SIZE(usdhc3_pads)); +	s32 status = 0; +	u32 index = 0; + +	/* +	 * Following map is done: +	 * (U-boot device node)    (Physical Port) +	 * mmc0                    SOM MicroSD +	 * mmc1                    Carrier board MicroSD +	 */ +	for (index = 0; index < CONFIG_SYS_FSL_USDHC_NUM; ++index) { +		switch (index) { +		case 0: +			imx_iomux_v3_setup_multiple_pads( +				usdhc3_pads, ARRAY_SIZE(usdhc3_pads)); +			usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK); +			usdhc_cfg[0].max_bus_width = 4; +			gpio_direction_input(USDHC3_CD_GPIO); +			break; +		case 1: +			imx_iomux_v3_setup_multiple_pads( +				usdhc1_pads, ARRAY_SIZE(usdhc1_pads)); +			usdhc_cfg[1].sdhc_clk = mxc_get_clock(MXC_ESDHC_CLK); +			usdhc_cfg[1].max_bus_width = 4; +			gpio_direction_input(USDHC1_CD_GPIO); +			break; +		default: +			printf("Warning: you configured more USDHC controllers" +			       "(%d) then supported by the board (%d)\n", +			       index + 1, CONFIG_SYS_FSL_USDHC_NUM); +			return status; +		} -	usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK); -	usdhc_cfg[0].max_bus_width = 4; +		status |= fsl_esdhc_initialize(bis, &usdhc_cfg[index]); +	} -	return fsl_esdhc_initialize(bis, &usdhc_cfg[0]); +	return status;  }  static int mx6_rgmii_rework(struct phy_device *phydev) @@ -162,6 +225,24 @@ int board_early_init_f(void)  	return 0;  } +#ifdef CONFIG_CMD_BMODE +static const struct boot_mode board_boot_modes[] = { +	/* 4 bit bus width */ +	{"mmc0",	  MAKE_CFGVAL(0x40, 0x30, 0x00, 0x00)}, +	{"mmc1",	  MAKE_CFGVAL(0x40, 0x20, 0x00, 0x00)}, +	{NULL,	 0}, +}; +#endif + +int board_late_init(void) +{ +#ifdef CONFIG_CMD_BMODE +	add_board_boot_modes(board_boot_modes); +#endif + +	return 0; +} +  int board_init(void)  {  	/* address of boot parameters */ |