xref: /rk3399_rockchip-uboot/board/barco/titanium/titanium.c (revision 10fda48779fc86e74e4482cbc7667431237cf60c)
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>
12c2cde27dSStefan Roese #include <asm/arch/mx6q_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[] = {
48*10fda487SEric Nelson 	MX6_PAD_SD3_DAT6__UART1_RX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL),
49*10fda487SEric 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[] = {
53*10fda487SEric Nelson 	MX6_PAD_EIM_D26__UART2_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL),
54*10fda487SEric 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[] = {
58*10fda487SEric Nelson 	MX6_PAD_CSI0_DAT12__UART4_TX_DATA | MUX_PAD_CTRL(UART_PAD_CTRL),
59*10fda487SEric 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,
67*10fda487SEric 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,
72*10fda487SEric 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,
80*10fda487SEric 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,
85*10fda487SEric 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[] = {
91*10fda487SEric Nelson 	MX6_PAD_SD3_CLK__SD3_CLK   | MUX_PAD_CTRL(USDHC_PAD_CTRL),
92*10fda487SEric Nelson 	MX6_PAD_SD3_CMD__SD3_CMD   | MUX_PAD_CTRL(USDHC_PAD_CTRL),
93*10fda487SEric Nelson 	MX6_PAD_SD3_DAT0__SD3_DATA0 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
94*10fda487SEric Nelson 	MX6_PAD_SD3_DAT1__SD3_DATA1 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
95*10fda487SEric Nelson 	MX6_PAD_SD3_DAT2__SD3_DATA2 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
96*10fda487SEric Nelson 	MX6_PAD_SD3_DAT3__SD3_DATA3 | MUX_PAD_CTRL(USDHC_PAD_CTRL),
97*10fda487SEric 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),
103*10fda487SEric Nelson 	MX6_PAD_RGMII_TXC__RGMII_TXC	| MUX_PAD_CTRL(ENET_PAD_CTRL),
104*10fda487SEric Nelson 	MX6_PAD_RGMII_TD0__RGMII_TD0	| MUX_PAD_CTRL(ENET_PAD_CTRL),
105*10fda487SEric Nelson 	MX6_PAD_RGMII_TD1__RGMII_TD1	| MUX_PAD_CTRL(ENET_PAD_CTRL),
106*10fda487SEric Nelson 	MX6_PAD_RGMII_TD2__RGMII_TD2	| MUX_PAD_CTRL(ENET_PAD_CTRL),
107*10fda487SEric 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 */
111*10fda487SEric Nelson 	MX6_PAD_RGMII_RXC__GPIO6_IO30		| MUX_PAD_CTRL(NO_PAD_CTRL),
112c2cde27dSStefan Roese 	/* pin 32 - 1 - (MODE0) all */
113*10fda487SEric Nelson 	MX6_PAD_RGMII_RD0__GPIO6_IO25		| MUX_PAD_CTRL(NO_PAD_CTRL),
114c2cde27dSStefan Roese 	/* pin 31 - 1 - (MODE1) all */
115*10fda487SEric Nelson 	MX6_PAD_RGMII_RD1__GPIO6_IO27		| MUX_PAD_CTRL(NO_PAD_CTRL),
116c2cde27dSStefan Roese 	/* pin 28 - 1 - (MODE2) all */
117*10fda487SEric Nelson 	MX6_PAD_RGMII_RD2__GPIO6_IO28		| MUX_PAD_CTRL(NO_PAD_CTRL),
118c2cde27dSStefan Roese 	/* pin 27 - 1 - (MODE3) all */
119*10fda487SEric Nelson 	MX6_PAD_RGMII_RD3__GPIO6_IO29		| MUX_PAD_CTRL(NO_PAD_CTRL),
120c2cde27dSStefan Roese 	/* pin 33 - 1 - (CLK125_EN) 125Mhz clockout enabled */
121*10fda487SEric Nelson 	MX6_PAD_RGMII_RX_CTL__GPIO6_IO24		| MUX_PAD_CTRL(NO_PAD_CTRL),
122c2cde27dSStefan Roese 	/* pin 42 PHY nRST */
123*10fda487SEric 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[] = {
127*10fda487SEric Nelson 	MX6_PAD_RGMII_RXC__RGMII_RXC	| MUX_PAD_CTRL(ENET_PAD_CTRL),
128*10fda487SEric Nelson 	MX6_PAD_RGMII_RD0__RGMII_RD0	| MUX_PAD_CTRL(ENET_PAD_CTRL),
129*10fda487SEric Nelson 	MX6_PAD_RGMII_RD1__RGMII_RD1	| MUX_PAD_CTRL(ENET_PAD_CTRL),
130*10fda487SEric Nelson 	MX6_PAD_RGMII_RD2__RGMII_RD2	| MUX_PAD_CTRL(ENET_PAD_CTRL),
131*10fda487SEric 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[] = {
136*10fda487SEric Nelson 	MX6_PAD_NANDF_CLE__NAND_CLE		| MUX_PAD_CTRL(NO_PAD_CTRL),
137*10fda487SEric Nelson 	MX6_PAD_NANDF_ALE__NAND_ALE		| MUX_PAD_CTRL(NO_PAD_CTRL),
138*10fda487SEric Nelson 	MX6_PAD_NANDF_WP_B__NAND_WP_B	| MUX_PAD_CTRL(NO_PAD_CTRL),
139*10fda487SEric Nelson 	MX6_PAD_NANDF_RB0__NAND_READY_B	| MUX_PAD_CTRL(NO_PAD_CTRL),
140*10fda487SEric Nelson 	MX6_PAD_NANDF_CS0__NAND_CE0_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
141*10fda487SEric Nelson 	MX6_PAD_NANDF_CS1__NAND_CE1_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
142*10fda487SEric Nelson 	MX6_PAD_NANDF_CS2__NAND_CE2_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
143*10fda487SEric Nelson 	MX6_PAD_NANDF_CS3__NAND_CE3_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
144*10fda487SEric Nelson 	MX6_PAD_SD4_CMD__NAND_RE_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
145*10fda487SEric Nelson 	MX6_PAD_SD4_CLK__NAND_WE_B		| MUX_PAD_CTRL(NO_PAD_CTRL),
146*10fda487SEric Nelson 	MX6_PAD_NANDF_D0__NAND_DATA00		| MUX_PAD_CTRL(NO_PAD_CTRL),
147*10fda487SEric Nelson 	MX6_PAD_NANDF_D1__NAND_DATA01		| MUX_PAD_CTRL(NO_PAD_CTRL),
148*10fda487SEric Nelson 	MX6_PAD_NANDF_D2__NAND_DATA02		| MUX_PAD_CTRL(NO_PAD_CTRL),
149*10fda487SEric Nelson 	MX6_PAD_NANDF_D3__NAND_DATA03		| MUX_PAD_CTRL(NO_PAD_CTRL),
150*10fda487SEric Nelson 	MX6_PAD_NANDF_D4__NAND_DATA04		| MUX_PAD_CTRL(NO_PAD_CTRL),
151*10fda487SEric Nelson 	MX6_PAD_NANDF_D5__NAND_DATA05		| MUX_PAD_CTRL(NO_PAD_CTRL),
152*10fda487SEric Nelson 	MX6_PAD_NANDF_D6__NAND_DATA06		| MUX_PAD_CTRL(NO_PAD_CTRL),
153*10fda487SEric Nelson 	MX6_PAD_NANDF_D7__NAND_DATA07		| MUX_PAD_CTRL(NO_PAD_CTRL),
154*10fda487SEric 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 	int ret;
268c2cde27dSStefan Roese 
269c2cde27dSStefan Roese 	setup_iomux_enet();
270c2cde27dSStefan Roese 
271c2cde27dSStefan Roese 	ret = cpu_eth_init(bis);
272c2cde27dSStefan Roese 	if (ret)
273c2cde27dSStefan Roese 		printf("FEC MXC: %s:failed\n", __func__);
274c2cde27dSStefan Roese 
275c2cde27dSStefan Roese 	return ret;
276c2cde27dSStefan Roese }
277c2cde27dSStefan Roese 
278c2cde27dSStefan Roese int board_early_init_f(void)
279c2cde27dSStefan Roese {
280c2cde27dSStefan Roese 	setup_iomux_uart();
281c2cde27dSStefan Roese 
282c2cde27dSStefan Roese 	return 0;
283c2cde27dSStefan Roese }
284c2cde27dSStefan Roese 
285c2cde27dSStefan Roese int board_init(void)
286c2cde27dSStefan Roese {
287c2cde27dSStefan Roese 	/* address of boot parameters */
288c2cde27dSStefan Roese 	gd->bd->bi_boot_params = PHYS_SDRAM + 0x100;
289c2cde27dSStefan Roese 
290c2cde27dSStefan Roese 	setup_i2c(0, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info0);
291c2cde27dSStefan Roese 	setup_i2c(2, CONFIG_SYS_I2C_SPEED, 0x7f, &i2c_pad_info2);
292c2cde27dSStefan Roese 
293c2cde27dSStefan Roese 	setup_gpmi_nand();
294c2cde27dSStefan Roese 
295c2cde27dSStefan Roese 	return 0;
296c2cde27dSStefan Roese }
297c2cde27dSStefan Roese 
298c2cde27dSStefan Roese int checkboard(void)
299c2cde27dSStefan Roese {
300c2cde27dSStefan Roese 	puts("Board: Titanium\n");
301c2cde27dSStefan Roese 
302c2cde27dSStefan Roese 	return 0;
303c2cde27dSStefan Roese }
304c2cde27dSStefan Roese 
305c2cde27dSStefan Roese #ifdef CONFIG_CMD_BMODE
306c2cde27dSStefan Roese static const struct boot_mode board_boot_modes[] = {
307c2cde27dSStefan Roese 	/* NAND */
308c2cde27dSStefan Roese 	{ "nand", MAKE_CFGVAL(0x80, 0x02, 0x00, 0x00) },
309c2cde27dSStefan Roese 	/* 4 bit bus width */
310c2cde27dSStefan Roese 	{ "mmc0", MAKE_CFGVAL(0x40, 0x30, 0x00, 0x00) },
311c2cde27dSStefan Roese 	{ "mmc1", MAKE_CFGVAL(0x40, 0x38, 0x00, 0x00) },
312c2cde27dSStefan Roese 	{ NULL, 0 },
313c2cde27dSStefan Roese };
314c2cde27dSStefan Roese #endif
315c2cde27dSStefan Roese 
316c2cde27dSStefan Roese int misc_init_r(void)
317c2cde27dSStefan Roese {
318c2cde27dSStefan Roese #ifdef CONFIG_CMD_BMODE
319c2cde27dSStefan Roese 	add_board_boot_modes(board_boot_modes);
320c2cde27dSStefan Roese #endif
321c2cde27dSStefan Roese 
322c2cde27dSStefan Roese 	return 0;
323c2cde27dSStefan Roese }
324