xref: /openbmc/u-boot/board/freescale/t208xqds/eth_t208xqds.c (revision f6ae1ca05839f92b103aaa0743d1d0012ba9773d)
1 /*
2  * Copyright 2013 Freescale Semiconductor, Inc.
3  *
4  * Shengzhou Liu <Shengzhou.Liu@freescale.com>
5  *
6  * SPDX-License-Identifier:     GPL-2.0+
7  */
8 
9 #include <common.h>
10 #include <command.h>
11 #include <netdev.h>
12 #include <asm/mmu.h>
13 #include <asm/processor.h>
14 #include <asm/immap_85xx.h>
15 #include <asm/fsl_law.h>
16 #include <asm/fsl_serdes.h>
17 #include <asm/fsl_portals.h>
18 #include <asm/fsl_liodn.h>
19 #include <malloc.h>
20 #include <fm_eth.h>
21 #include <fsl_mdio.h>
22 #include <miiphy.h>
23 #include <phy.h>
24 #include <asm/fsl_dtsec.h>
25 #include <asm/fsl_serdes.h>
26 #include "../common/qixis.h"
27 #include "../common/fman.h"
28 #include "t208xqds_qixis.h"
29 
30 #define EMI_NONE	0xFFFFFFFF
31 #define EMI1_RGMII1	0
32 #define EMI1_RGMII2     1
33 #define EMI1_SLOT1	2
34 #if defined(CONFIG_T2080QDS)
35 #define EMI1_SLOT2	6
36 #define EMI1_SLOT3	3
37 #define EMI1_SLOT4	4
38 #define EMI1_SLOT5	5
39 #define EMI2            7
40 #elif defined(CONFIG_T2081QDS)
41 #define EMI1_SLOT2      3
42 #define EMI1_SLOT3      4
43 #define EMI1_SLOT5      5
44 #define EMI1_SLOT6      6
45 #define EMI1_SLOT7      7
46 #define EMI2		8
47 #endif
48 
49 static int mdio_mux[NUM_FM_PORTS];
50 
51 static const char * const mdio_names[] = {
52 #if defined(CONFIG_T2080QDS)
53 	"T2080QDS_MDIO_RGMII1",
54 	"T2080QDS_MDIO_RGMII2",
55 	"T2080QDS_MDIO_SLOT1",
56 	"T2080QDS_MDIO_SLOT3",
57 	"T2080QDS_MDIO_SLOT4",
58 	"T2080QDS_MDIO_SLOT5",
59 	"T2080QDS_MDIO_SLOT2",
60 	"T2080QDS_MDIO_10GC",
61 #elif defined(CONFIG_T2081QDS)
62 	"T2081QDS_MDIO_RGMII1",
63 	"T2081QDS_MDIO_RGMII2",
64 	"T2081QDS_MDIO_SLOT1",
65 	"T2081QDS_MDIO_SLOT2",
66 	"T2081QDS_MDIO_SLOT3",
67 	"T2081QDS_MDIO_SLOT5",
68 	"T2081QDS_MDIO_SLOT6",
69 	"T2081QDS_MDIO_SLOT7",
70 	"T2081QDS_MDIO_10GC",
71 #endif
72 };
73 
74 /* Map SerDes1 8 lanes to default slot, will be initialized dynamically */
75 #if defined(CONFIG_T2080QDS)
76 static u8 lane_to_slot[] = {3, 3, 3, 3, 1, 1, 1, 1};
77 #elif defined(CONFIG_T2081QDS)
78 static u8 lane_to_slot[] = {2, 2, 2, 2, 1, 1, 1, 1};
79 #endif
80 
81 static const char *t208xqds_mdio_name_for_muxval(u8 muxval)
82 {
83 	return mdio_names[muxval];
84 }
85 
86 struct mii_dev *mii_dev_for_muxval(u8 muxval)
87 {
88 	struct mii_dev *bus;
89 	const char *name = t208xqds_mdio_name_for_muxval(muxval);
90 
91 	if (!name) {
92 		printf("No bus for muxval %x\n", muxval);
93 		return NULL;
94 	}
95 
96 	bus = miiphy_get_dev_by_name(name);
97 
98 	if (!bus) {
99 		printf("No bus by name %s\n", name);
100 		return NULL;
101 	}
102 
103 	return bus;
104 }
105 
106 struct t208xqds_mdio {
107 	u8 muxval;
108 	struct mii_dev *realbus;
109 };
110 
111 static void t208xqds_mux_mdio(u8 muxval)
112 {
113 	u8 brdcfg4;
114 	if (muxval < 8) {
115 		brdcfg4 = QIXIS_READ(brdcfg[4]);
116 		brdcfg4 &= ~BRDCFG4_EMISEL_MASK;
117 		brdcfg4 |= (muxval << BRDCFG4_EMISEL_SHIFT);
118 		QIXIS_WRITE(brdcfg[4], brdcfg4);
119 	}
120 }
121 
122 static int t208xqds_mdio_read(struct mii_dev *bus, int addr, int devad,
123 				int regnum)
124 {
125 	struct t208xqds_mdio *priv = bus->priv;
126 
127 	t208xqds_mux_mdio(priv->muxval);
128 
129 	return priv->realbus->read(priv->realbus, addr, devad, regnum);
130 }
131 
132 static int t208xqds_mdio_write(struct mii_dev *bus, int addr, int devad,
133 				int regnum, u16 value)
134 {
135 	struct t208xqds_mdio *priv = bus->priv;
136 
137 	t208xqds_mux_mdio(priv->muxval);
138 
139 	return priv->realbus->write(priv->realbus, addr, devad, regnum, value);
140 }
141 
142 static int t208xqds_mdio_reset(struct mii_dev *bus)
143 {
144 	struct t208xqds_mdio *priv = bus->priv;
145 
146 	return priv->realbus->reset(priv->realbus);
147 }
148 
149 static int t208xqds_mdio_init(char *realbusname, u8 muxval)
150 {
151 	struct t208xqds_mdio *pmdio;
152 	struct mii_dev *bus = mdio_alloc();
153 
154 	if (!bus) {
155 		printf("Failed to allocate t208xqds MDIO bus\n");
156 		return -1;
157 	}
158 
159 	pmdio = malloc(sizeof(*pmdio));
160 	if (!pmdio) {
161 		printf("Failed to allocate t208xqds private data\n");
162 		free(bus);
163 		return -1;
164 	}
165 
166 	bus->read = t208xqds_mdio_read;
167 	bus->write = t208xqds_mdio_write;
168 	bus->reset = t208xqds_mdio_reset;
169 	sprintf(bus->name, t208xqds_mdio_name_for_muxval(muxval));
170 
171 	pmdio->realbus = miiphy_get_dev_by_name(realbusname);
172 
173 	if (!pmdio->realbus) {
174 		printf("No bus with name %s\n", realbusname);
175 		free(bus);
176 		free(pmdio);
177 		return -1;
178 	}
179 
180 	pmdio->muxval = muxval;
181 	bus->priv = pmdio;
182 	return mdio_register(bus);
183 }
184 
185 void board_ft_fman_fixup_port(void *fdt, char *compat, phys_addr_t addr,
186 				enum fm_port port, int offset)
187 {
188 	int phy;
189 	char alias[20];
190 	struct fixed_link f_link;
191 	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
192 	u32 srds_s1 = in_be32(&gur->rcwsr[4]) &
193 				FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
194 
195 	srds_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
196 
197 	if (fm_info_get_enet_if(port) == PHY_INTERFACE_MODE_SGMII) {
198 		phy = fm_info_get_phy_address(port);
199 		switch (port) {
200 #if defined(CONFIG_T2080QDS)
201 		case FM1_DTSEC1:
202 		case FM1_DTSEC2:
203 		case FM1_DTSEC9:
204 		case FM1_DTSEC10:
205 			if (mdio_mux[port] == EMI1_SLOT2) {
206 				sprintf(alias, "phy_sgmii_s2_%x", phy);
207 				fdt_set_phy_handle(fdt, compat, addr, alias);
208 				fdt_status_okay_by_alias(fdt, "emi1_slot2");
209 			} else if (mdio_mux[port] == EMI1_SLOT3) {
210 				sprintf(alias, "phy_sgmii_s3_%x", phy);
211 				fdt_set_phy_handle(fdt, compat, addr, alias);
212 				fdt_status_okay_by_alias(fdt, "emi1_slot3");
213 			}
214 			break;
215 		case FM1_DTSEC5:
216 		case FM1_DTSEC6:
217 			if (mdio_mux[port] == EMI1_SLOT1) {
218 				sprintf(alias, "phy_sgmii_s1_%x", phy);
219 				fdt_set_phy_handle(fdt, compat, addr, alias);
220 				fdt_status_okay_by_alias(fdt, "emi1_slot1");
221 			} else if (mdio_mux[port] == EMI1_SLOT2) {
222 				sprintf(alias, "phy_sgmii_s2_%x", phy);
223 				fdt_set_phy_handle(fdt, compat, addr, alias);
224 				fdt_status_okay_by_alias(fdt, "emi1_slot2");
225 			}
226 			break;
227 #elif defined(CONFIG_T2081QDS)
228 		case FM1_DTSEC1:
229 		case FM1_DTSEC2:
230 		case FM1_DTSEC5:
231 		case FM1_DTSEC6:
232 		case FM1_DTSEC9:
233 		case FM1_DTSEC10:
234 			if (mdio_mux[port] == EMI1_SLOT2) {
235 				sprintf(alias, "phy_sgmii_s2_%x", phy);
236 				fdt_set_phy_handle(fdt, compat, addr, alias);
237 				fdt_status_okay_by_alias(fdt, "emi1_slot2");
238 			} else if (mdio_mux[port] == EMI1_SLOT3) {
239 				sprintf(alias, "phy_sgmii_s3_%x", phy);
240 				fdt_set_phy_handle(fdt, compat, addr, alias);
241 				fdt_status_okay_by_alias(fdt, "emi1_slot3");
242 			} else if (mdio_mux[port] == EMI1_SLOT5) {
243 				sprintf(alias, "phy_sgmii_s5_%x", phy);
244 				fdt_set_phy_handle(fdt, compat, addr, alias);
245 				fdt_status_okay_by_alias(fdt, "emi1_slot5");
246 			} else if (mdio_mux[port] == EMI1_SLOT6) {
247 				sprintf(alias, "phy_sgmii_s6_%x", phy);
248 				fdt_set_phy_handle(fdt, compat, addr, alias);
249 				fdt_status_okay_by_alias(fdt, "emi1_slot6");
250 			} else if (mdio_mux[port] == EMI1_SLOT7) {
251 				sprintf(alias, "phy_sgmii_s7_%x", phy);
252 				fdt_set_phy_handle(fdt, compat, addr, alias);
253 				fdt_status_okay_by_alias(fdt, "emi1_slot7");
254 			}
255 			break;
256 #endif
257 		default:
258 			break;
259 		}
260 
261 	} else if (fm_info_get_enet_if(port) == PHY_INTERFACE_MODE_XGMII) {
262 		switch (srds_s1) {
263 		case 0x66: /* XFI interface */
264 		case 0x6b:
265 		case 0x6c:
266 		case 0x6d:
267 		case 0x71:
268 			f_link.phy_id = port;
269 			f_link.duplex = 1;
270 			f_link.link_speed = 10000;
271 			f_link.pause = 0;
272 			f_link.asym_pause = 0;
273 			/* no PHY for XFI */
274 			fdt_delprop(fdt, offset, "phy-handle");
275 			fdt_setprop(fdt, offset, "fixed-link", &f_link,
276 				    sizeof(f_link));
277 			break;
278 		default:
279 			break;
280 		}
281 	}
282 }
283 
284 void fdt_fixup_board_enet(void *fdt)
285 {
286 	return;
287 }
288 
289 /*
290  * This function reads RCW to check if Serdes1{A:H} is configured
291  * to slot 1/2/3/4/5/6/7 and update the lane_to_slot[] array accordingly
292  */
293 static void initialize_lane_to_slot(void)
294 {
295 	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
296 	u32 srds_s1 = in_be32(&gur->rcwsr[4]) &
297 				FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
298 
299 	srds_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
300 
301 	switch (srds_s1) {
302 #if defined(CONFIG_T2080QDS)
303 	case 0x51:
304 	case 0x5f:
305 	case 0x65:
306 	case 0x6b:
307 	case 0x71:
308 		lane_to_slot[5] = 2;
309 		lane_to_slot[6] = 2;
310 		lane_to_slot[7] = 2;
311 		break;
312 	case 0xa6:
313 	case 0x8e:
314 	case 0x8f:
315 	case 0x82:
316 	case 0x83:
317 	case 0xd3:
318 	case 0xd9:
319 	case 0xcb:
320 		lane_to_slot[6] = 2;
321 		lane_to_slot[7] = 2;
322 		break;
323 	case 0xda:
324 		lane_to_slot[4] = 3;
325 		lane_to_slot[5] = 3;
326 		lane_to_slot[6] = 3;
327 		lane_to_slot[7] = 3;
328 		break;
329 #elif defined(CONFIG_T2081QDS)
330 	case 0x6b:
331 		lane_to_slot[4] = 1;
332 		lane_to_slot[5] = 3;
333 		lane_to_slot[6] = 3;
334 		lane_to_slot[7] = 3;
335 		break;
336 	case 0xca:
337 	case 0xcb:
338 		lane_to_slot[1] = 7;
339 		lane_to_slot[2] = 6;
340 		lane_to_slot[3] = 5;
341 		lane_to_slot[5] = 3;
342 		lane_to_slot[6] = 3;
343 		lane_to_slot[7] = 3;
344 		break;
345 	case 0xf2:
346 		lane_to_slot[1] = 7;
347 		lane_to_slot[2] = 7;
348 		lane_to_slot[3] = 7;
349 		lane_to_slot[5] = 4;
350 		lane_to_slot[6] = 3;
351 		lane_to_slot[7] = 7;
352 		break;
353 #endif
354 	default:
355 		break;
356 	}
357 }
358 
359 int board_eth_init(bd_t *bis)
360 {
361 #if defined(CONFIG_FMAN_ENET)
362 	int i, idx, lane, slot, interface;
363 	struct memac_mdio_info dtsec_mdio_info;
364 	struct memac_mdio_info tgec_mdio_info;
365 	ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
366 	u32 rcwsr13 = in_be32(&gur->rcwsr[13]);
367 	u32 srds_s1;
368 
369 	srds_s1 = in_be32(&gur->rcwsr[4]) &
370 					FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
371 	srds_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
372 
373 	initialize_lane_to_slot();
374 
375 	/* Initialize the mdio_mux array so we can recognize empty elements */
376 	for (i = 0; i < NUM_FM_PORTS; i++)
377 		mdio_mux[i] = EMI_NONE;
378 
379 	dtsec_mdio_info.regs =
380 		(struct memac_mdio_controller *)CONFIG_SYS_FM1_DTSEC_MDIO_ADDR;
381 
382 	dtsec_mdio_info.name = DEFAULT_FM_MDIO_NAME;
383 
384 	/* Register the 1G MDIO bus */
385 	fm_memac_mdio_init(bis, &dtsec_mdio_info);
386 
387 	tgec_mdio_info.regs =
388 		(struct memac_mdio_controller *)CONFIG_SYS_FM1_TGEC_MDIO_ADDR;
389 	tgec_mdio_info.name = DEFAULT_FM_TGEC_MDIO_NAME;
390 
391 	/* Register the 10G MDIO bus */
392 	fm_memac_mdio_init(bis, &tgec_mdio_info);
393 
394 	/* Register the muxing front-ends to the MDIO buses */
395 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_RGMII1);
396 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_RGMII2);
397 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT1);
398 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT2);
399 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT3);
400 #if defined(CONFIG_T2080QDS)
401 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT4);
402 #endif
403 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT5);
404 #if defined(CONFIG_T2081QDS)
405 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT6);
406 	t208xqds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT7);
407 #endif
408 	t208xqds_mdio_init(DEFAULT_FM_TGEC_MDIO_NAME, EMI2);
409 
410 	/* Set the two on-board RGMII PHY address */
411 	fm_info_set_phy_address(FM1_DTSEC3, RGMII_PHY1_ADDR);
412 	if ((rcwsr13 & FSL_CORENET_RCWSR13_EC2) ==
413 			FSL_CORENET_RCWSR13_EC2_DTSEC4_RGMII)
414 		fm_info_set_phy_address(FM1_DTSEC4, RGMII_PHY2_ADDR);
415 	else
416 		fm_info_set_phy_address(FM1_DTSEC10, RGMII_PHY2_ADDR);
417 
418 	switch (srds_s1) {
419 	case 0x1c:
420 	case 0x95:
421 	case 0xa2:
422 	case 0x94:
423 		/* T2080QDS: SGMII in Slot3;  T2081QDS: SGMII in Slot2 */
424 		fm_info_set_phy_address(FM1_DTSEC9, SGMII_CARD_PORT1_PHY_ADDR);
425 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT2_PHY_ADDR);
426 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
427 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
428 		/* T2080QDS: SGMII in Slot2;  T2081QDS: SGMII in Slot1 */
429 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
430 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT4_PHY_ADDR);
431 		break;
432 	case 0x51:
433 	case 0x5f:
434 	case 0x65:
435 		/* T2080QDS: XAUI/HiGig in Slot3;  T2081QDS: in Slot2 */
436 		fm_info_set_phy_address(FM1_10GEC1, FM1_10GEC1_PHY_ADDR);
437 		/* T2080QDS: SGMII in Slot2;  T2081QDS: in Slot3 */
438 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
439 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT4_PHY_ADDR);
440 		break;
441 	case 0x66:
442 		/*
443 		 * XFI does not need a PHY to work, but to avoid U-boot use
444 		 * default PHY address which is zero to a MAC when it found
445 		 * a MAC has no PHY address, we give a PHY address to XFI
446 		 * MAC, and should not use a real XAUI PHY address, since
447 		 * MDIO can access it successfully, and then MDIO thinks
448 		 * the XAUI card is used for the XFI MAC, which will cause
449 		 * error.
450 		 */
451 		fm_info_set_phy_address(FM1_10GEC1, 4);
452 		fm_info_set_phy_address(FM1_10GEC2, 5);
453 		fm_info_set_phy_address(FM1_10GEC3, 6);
454 		fm_info_set_phy_address(FM1_10GEC4, 7);
455 		break;
456 	case 0x6b:
457 		fm_info_set_phy_address(FM1_10GEC1, 4);
458 		fm_info_set_phy_address(FM1_10GEC2, 5);
459 		fm_info_set_phy_address(FM1_10GEC3, 6);
460 		fm_info_set_phy_address(FM1_10GEC4, 7);
461 		/* T2080QDS: SGMII in Slot2;  T2081QDS: in Slot3 */
462 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
463 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT2_PHY_ADDR);
464 		break;
465 	case 0x6c:
466 	case 0x6d:
467 		fm_info_set_phy_address(FM1_10GEC1, 4);
468 		fm_info_set_phy_address(FM1_10GEC2, 5);
469 		/* T2080QDS: SGMII in Slot3;  T2081QDS: in Slot2 */
470 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
471 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
472 		break;
473 	case 0x71:
474 		/* SGMII in Slot3 */
475 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
476 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
477 		/* SGMII in Slot2 */
478 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
479 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT2_PHY_ADDR);
480 		break;
481 	case 0xa6:
482 	case 0x8e:
483 	case 0x8f:
484 	case 0x82:
485 	case 0x83:
486 		/* SGMII in Slot3 */
487 		fm_info_set_phy_address(FM1_DTSEC9, SGMII_CARD_PORT1_PHY_ADDR);
488 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT2_PHY_ADDR);
489 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
490 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
491 		/* SGMII in Slot2 */
492 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
493 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT2_PHY_ADDR);
494 		break;
495 	case 0xa4:
496 	case 0x96:
497 	case 0x8a:
498 		/* SGMII in Slot3 */
499 		fm_info_set_phy_address(FM1_DTSEC9, SGMII_CARD_PORT1_PHY_ADDR);
500 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT2_PHY_ADDR);
501 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
502 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
503 		break;
504 #if defined(CONFIG_T2080QDS)
505 	case 0xd9:
506 	case 0xd3:
507 	case 0xcb:
508 		/* SGMII in Slot3 */
509 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT2_PHY_ADDR);
510 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT3_PHY_ADDR);
511 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT4_PHY_ADDR);
512 		/* SGMII in Slot2 */
513 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT3_PHY_ADDR);
514 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT2_PHY_ADDR);
515 		break;
516 #elif defined(CONFIG_T2081QDS)
517 	case 0xca:
518 	case 0xcb:
519 		/* SGMII in Slot3 */
520 		fm_info_set_phy_address(FM1_DTSEC5, SGMII_CARD_PORT1_PHY_ADDR);
521 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT2_PHY_ADDR);
522 		/* SGMII in Slot5 */
523 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT1_PHY_ADDR);
524 		/* SGMII in Slot6 */
525 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT1_PHY_ADDR);
526 		/* SGMII in Slot7 */
527 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT3_PHY_ADDR);
528 		break;
529 #endif
530 	case 0xf2:
531 		/* T2080QDS: SGMII in Slot3; T2081QDS: SGMII in Slot7 */
532 		fm_info_set_phy_address(FM1_DTSEC1, SGMII_CARD_PORT1_PHY_ADDR);
533 		fm_info_set_phy_address(FM1_DTSEC2, SGMII_CARD_PORT2_PHY_ADDR);
534 		fm_info_set_phy_address(FM1_DTSEC10, SGMII_CARD_PORT3_PHY_ADDR);
535 		fm_info_set_phy_address(FM1_DTSEC6, SGMII_CARD_PORT4_PHY_ADDR);
536 		break;
537 	default:
538 		break;
539 	}
540 
541 	for (i = FM1_DTSEC1; i < FM1_DTSEC1 + CONFIG_SYS_NUM_FM1_DTSEC; i++) {
542 		idx = i - FM1_DTSEC1;
543 		interface = fm_info_get_enet_if(i);
544 		switch (interface) {
545 		case PHY_INTERFACE_MODE_SGMII:
546 			lane = serdes_get_first_lane(FSL_SRDS_1,
547 					SGMII_FM1_DTSEC1 + idx);
548 			if (lane < 0)
549 				break;
550 			slot = lane_to_slot[lane];
551 			debug("FM1@DTSEC%u expects SGMII in slot %u\n",
552 			      idx + 1, slot);
553 			if (QIXIS_READ(present2) & (1 << (slot - 1)))
554 				fm_disable_port(i);
555 
556 			switch (slot) {
557 			case 1:
558 				mdio_mux[i] = EMI1_SLOT1;
559 				fm_info_set_mdio(i, mii_dev_for_muxval(
560 						 mdio_mux[i]));
561 				break;
562 			case 2:
563 				mdio_mux[i] = EMI1_SLOT2;
564 				fm_info_set_mdio(i, mii_dev_for_muxval(
565 						 mdio_mux[i]));
566 				break;
567 			case 3:
568 				mdio_mux[i] = EMI1_SLOT3;
569 				fm_info_set_mdio(i, mii_dev_for_muxval(
570 						 mdio_mux[i]));
571 				break;
572 #if defined(CONFIG_T2081QDS)
573 			case 5:
574 				mdio_mux[i] = EMI1_SLOT5;
575 				fm_info_set_mdio(i, mii_dev_for_muxval(
576 						 mdio_mux[i]));
577 				break;
578 			case 6:
579 				mdio_mux[i] = EMI1_SLOT6;
580 				fm_info_set_mdio(i, mii_dev_for_muxval(
581 						 mdio_mux[i]));
582 				break;
583 			case 7:
584 				mdio_mux[i] = EMI1_SLOT7;
585 				fm_info_set_mdio(i, mii_dev_for_muxval(
586 						 mdio_mux[i]));
587 				break;
588 #endif
589 			}
590 			break;
591 		case PHY_INTERFACE_MODE_RGMII:
592 			if (i == FM1_DTSEC3)
593 				mdio_mux[i] = EMI1_RGMII1;
594 			else if (i == FM1_DTSEC4 || FM1_DTSEC10)
595 				mdio_mux[i] = EMI1_RGMII2;
596 			fm_info_set_mdio(i, mii_dev_for_muxval(mdio_mux[i]));
597 			break;
598 		default:
599 			break;
600 		}
601 	}
602 
603 	for (i = FM1_10GEC1; i < FM1_10GEC1 + CONFIG_SYS_NUM_FM1_10GEC; i++) {
604 		idx = i - FM1_10GEC1;
605 		switch (fm_info_get_enet_if(i)) {
606 		case PHY_INTERFACE_MODE_XGMII:
607 			if (srds_s1 == 0x51) {
608 				lane = serdes_get_first_lane(FSL_SRDS_1,
609 						XAUI_FM1_MAC9 + idx);
610 			} else if ((srds_s1 == 0x5f) || (srds_s1 == 0x65)) {
611 				lane = serdes_get_first_lane(FSL_SRDS_1,
612 						HIGIG_FM1_MAC9 + idx);
613 			} else {
614 				if (i == FM1_10GEC1 || i == FM1_10GEC2)
615 					lane = serdes_get_first_lane(FSL_SRDS_1,
616 						XFI_FM1_MAC9 + idx);
617 				else
618 					lane = serdes_get_first_lane(FSL_SRDS_1,
619 						XFI_FM1_MAC1 + idx);
620 			}
621 
622 			if (lane < 0)
623 				break;
624 			mdio_mux[i] = EMI2;
625 			fm_info_set_mdio(i, mii_dev_for_muxval(mdio_mux[i]));
626 
627 			if ((srds_s1 == 0x66) || (srds_s1 == 0x6b) ||
628 			    (srds_s1 == 0x6c) || (srds_s1 == 0x6d) ||
629 			    (srds_s1 == 0x71)) {
630 				/* As XFI is in cage intead of a slot, so
631 				 * ensure doesn't disable the corresponding port
632 				 */
633 				break;
634 			}
635 
636 			slot = lane_to_slot[lane];
637 			if (QIXIS_READ(present2) & (1 << (slot - 1)))
638 				fm_disable_port(i);
639 			break;
640 		default:
641 			break;
642 		}
643 	}
644 
645 	cpu_eth_init(bis);
646 #endif /* CONFIG_FMAN_ENET */
647 
648 	return pci_eth_init(bis);
649 }
650