1c2cde27dSStefan Roese /* 2c2cde27dSStefan Roese * Copyright (C) 2013 Stefan Roese <sr@denx.de> 3c2cde27dSStefan Roese * 4c2cde27dSStefan Roese * SPDX-License-Identifier: GPL-2.0+ 5c2cde27dSStefan Roese */ 6c2cde27dSStefan Roese 7c2cde27dSStefan Roese #include <common.h> 8c2cde27dSStefan Roese #include <asm/io.h> 9c2cde27dSStefan Roese #include <asm/arch/clock.h> 10c2cde27dSStefan Roese #include <asm/arch/imx-regs.h> 11c2cde27dSStefan Roese #include <asm/arch/iomux.h> 12b47abc36SEric Nelson #include <asm/arch/mx6-pins.h> 13c2cde27dSStefan Roese #include <asm/arch/crm_regs.h> 14c2cde27dSStefan Roese #include <asm/arch/sys_proto.h> 15c2cde27dSStefan Roese #include <asm/gpio.h> 16c2cde27dSStefan Roese #include <asm/imx-common/iomux-v3.h> 17c2cde27dSStefan Roese #include <asm/imx-common/mxc_i2c.h> 18c2cde27dSStefan Roese #include <asm/imx-common/boot_mode.h> 19c2cde27dSStefan Roese #include <mmc.h> 20c2cde27dSStefan Roese #include <fsl_esdhc.h> 21c2cde27dSStefan Roese #include <micrel.h> 22c2cde27dSStefan Roese #include <miiphy.h> 23c2cde27dSStefan Roese #include <netdev.h> 24c2cde27dSStefan Roese 25c2cde27dSStefan Roese DECLARE_GLOBAL_DATA_PTR; 26c2cde27dSStefan Roese 27c2cde27dSStefan Roese #define UART_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \ 28c2cde27dSStefan Roese PAD_CTL_DSE_40ohm | PAD_CTL_SRE_FAST | PAD_CTL_HYS) 29c2cde27dSStefan Roese 30c2cde27dSStefan Roese #define USDHC_PAD_CTRL (PAD_CTL_PUS_47K_UP | PAD_CTL_SPEED_LOW | \ 31c2cde27dSStefan Roese PAD_CTL_DSE_80ohm | PAD_CTL_SRE_FAST | PAD_CTL_HYS) 32c2cde27dSStefan Roese 33c2cde27dSStefan Roese #define ENET_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \ 34c2cde27dSStefan Roese PAD_CTL_DSE_40ohm | PAD_CTL_HYS) 35c2cde27dSStefan Roese 36c2cde27dSStefan Roese #define I2C_PAD_CTRL (PAD_CTL_PUS_100K_UP | PAD_CTL_SPEED_MED | \ 37c2cde27dSStefan Roese PAD_CTL_DSE_40ohm | PAD_CTL_HYS | \ 38c2cde27dSStefan Roese PAD_CTL_ODE | PAD_CTL_SRE_FAST) 39c2cde27dSStefan Roese 40c2cde27dSStefan Roese int dram_init(void) 41c2cde27dSStefan Roese { 42c2cde27dSStefan Roese gd->ram_size = get_ram_size((void *)PHYS_SDRAM, PHYS_SDRAM_SIZE); 43c2cde27dSStefan Roese 44c2cde27dSStefan Roese return 0; 45c2cde27dSStefan Roese } 46c2cde27dSStefan Roese 47c2cde27dSStefan Roese iomux_v3_cfg_t const uart1_pads[] = { 4810fda487SEric Nelson MX6_PAD_SD3_DAT6__UART1_RX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 4910fda487SEric Nelson MX6_PAD_SD3_DAT7__UART1_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 50c2cde27dSStefan Roese }; 51c2cde27dSStefan Roese 52c2cde27dSStefan Roese iomux_v3_cfg_t const uart2_pads[] = { 5310fda487SEric Nelson MX6_PAD_EIM_D26__UART2_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 5410fda487SEric Nelson MX6_PAD_EIM_D27__UART2_RX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 55c2cde27dSStefan Roese }; 56c2cde27dSStefan Roese 57c2cde27dSStefan Roese iomux_v3_cfg_t const uart4_pads[] = { 5810fda487SEric Nelson MX6_PAD_CSI0_DAT12__UART4_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 5910fda487SEric Nelson MX6_PAD_CSI0_DAT13__UART4_RX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL), 60c2cde27dSStefan Roese }; 61c2cde27dSStefan Roese 62c2cde27dSStefan Roese #define PC MUX_PAD_CTRL(I2C_PAD_CTRL) 63c2cde27dSStefan Roese 64c2cde27dSStefan Roese struct i2c_pads_info i2c_pad_info0 = { 65c2cde27dSStefan Roese .scl = { 66c2cde27dSStefan Roese .i2c_mode = MX6_PAD_CSI0_DAT9__I2C1_SCL | PC, 6710fda487SEric Nelson .gpio_mode = MX6_PAD_CSI0_DAT9__GPIO5_IO27 | PC, 68c2cde27dSStefan Roese .gp = IMX_GPIO_NR(5, 27) 69c2cde27dSStefan Roese }, 70c2cde27dSStefan Roese .sda = { 71c2cde27dSStefan Roese .i2c_mode = MX6_PAD_CSI0_DAT8__I2C1_SDA | PC, 7210fda487SEric Nelson .gpio_mode = MX6_PAD_CSI0_DAT8__GPIO5_IO26 | PC, 73c2cde27dSStefan Roese .gp = IMX_GPIO_NR(5, 26) 74c2cde27dSStefan Roese } 75c2cde27dSStefan Roese }; 76c2cde27dSStefan Roese 77c2cde27dSStefan Roese struct i2c_pads_info i2c_pad_info2 = { 78c2cde27dSStefan Roese .scl = { 79c2cde27dSStefan Roese .i2c_mode = MX6_PAD_GPIO_3__I2C3_SCL | PC, 8010fda487SEric Nelson .gpio_mode = MX6_PAD_GPIO_3__GPIO1_IO03 | PC, 81c2cde27dSStefan Roese .gp = IMX_GPIO_NR(1, 3) 82c2cde27dSStefan Roese }, 83c2cde27dSStefan Roese .sda = { 84c2cde27dSStefan Roese .i2c_mode = MX6_PAD_GPIO_16__I2C3_SDA | PC, 8510fda487SEric Nelson .gpio_mode = MX6_PAD_GPIO_16__GPIO7_IO11 | PC, 86c2cde27dSStefan Roese .gp = IMX_GPIO_NR(7, 11) 87c2cde27dSStefan Roese } 88c2cde27dSStefan Roese }; 89c2cde27dSStefan Roese 90c2cde27dSStefan Roese iomux_v3_cfg_t const usdhc3_pads[] = { 9110fda487SEric Nelson MX6_PAD_SD3_CLK__SD3_CLK | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9210fda487SEric Nelson MX6_PAD_SD3_CMD__SD3_CMD | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9310fda487SEric Nelson MX6_PAD_SD3_DAT0__SD3_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9410fda487SEric Nelson MX6_PAD_SD3_DAT1__SD3_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9510fda487SEric Nelson MX6_PAD_SD3_DAT2__SD3_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9610fda487SEric Nelson MX6_PAD_SD3_DAT3__SD3_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL), 9710fda487SEric Nelson MX6_PAD_SD3_DAT5__GPIO7_IO00 | MUX_PAD_CTRL(NO_PAD_CTRL), /* CD */ 98c2cde27dSStefan Roese }; 99c2cde27dSStefan Roese 100c2cde27dSStefan Roese iomux_v3_cfg_t const enet_pads1[] = { 101c2cde27dSStefan Roese MX6_PAD_ENET_MDIO__ENET_MDIO | MUX_PAD_CTRL(ENET_PAD_CTRL), 102c2cde27dSStefan Roese MX6_PAD_ENET_MDC__ENET_MDC | MUX_PAD_CTRL(ENET_PAD_CTRL), 10310fda487SEric Nelson MX6_PAD_RGMII_TXC__RGMII_TXC | MUX_PAD_CTRL(ENET_PAD_CTRL), 10410fda487SEric Nelson MX6_PAD_RGMII_TD0__RGMII_TD0 | MUX_PAD_CTRL(ENET_PAD_CTRL), 10510fda487SEric Nelson MX6_PAD_RGMII_TD1__RGMII_TD1 | MUX_PAD_CTRL(ENET_PAD_CTRL), 10610fda487SEric Nelson MX6_PAD_RGMII_TD2__RGMII_TD2 | MUX_PAD_CTRL(ENET_PAD_CTRL), 10710fda487SEric Nelson MX6_PAD_RGMII_TD3__RGMII_TD3 | MUX_PAD_CTRL(ENET_PAD_CTRL), 108c2cde27dSStefan Roese MX6_PAD_RGMII_TX_CTL__RGMII_TX_CTL | MUX_PAD_CTRL(ENET_PAD_CTRL), 109c2cde27dSStefan Roese MX6_PAD_ENET_REF_CLK__ENET_TX_CLK | MUX_PAD_CTRL(ENET_PAD_CTRL), 110c2cde27dSStefan Roese /* pin 35 - 1 (PHY_AD2) on reset */ 11110fda487SEric Nelson MX6_PAD_RGMII_RXC__GPIO6_IO30 | MUX_PAD_CTRL(NO_PAD_CTRL), 112c2cde27dSStefan Roese /* pin 32 - 1 - (MODE0) all */ 11310fda487SEric Nelson MX6_PAD_RGMII_RD0__GPIO6_IO25 | MUX_PAD_CTRL(NO_PAD_CTRL), 114c2cde27dSStefan Roese /* pin 31 - 1 - (MODE1) all */ 11510fda487SEric Nelson MX6_PAD_RGMII_RD1__GPIO6_IO27 | MUX_PAD_CTRL(NO_PAD_CTRL), 116c2cde27dSStefan Roese /* pin 28 - 1 - (MODE2) all */ 11710fda487SEric Nelson MX6_PAD_RGMII_RD2__GPIO6_IO28 | MUX_PAD_CTRL(NO_PAD_CTRL), 118c2cde27dSStefan Roese /* pin 27 - 1 - (MODE3) all */ 11910fda487SEric Nelson MX6_PAD_RGMII_RD3__GPIO6_IO29 | MUX_PAD_CTRL(NO_PAD_CTRL), 120c2cde27dSStefan Roese /* pin 33 - 1 - (CLK125_EN) 125Mhz clockout enabled */ 12110fda487SEric Nelson MX6_PAD_RGMII_RX_CTL__GPIO6_IO24 | MUX_PAD_CTRL(NO_PAD_CTRL), 122c2cde27dSStefan Roese /* pin 42 PHY nRST */ 12310fda487SEric Nelson MX6_PAD_EIM_D23__GPIO3_IO23 | MUX_PAD_CTRL(NO_PAD_CTRL), 124c2cde27dSStefan Roese }; 125c2cde27dSStefan Roese 126c2cde27dSStefan Roese iomux_v3_cfg_t const enet_pads2[] = { 12710fda487SEric Nelson MX6_PAD_RGMII_RXC__RGMII_RXC | MUX_PAD_CTRL(ENET_PAD_CTRL), 12810fda487SEric Nelson MX6_PAD_RGMII_RD0__RGMII_RD0 | MUX_PAD_CTRL(ENET_PAD_CTRL), 12910fda487SEric Nelson MX6_PAD_RGMII_RD1__RGMII_RD1 | MUX_PAD_CTRL(ENET_PAD_CTRL), 13010fda487SEric Nelson MX6_PAD_RGMII_RD2__RGMII_RD2 | MUX_PAD_CTRL(ENET_PAD_CTRL), 13110fda487SEric Nelson MX6_PAD_RGMII_RD3__RGMII_RD3 | MUX_PAD_CTRL(ENET_PAD_CTRL), 132c2cde27dSStefan Roese MX6_PAD_RGMII_RX_CTL__RGMII_RX_CTL | MUX_PAD_CTRL(ENET_PAD_CTRL), 133c2cde27dSStefan Roese }; 134c2cde27dSStefan Roese 135c2cde27dSStefan Roese iomux_v3_cfg_t nfc_pads[] = { 13610fda487SEric Nelson MX6_PAD_NANDF_CLE__NAND_CLE | MUX_PAD_CTRL(NO_PAD_CTRL), 13710fda487SEric Nelson MX6_PAD_NANDF_ALE__NAND_ALE | MUX_PAD_CTRL(NO_PAD_CTRL), 13810fda487SEric Nelson MX6_PAD_NANDF_WP_B__NAND_WP_B | MUX_PAD_CTRL(NO_PAD_CTRL), 13910fda487SEric Nelson MX6_PAD_NANDF_RB0__NAND_READY_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14010fda487SEric Nelson MX6_PAD_NANDF_CS0__NAND_CE0_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14110fda487SEric Nelson MX6_PAD_NANDF_CS1__NAND_CE1_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14210fda487SEric Nelson MX6_PAD_NANDF_CS2__NAND_CE2_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14310fda487SEric Nelson MX6_PAD_NANDF_CS3__NAND_CE3_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14410fda487SEric Nelson MX6_PAD_SD4_CMD__NAND_RE_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14510fda487SEric Nelson MX6_PAD_SD4_CLK__NAND_WE_B | MUX_PAD_CTRL(NO_PAD_CTRL), 14610fda487SEric Nelson MX6_PAD_NANDF_D0__NAND_DATA00 | MUX_PAD_CTRL(NO_PAD_CTRL), 14710fda487SEric Nelson MX6_PAD_NANDF_D1__NAND_DATA01 | MUX_PAD_CTRL(NO_PAD_CTRL), 14810fda487SEric Nelson MX6_PAD_NANDF_D2__NAND_DATA02 | MUX_PAD_CTRL(NO_PAD_CTRL), 14910fda487SEric Nelson MX6_PAD_NANDF_D3__NAND_DATA03 | MUX_PAD_CTRL(NO_PAD_CTRL), 15010fda487SEric Nelson MX6_PAD_NANDF_D4__NAND_DATA04 | MUX_PAD_CTRL(NO_PAD_CTRL), 15110fda487SEric Nelson MX6_PAD_NANDF_D5__NAND_DATA05 | MUX_PAD_CTRL(NO_PAD_CTRL), 15210fda487SEric Nelson MX6_PAD_NANDF_D6__NAND_DATA06 | MUX_PAD_CTRL(NO_PAD_CTRL), 15310fda487SEric Nelson MX6_PAD_NANDF_D7__NAND_DATA07 | MUX_PAD_CTRL(NO_PAD_CTRL), 15410fda487SEric Nelson MX6_PAD_SD4_DAT0__NAND_DQS | MUX_PAD_CTRL(NO_PAD_CTRL), 155c2cde27dSStefan Roese }; 156c2cde27dSStefan Roese 157c2cde27dSStefan Roese static void setup_gpmi_nand(void) 158c2cde27dSStefan Roese { 159c2cde27dSStefan Roese struct mxc_ccm_reg *mxc_ccm = (struct mxc_ccm_reg *)CCM_BASE_ADDR; 160c2cde27dSStefan Roese 161c2cde27dSStefan Roese /* config gpmi nand iomux */ 162c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(nfc_pads, 163c2cde27dSStefan Roese ARRAY_SIZE(nfc_pads)); 164c2cde27dSStefan Roese 165c2cde27dSStefan Roese /* config gpmi and bch clock to 100 MHz */ 166c2cde27dSStefan Roese clrsetbits_le32(&mxc_ccm->cs2cdr, 167c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_PODF_MASK | 168c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_PRED_MASK | 169c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_SEL_MASK, 170c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_PODF(0) | 171c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_PRED(3) | 172c2cde27dSStefan Roese MXC_CCM_CS2CDR_ENFC_CLK_SEL(3)); 173c2cde27dSStefan Roese 174c2cde27dSStefan Roese /* enable gpmi and bch clock gating */ 175c2cde27dSStefan Roese setbits_le32(&mxc_ccm->CCGR4, 176c2cde27dSStefan Roese MXC_CCM_CCGR4_RAWNAND_U_BCH_INPUT_APB_MASK | 177c2cde27dSStefan Roese MXC_CCM_CCGR4_RAWNAND_U_GPMI_BCH_INPUT_BCH_MASK | 178c2cde27dSStefan Roese MXC_CCM_CCGR4_RAWNAND_U_GPMI_BCH_INPUT_GPMI_IO_MASK | 179c2cde27dSStefan Roese MXC_CCM_CCGR4_RAWNAND_U_GPMI_INPUT_APB_MASK | 180c2cde27dSStefan Roese MXC_CCM_CCGR4_PL301_MX6QPER1_BCH_OFFSET); 181c2cde27dSStefan Roese 182c2cde27dSStefan Roese /* enable apbh clock gating */ 183c2cde27dSStefan Roese setbits_le32(&mxc_ccm->CCGR0, MXC_CCM_CCGR0_APBHDMA_MASK); 184c2cde27dSStefan Roese } 185c2cde27dSStefan Roese 186c2cde27dSStefan Roese static void setup_iomux_enet(void) 187c2cde27dSStefan Roese { 188c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(3, 23), 0); 189c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 30), 1); 190c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 25), 1); 191c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 27), 1); 192c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 28), 1); 193c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 29), 1); 194c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(enet_pads1, ARRAY_SIZE(enet_pads1)); 195c2cde27dSStefan Roese gpio_direction_output(IMX_GPIO_NR(6, 24), 1); 196c2cde27dSStefan Roese 197c2cde27dSStefan Roese /* Need delay 10ms according to KSZ9021 spec */ 198c2cde27dSStefan Roese udelay(1000 * 10); 199c2cde27dSStefan Roese gpio_set_value(IMX_GPIO_NR(3, 23), 1); 200c2cde27dSStefan Roese 201c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(enet_pads2, ARRAY_SIZE(enet_pads2)); 202c2cde27dSStefan Roese } 203c2cde27dSStefan Roese 204c2cde27dSStefan Roese static void setup_iomux_uart(void) 205c2cde27dSStefan Roese { 206c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(uart1_pads, ARRAY_SIZE(uart1_pads)); 207c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(uart2_pads, ARRAY_SIZE(uart2_pads)); 208c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(uart4_pads, ARRAY_SIZE(uart4_pads)); 209c2cde27dSStefan Roese } 210c2cde27dSStefan Roese 211c2cde27dSStefan Roese #ifdef CONFIG_USB_EHCI_MX6 212c2cde27dSStefan Roese int board_ehci_hcd_init(int port) 213c2cde27dSStefan Roese { 214c2cde27dSStefan Roese return 0; 215c2cde27dSStefan Roese } 216c2cde27dSStefan Roese 217c2cde27dSStefan Roese #endif 218c2cde27dSStefan Roese 219c2cde27dSStefan Roese #ifdef CONFIG_FSL_ESDHC 220c2cde27dSStefan Roese struct fsl_esdhc_cfg usdhc_cfg[1] = { 221c2cde27dSStefan Roese { USDHC3_BASE_ADDR }, 222c2cde27dSStefan Roese }; 223c2cde27dSStefan Roese 224c2cde27dSStefan Roese int board_mmc_getcd(struct mmc *mmc) 225c2cde27dSStefan Roese { 226c2cde27dSStefan Roese struct fsl_esdhc_cfg *cfg = (struct fsl_esdhc_cfg *)mmc->priv; 227c2cde27dSStefan Roese 228c2cde27dSStefan Roese if (cfg->esdhc_base == USDHC3_BASE_ADDR) { 229c2cde27dSStefan Roese gpio_direction_input(IMX_GPIO_NR(7, 0)); 230c2cde27dSStefan Roese return !gpio_get_value(IMX_GPIO_NR(7, 0)); 231c2cde27dSStefan Roese } 232c2cde27dSStefan Roese 233c2cde27dSStefan Roese return 0; 234c2cde27dSStefan Roese } 235c2cde27dSStefan Roese 236c2cde27dSStefan Roese int board_mmc_init(bd_t *bis) 237c2cde27dSStefan Roese { 238c2cde27dSStefan Roese /* 239c2cde27dSStefan Roese * Only one USDHC controller on titianium 240c2cde27dSStefan Roese */ 241c2cde27dSStefan Roese imx_iomux_v3_setup_multiple_pads(usdhc3_pads, ARRAY_SIZE(usdhc3_pads)); 242c2cde27dSStefan Roese usdhc_cfg[0].sdhc_clk = mxc_get_clock(MXC_ESDHC3_CLK); 243c2cde27dSStefan Roese 244c2cde27dSStefan Roese return fsl_esdhc_initialize(bis, &usdhc_cfg[0]); 245c2cde27dSStefan Roese } 246c2cde27dSStefan Roese #endif 247c2cde27dSStefan Roese 248c2cde27dSStefan Roese int board_phy_config(struct phy_device *phydev) 249c2cde27dSStefan Roese { 250c2cde27dSStefan Roese /* min rx data delay */ 251c2cde27dSStefan Roese ksz9021_phy_extended_write(phydev, 252c2cde27dSStefan Roese MII_KSZ9021_EXT_RGMII_RX_DATA_SKEW, 0x0); 253c2cde27dSStefan Roese /* min tx data delay */ 254c2cde27dSStefan Roese ksz9021_phy_extended_write(phydev, 255c2cde27dSStefan Roese MII_KSZ9021_EXT_RGMII_TX_DATA_SKEW, 0x0); 256c2cde27dSStefan Roese /* max rx/tx clock delay, min rx/tx control */ 257c2cde27dSStefan Roese ksz9021_phy_extended_write(phydev, 258c2cde27dSStefan Roese MII_KSZ9021_EXT_RGMII_CLOCK_SKEW, 0xf0f0); 259c2cde27dSStefan Roese if (phydev->drv->config) 260c2cde27dSStefan Roese phydev->drv->config(phydev); 261c2cde27dSStefan Roese 262c2cde27dSStefan Roese return 0; 263c2cde27dSStefan Roese } 264c2cde27dSStefan Roese 265c2cde27dSStefan Roese int board_eth_init(bd_t *bis) 266c2cde27dSStefan Roese { 267c2cde27dSStefan Roese setup_iomux_enet(); 268c2cde27dSStefan Roese 269*8aa42441SFabio Estevam return cpu_eth_init(bis); 270c2cde27dSStefan Roese } 271c2cde27dSStefan Roese 272c2cde27dSStefan Roese int board_early_init_f(void) 273c2cde27dSStefan Roese { 274c2cde27dSStefan Roese setup_iomux_uart(); 275c2cde27dSStefan Roese 276c2cde27dSStefan Roese return 0; 277c2cde27dSStefan Roese } 278c2cde27dSStefan Roese 279c2cde27dSStefan Roese int board_init(void) 280c2cde27dSStefan Roese { 281c2cde27dSStefan Roese /* address of boot parameters */ 282c2cde27dSStefan Roese gd->bd->bi_boot_params = PHYS_SDRAM + 0x100; 283c2cde27dSStefan Roese 284c2cde27dSStefan Roese setup_i2c(0, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info0); 285c2cde27dSStefan Roese setup_i2c(2, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info2); 286c2cde27dSStefan Roese 287c2cde27dSStefan Roese setup_gpmi_nand(); 288c2cde27dSStefan Roese 289c2cde27dSStefan Roese return 0; 290c2cde27dSStefan Roese } 291c2cde27dSStefan Roese 292c2cde27dSStefan Roese int checkboard(void) 293c2cde27dSStefan Roese { 294c2cde27dSStefan Roese puts("Board: Titanium\n"); 295c2cde27dSStefan Roese 296c2cde27dSStefan Roese return 0; 297c2cde27dSStefan Roese } 298c2cde27dSStefan Roese 299c2cde27dSStefan Roese #ifdef CONFIG_CMD_BMODE 300c2cde27dSStefan Roese static const struct boot_mode board_boot_modes[] = { 301c2cde27dSStefan Roese /* NAND */ 302c2cde27dSStefan Roese { "nand", MAKE_CFGVAL(0x80, 0x02, 0x00, 0x00) }, 303c2cde27dSStefan Roese /* 4 bit bus width */ 304c2cde27dSStefan Roese { "mmc0", MAKE_CFGVAL(0x40, 0x30, 0x00, 0x00) }, 305c2cde27dSStefan Roese { "mmc1", MAKE_CFGVAL(0x40, 0x38, 0x00, 0x00) }, 306c2cde27dSStefan Roese { NULL, 0 }, 307c2cde27dSStefan Roese }; 308c2cde27dSStefan Roese #endif 309c2cde27dSStefan Roese 310c2cde27dSStefan Roese int misc_init_r(void) 311c2cde27dSStefan Roese { 312c2cde27dSStefan Roese #ifdef CONFIG_CMD_BMODE 313c2cde27dSStefan Roese add_board_boot_modes(board_boot_modes); 314c2cde27dSStefan Roese #endif 315c2cde27dSStefan Roese 316c2cde27dSStefan Roese return 0; 317c2cde27dSStefan Roese } 318