xref: /rk3399_rockchip-uboot/board/barco/titanium/titanium.c (revision 39632b4a01210e329333d787d828157dcd2c7328)
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>
16*552a848eSStefano Babic #include <asm/mach-imx/iomux-v3.h>
17*552a848eSStefano Babic #include <asm/mach-imx/mxc_i2c.h>
18*552a848eSStefano Babic #include <asm/mach-imx/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 
dram_init(void)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 
setup_gpmi_nand(void)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 
setup_iomux_enet(void)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 
setup_iomux_uart(void)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
board_ehci_hcd_init(int port)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 
board_mmc_getcd(struct mmc * mmc)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 
board_mmc_init(bd_t * bis)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 
board_phy_config(struct phy_device * phydev)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 
board_eth_init(bd_t * bis)265c2cde27dSStefan Roese int board_eth_init(bd_t *bis)
266c2cde27dSStefan Roese {
267c2cde27dSStefan Roese 	setup_iomux_enet();
268c2cde27dSStefan Roese 
2698aa42441SFabio Estevam 	return cpu_eth_init(bis);
270c2cde27dSStefan Roese }
271c2cde27dSStefan Roese 
board_early_init_f(void)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 
board_init(void)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 
checkboard(void)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 
misc_init_r(void)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