xref: /OK3568_Linux_fs/u-boot/board/freescale/t4rdb/eth.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /*
2*4882a593Smuzhiyun  * Copyright 2014 Freescale Semiconductor, Inc.
3*4882a593Smuzhiyun  *
4*4882a593Smuzhiyun  * Chunhe Lan <Chunhe.Lan@freescale.com>
5*4882a593Smuzhiyun  *
6*4882a593Smuzhiyun  * SPDX-License-Identifier:	GPL-2.0+
7*4882a593Smuzhiyun  */
8*4882a593Smuzhiyun 
9*4882a593Smuzhiyun #include <common.h>
10*4882a593Smuzhiyun #include <command.h>
11*4882a593Smuzhiyun #include <netdev.h>
12*4882a593Smuzhiyun #include <asm/mmu.h>
13*4882a593Smuzhiyun #include <asm/processor.h>
14*4882a593Smuzhiyun #include <asm/cache.h>
15*4882a593Smuzhiyun #include <asm/immap_85xx.h>
16*4882a593Smuzhiyun #include <asm/fsl_law.h>
17*4882a593Smuzhiyun #include <fsl_ddr_sdram.h>
18*4882a593Smuzhiyun #include <asm/fsl_serdes.h>
19*4882a593Smuzhiyun #include <asm/fsl_portals.h>
20*4882a593Smuzhiyun #include <asm/fsl_liodn.h>
21*4882a593Smuzhiyun #include <malloc.h>
22*4882a593Smuzhiyun #include <fm_eth.h>
23*4882a593Smuzhiyun #include <fsl_mdio.h>
24*4882a593Smuzhiyun #include <miiphy.h>
25*4882a593Smuzhiyun #include <phy.h>
26*4882a593Smuzhiyun #include <fsl_dtsec.h>
27*4882a593Smuzhiyun #include <asm/fsl_serdes.h>
28*4882a593Smuzhiyun #include <hwconfig.h>
29*4882a593Smuzhiyun 
30*4882a593Smuzhiyun #include "../common/fman.h"
31*4882a593Smuzhiyun #include "t4rdb.h"
32*4882a593Smuzhiyun 
fdt_fixup_board_enet(void * fdt)33*4882a593Smuzhiyun void fdt_fixup_board_enet(void *fdt)
34*4882a593Smuzhiyun {
35*4882a593Smuzhiyun 	return;
36*4882a593Smuzhiyun }
37*4882a593Smuzhiyun 
board_eth_init(bd_t * bis)38*4882a593Smuzhiyun int board_eth_init(bd_t *bis)
39*4882a593Smuzhiyun {
40*4882a593Smuzhiyun #if defined(CONFIG_FMAN_ENET)
41*4882a593Smuzhiyun 	int i, interface;
42*4882a593Smuzhiyun 	struct memac_mdio_info dtsec_mdio_info;
43*4882a593Smuzhiyun 	struct memac_mdio_info tgec_mdio_info;
44*4882a593Smuzhiyun 	struct mii_dev *dev;
45*4882a593Smuzhiyun 	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
46*4882a593Smuzhiyun 	u32 srds_prtcl_s1, srds_prtcl_s2;
47*4882a593Smuzhiyun 
48*4882a593Smuzhiyun 	srds_prtcl_s1 = in_be32(&gur->rcwsr[4]) &
49*4882a593Smuzhiyun 				FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
50*4882a593Smuzhiyun 	srds_prtcl_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
51*4882a593Smuzhiyun 	srds_prtcl_s2 = in_be32(&gur->rcwsr[4]) &
52*4882a593Smuzhiyun 				FSL_CORENET2_RCWSR4_SRDS2_PRTCL;
53*4882a593Smuzhiyun 	srds_prtcl_s2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;
54*4882a593Smuzhiyun 
55*4882a593Smuzhiyun 	dtsec_mdio_info.regs =
56*4882a593Smuzhiyun 		(struct memac_mdio_controller *)CONFIG_SYS_FM2_DTSEC_MDIO_ADDR;
57*4882a593Smuzhiyun 
58*4882a593Smuzhiyun 	dtsec_mdio_info.name = DEFAULT_FM_MDIO_NAME;
59*4882a593Smuzhiyun 
60*4882a593Smuzhiyun 	/* Register the 1G MDIO bus */
61*4882a593Smuzhiyun 	fm_memac_mdio_init(bis, &dtsec_mdio_info);
62*4882a593Smuzhiyun 
63*4882a593Smuzhiyun 	tgec_mdio_info.regs =
64*4882a593Smuzhiyun 		(struct memac_mdio_controller *)CONFIG_SYS_FM2_TGEC_MDIO_ADDR;
65*4882a593Smuzhiyun 	tgec_mdio_info.name = DEFAULT_FM_TGEC_MDIO_NAME;
66*4882a593Smuzhiyun 
67*4882a593Smuzhiyun 	/* Register the 10G MDIO bus */
68*4882a593Smuzhiyun 	fm_memac_mdio_init(bis, &tgec_mdio_info);
69*4882a593Smuzhiyun 
70*4882a593Smuzhiyun 	if ((srds_prtcl_s1 == 28) || (srds_prtcl_s1 == 27)) {
71*4882a593Smuzhiyun 		/* SGMII */
72*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_PHY_ADDR1);
73*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_PHY_ADDR2);
74*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_DTSEC3, SGMII_PHY_ADDR3);
75*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_DTSEC4, SGMII_PHY_ADDR4);
76*4882a593Smuzhiyun 	} else {
77*4882a593Smuzhiyun 		puts("Invalid SerDes1 protocol for T4240RDB\n");
78*4882a593Smuzhiyun 	}
79*4882a593Smuzhiyun 
80*4882a593Smuzhiyun 	fm_disable_port(FM1_DTSEC5);
81*4882a593Smuzhiyun 	fm_disable_port(FM1_DTSEC6);
82*4882a593Smuzhiyun 
83*4882a593Smuzhiyun 	for (i = FM1_DTSEC1; i < FM1_DTSEC1 + CONFIG_SYS_NUM_FM1_DTSEC; i++) {
84*4882a593Smuzhiyun 		interface = fm_info_get_enet_if(i);
85*4882a593Smuzhiyun 		switch (interface) {
86*4882a593Smuzhiyun 		case PHY_INTERFACE_MODE_SGMII:
87*4882a593Smuzhiyun 			dev = miiphy_get_dev_by_name(DEFAULT_FM_MDIO_NAME);
88*4882a593Smuzhiyun 			fm_info_set_mdio(i, dev);
89*4882a593Smuzhiyun 			break;
90*4882a593Smuzhiyun 		default:
91*4882a593Smuzhiyun 			break;
92*4882a593Smuzhiyun 		}
93*4882a593Smuzhiyun 	}
94*4882a593Smuzhiyun 
95*4882a593Smuzhiyun 	for (i = FM1_10GEC1; i < FM1_10GEC1 + CONFIG_SYS_NUM_FM1_10GEC; i++) {
96*4882a593Smuzhiyun 		switch (fm_info_get_enet_if(i)) {
97*4882a593Smuzhiyun 		case PHY_INTERFACE_MODE_XGMII:
98*4882a593Smuzhiyun 			dev = miiphy_get_dev_by_name(DEFAULT_FM_TGEC_MDIO_NAME);
99*4882a593Smuzhiyun 			fm_info_set_mdio(i, dev);
100*4882a593Smuzhiyun 			break;
101*4882a593Smuzhiyun 		default:
102*4882a593Smuzhiyun 			break;
103*4882a593Smuzhiyun 		}
104*4882a593Smuzhiyun 	}
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun #if (CONFIG_SYS_NUM_FMAN == 2)
107*4882a593Smuzhiyun 	if ((srds_prtcl_s2 == 56) || (srds_prtcl_s2 == 55)) {
108*4882a593Smuzhiyun 		/* SGMII && XFI */
109*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_DTSEC1, SGMII_PHY_ADDR5);
110*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_DTSEC2, SGMII_PHY_ADDR6);
111*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_DTSEC3, SGMII_PHY_ADDR7);
112*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_DTSEC4, SGMII_PHY_ADDR8);
113*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_10GEC1, FM1_10GEC1_PHY_ADDR);
114*4882a593Smuzhiyun 		fm_info_set_phy_address(FM1_10GEC2, FM1_10GEC2_PHY_ADDR);
115*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_10GEC1, FM2_10GEC2_PHY_ADDR);
116*4882a593Smuzhiyun 		fm_info_set_phy_address(FM2_10GEC2, FM2_10GEC1_PHY_ADDR);
117*4882a593Smuzhiyun 	} else {
118*4882a593Smuzhiyun 		puts("Invalid SerDes2 protocol for T4240RDB\n");
119*4882a593Smuzhiyun 	}
120*4882a593Smuzhiyun 
121*4882a593Smuzhiyun 	fm_disable_port(FM2_DTSEC5);
122*4882a593Smuzhiyun 	fm_disable_port(FM2_DTSEC6);
123*4882a593Smuzhiyun 	for (i = FM2_DTSEC1; i < FM2_DTSEC1 + CONFIG_SYS_NUM_FM2_DTSEC; i++) {
124*4882a593Smuzhiyun 		interface = fm_info_get_enet_if(i);
125*4882a593Smuzhiyun 		switch (interface) {
126*4882a593Smuzhiyun 		case PHY_INTERFACE_MODE_SGMII:
127*4882a593Smuzhiyun 			dev = miiphy_get_dev_by_name(DEFAULT_FM_MDIO_NAME);
128*4882a593Smuzhiyun 			fm_info_set_mdio(i, dev);
129*4882a593Smuzhiyun 			break;
130*4882a593Smuzhiyun 		default:
131*4882a593Smuzhiyun 			break;
132*4882a593Smuzhiyun 		}
133*4882a593Smuzhiyun 	}
134*4882a593Smuzhiyun 
135*4882a593Smuzhiyun 	for (i = FM2_10GEC1; i < FM2_10GEC1 + CONFIG_SYS_NUM_FM2_10GEC; i++) {
136*4882a593Smuzhiyun 		switch (fm_info_get_enet_if(i)) {
137*4882a593Smuzhiyun 		case PHY_INTERFACE_MODE_XGMII:
138*4882a593Smuzhiyun 			dev = miiphy_get_dev_by_name(DEFAULT_FM_TGEC_MDIO_NAME);
139*4882a593Smuzhiyun 			fm_info_set_mdio(i, dev);
140*4882a593Smuzhiyun 			break;
141*4882a593Smuzhiyun 		default:
142*4882a593Smuzhiyun 			break;
143*4882a593Smuzhiyun 		}
144*4882a593Smuzhiyun 	}
145*4882a593Smuzhiyun #endif /* CONFIG_SYS_NUM_FMAN */
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun 	cpu_eth_init(bis);
148*4882a593Smuzhiyun #endif /* CONFIG_FMAN_ENET */
149*4882a593Smuzhiyun 
150*4882a593Smuzhiyun 	return pci_eth_init(bis);
151*4882a593Smuzhiyun }
152