eth.c 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2012 Freescale Semiconductor, Inc.
  4. */
  5. #include <common.h>
  6. #include <command.h>
  7. #include <netdev.h>
  8. #include <asm/mmu.h>
  9. #include <asm/processor.h>
  10. #include <asm/cache.h>
  11. #include <asm/immap_85xx.h>
  12. #include <asm/fsl_law.h>
  13. #include <fsl_ddr_sdram.h>
  14. #include <asm/fsl_serdes.h>
  15. #include <asm/fsl_portals.h>
  16. #include <asm/fsl_liodn.h>
  17. #include <malloc.h>
  18. #include <fm_eth.h>
  19. #include <fsl_mdio.h>
  20. #include <miiphy.h>
  21. #include <phy.h>
  22. #include <fsl_dtsec.h>
  23. #include <asm/fsl_serdes.h>
  24. #include <hwconfig.h>
  25. #include "../common/qixis.h"
  26. #include "../common/fman.h"
  27. #include "t4240qds_qixis.h"
  28. #define EMI_NONE 0xFFFFFFFF
  29. #define EMI1_RGMII 0
  30. #define EMI1_SLOT1 1
  31. #define EMI1_SLOT2 2
  32. #define EMI1_SLOT3 3
  33. #define EMI1_SLOT4 4
  34. #define EMI1_SLOT5 5
  35. #define EMI1_SLOT7 7
  36. #define EMI2 8
  37. /* Slot6 and Slot8 do not have EMI connections */
  38. static int mdio_mux[NUM_FM_PORTS];
  39. static const char *mdio_names[] = {
  40. "T4240QDS_MDIO0",
  41. "T4240QDS_MDIO1",
  42. "T4240QDS_MDIO2",
  43. "T4240QDS_MDIO3",
  44. "T4240QDS_MDIO4",
  45. "T4240QDS_MDIO5",
  46. "NULL",
  47. "T4240QDS_MDIO7",
  48. "T4240QDS_10GC",
  49. };
  50. static u8 lane_to_slot_fsm1[] = {1, 1, 1, 1, 2, 2, 2, 2};
  51. static u8 lane_to_slot_fsm2[] = {3, 3, 3, 3, 4, 4, 4, 4};
  52. static u8 slot_qsgmii_phyaddr[5][4] = {
  53. {0, 0, 0, 0},/* not used, to make index match slot No. */
  54. {0, 1, 2, 3},
  55. {4, 5, 6, 7},
  56. {8, 9, 0xa, 0xb},
  57. {0xc, 0xd, 0xe, 0xf},
  58. };
  59. static u8 qsgmiiphy_fix[NUM_FM_PORTS] = {0};
  60. static const char *t4240qds_mdio_name_for_muxval(u8 muxval)
  61. {
  62. return mdio_names[muxval];
  63. }
  64. struct mii_dev *mii_dev_for_muxval(u8 muxval)
  65. {
  66. struct mii_dev *bus;
  67. const char *name = t4240qds_mdio_name_for_muxval(muxval);
  68. if (!name) {
  69. printf("No bus for muxval %x\n", muxval);
  70. return NULL;
  71. }
  72. bus = miiphy_get_dev_by_name(name);
  73. if (!bus) {
  74. printf("No bus by name %s\n", name);
  75. return NULL;
  76. }
  77. return bus;
  78. }
  79. struct t4240qds_mdio {
  80. u8 muxval;
  81. struct mii_dev *realbus;
  82. };
  83. static void t4240qds_mux_mdio(u8 muxval)
  84. {
  85. u8 brdcfg4;
  86. if ((muxval < 6) || (muxval == 7)) {
  87. brdcfg4 = QIXIS_READ(brdcfg[4]);
  88. brdcfg4 &= ~BRDCFG4_EMISEL_MASK;
  89. brdcfg4 |= (muxval << BRDCFG4_EMISEL_SHIFT);
  90. QIXIS_WRITE(brdcfg[4], brdcfg4);
  91. }
  92. }
  93. static int t4240qds_mdio_read(struct mii_dev *bus, int addr, int devad,
  94. int regnum)
  95. {
  96. struct t4240qds_mdio *priv = bus->priv;
  97. t4240qds_mux_mdio(priv->muxval);
  98. return priv->realbus->read(priv->realbus, addr, devad, regnum);
  99. }
  100. static int t4240qds_mdio_write(struct mii_dev *bus, int addr, int devad,
  101. int regnum, u16 value)
  102. {
  103. struct t4240qds_mdio *priv = bus->priv;
  104. t4240qds_mux_mdio(priv->muxval);
  105. return priv->realbus->write(priv->realbus, addr, devad, regnum, value);
  106. }
  107. static int t4240qds_mdio_reset(struct mii_dev *bus)
  108. {
  109. struct t4240qds_mdio *priv = bus->priv;
  110. return priv->realbus->reset(priv->realbus);
  111. }
  112. static int t4240qds_mdio_init(char *realbusname, u8 muxval)
  113. {
  114. struct t4240qds_mdio *pmdio;
  115. struct mii_dev *bus = mdio_alloc();
  116. if (!bus) {
  117. printf("Failed to allocate T4240QDS MDIO bus\n");
  118. return -1;
  119. }
  120. pmdio = malloc(sizeof(*pmdio));
  121. if (!pmdio) {
  122. printf("Failed to allocate T4240QDS private data\n");
  123. free(bus);
  124. return -1;
  125. }
  126. bus->read = t4240qds_mdio_read;
  127. bus->write = t4240qds_mdio_write;
  128. bus->reset = t4240qds_mdio_reset;
  129. strcpy(bus->name, t4240qds_mdio_name_for_muxval(muxval));
  130. pmdio->realbus = miiphy_get_dev_by_name(realbusname);
  131. if (!pmdio->realbus) {
  132. printf("No bus with name %s\n", realbusname);
  133. free(bus);
  134. free(pmdio);
  135. return -1;
  136. }
  137. pmdio->muxval = muxval;
  138. bus->priv = pmdio;
  139. return mdio_register(bus);
  140. }
  141. void board_ft_fman_fixup_port(void *blob, char * prop, phys_addr_t pa,
  142. enum fm_port port, int offset)
  143. {
  144. int interface = fm_info_get_enet_if(port);
  145. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  146. u32 prtcl2 = in_be32(&gur->rcwsr[4]) & FSL_CORENET2_RCWSR4_SRDS2_PRTCL;
  147. prtcl2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;
  148. if (interface == PHY_INTERFACE_MODE_SGMII ||
  149. interface == PHY_INTERFACE_MODE_QSGMII) {
  150. switch (port) {
  151. case FM1_DTSEC1:
  152. if (qsgmiiphy_fix[port])
  153. fdt_set_phy_handle(blob, prop, pa,
  154. "sgmii_phy21");
  155. break;
  156. case FM1_DTSEC2:
  157. if (qsgmiiphy_fix[port])
  158. fdt_set_phy_handle(blob, prop, pa,
  159. "sgmii_phy22");
  160. break;
  161. case FM1_DTSEC3:
  162. if (qsgmiiphy_fix[port])
  163. fdt_set_phy_handle(blob, prop, pa,
  164. "sgmii_phy23");
  165. break;
  166. case FM1_DTSEC4:
  167. if (qsgmiiphy_fix[port])
  168. fdt_set_phy_handle(blob, prop, pa,
  169. "sgmii_phy24");
  170. break;
  171. case FM1_DTSEC6:
  172. if (qsgmiiphy_fix[port])
  173. fdt_set_phy_handle(blob, prop, pa,
  174. "sgmii_phy12");
  175. break;
  176. case FM1_DTSEC9:
  177. if (qsgmiiphy_fix[port])
  178. fdt_set_phy_handle(blob, prop, pa,
  179. "sgmii_phy14");
  180. else
  181. fdt_set_phy_handle(blob, prop, pa,
  182. "phy_sgmii4");
  183. break;
  184. case FM1_DTSEC10:
  185. if (qsgmiiphy_fix[port])
  186. fdt_set_phy_handle(blob, prop, pa,
  187. "sgmii_phy13");
  188. else
  189. fdt_set_phy_handle(blob, prop, pa,
  190. "phy_sgmii3");
  191. break;
  192. case FM2_DTSEC1:
  193. if (qsgmiiphy_fix[port])
  194. fdt_set_phy_handle(blob, prop, pa,
  195. "sgmii_phy41");
  196. break;
  197. case FM2_DTSEC2:
  198. if (qsgmiiphy_fix[port])
  199. fdt_set_phy_handle(blob, prop, pa,
  200. "sgmii_phy42");
  201. break;
  202. case FM2_DTSEC3:
  203. if (qsgmiiphy_fix[port])
  204. fdt_set_phy_handle(blob, prop, pa,
  205. "sgmii_phy43");
  206. break;
  207. case FM2_DTSEC4:
  208. if (qsgmiiphy_fix[port])
  209. fdt_set_phy_handle(blob, prop, pa,
  210. "sgmii_phy44");
  211. break;
  212. case FM2_DTSEC6:
  213. if (qsgmiiphy_fix[port])
  214. fdt_set_phy_handle(blob, prop, pa,
  215. "sgmii_phy32");
  216. break;
  217. case FM2_DTSEC9:
  218. if (qsgmiiphy_fix[port])
  219. fdt_set_phy_handle(blob, prop, pa,
  220. "sgmii_phy34");
  221. else
  222. fdt_set_phy_handle(blob, prop, pa,
  223. "phy_sgmii12");
  224. break;
  225. case FM2_DTSEC10:
  226. if (qsgmiiphy_fix[port])
  227. fdt_set_phy_handle(blob, prop, pa,
  228. "sgmii_phy33");
  229. else
  230. fdt_set_phy_handle(blob, prop, pa,
  231. "phy_sgmii11");
  232. break;
  233. default:
  234. break;
  235. }
  236. } else if (interface == PHY_INTERFACE_MODE_XGMII &&
  237. ((prtcl2 == 55) || (prtcl2 == 57))) {
  238. /*
  239. * if the 10G is XFI, check hwconfig to see what is the
  240. * media type, there are two types, fiber or copper,
  241. * fix the dtb accordingly.
  242. */
  243. int media_type = 0;
  244. struct fixed_link f_link;
  245. char lane_mode[20] = {"10GBASE-KR"};
  246. char buf[32] = "serdes-2,";
  247. int off;
  248. switch (port) {
  249. case FM1_10GEC1:
  250. if (hwconfig_sub("fsl_10gkr_copper", "fm1_10g1")) {
  251. media_type = 1;
  252. fdt_set_phy_handle(blob, prop, pa,
  253. "phy_xfi1");
  254. sprintf(buf, "%s%s%s", buf, "lane-a,",
  255. (char *)lane_mode);
  256. }
  257. break;
  258. case FM1_10GEC2:
  259. if (hwconfig_sub("fsl_10gkr_copper", "fm1_10g2")) {
  260. media_type = 1;
  261. fdt_set_phy_handle(blob, prop, pa,
  262. "phy_xfi2");
  263. sprintf(buf, "%s%s%s", buf, "lane-b,",
  264. (char *)lane_mode);
  265. }
  266. break;
  267. case FM2_10GEC1:
  268. if (hwconfig_sub("fsl_10gkr_copper", "fm2_10g1")) {
  269. media_type = 1;
  270. fdt_set_phy_handle(blob, prop, pa,
  271. "phy_xfi3");
  272. sprintf(buf, "%s%s%s", buf, "lane-d,",
  273. (char *)lane_mode);
  274. }
  275. break;
  276. case FM2_10GEC2:
  277. if (hwconfig_sub("fsl_10gkr_copper", "fm2_10g2")) {
  278. media_type = 1;
  279. fdt_set_phy_handle(blob, prop, pa,
  280. "phy_xfi4");
  281. sprintf(buf, "%s%s%s", buf, "lane-c,",
  282. (char *)lane_mode);
  283. }
  284. break;
  285. default:
  286. return;
  287. }
  288. if (!media_type) {
  289. /* fixed-link is used for XFI fiber cable */
  290. fdt_delprop(blob, offset, "phy-handle");
  291. f_link.phy_id = port;
  292. f_link.duplex = 1;
  293. f_link.link_speed = 10000;
  294. f_link.pause = 0;
  295. f_link.asym_pause = 0;
  296. fdt_setprop(blob, offset, "fixed-link", &f_link,
  297. sizeof(f_link));
  298. } else {
  299. /* set property for copper cable */
  300. off = fdt_node_offset_by_compat_reg(blob,
  301. "fsl,fman-memac-mdio", pa + 0x1000);
  302. fdt_setprop_string(blob, off, "lane-instance", buf);
  303. }
  304. }
  305. }
  306. void fdt_fixup_board_enet(void *fdt)
  307. {
  308. int i;
  309. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  310. u32 prtcl2 = in_be32(&gur->rcwsr[4]) & FSL_CORENET2_RCWSR4_SRDS2_PRTCL;
  311. prtcl2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;
  312. for (i = FM1_DTSEC1; i < NUM_FM_PORTS; i++) {
  313. switch (fm_info_get_enet_if(i)) {
  314. case PHY_INTERFACE_MODE_SGMII:
  315. case PHY_INTERFACE_MODE_QSGMII:
  316. switch (mdio_mux[i]) {
  317. case EMI1_SLOT1:
  318. fdt_status_okay_by_alias(fdt, "emi1_slot1");
  319. break;
  320. case EMI1_SLOT2:
  321. fdt_status_okay_by_alias(fdt, "emi1_slot2");
  322. break;
  323. case EMI1_SLOT3:
  324. fdt_status_okay_by_alias(fdt, "emi1_slot3");
  325. break;
  326. case EMI1_SLOT4:
  327. fdt_status_okay_by_alias(fdt, "emi1_slot4");
  328. break;
  329. default:
  330. break;
  331. }
  332. break;
  333. case PHY_INTERFACE_MODE_XGMII:
  334. /* check if it's XFI interface for 10g */
  335. if ((prtcl2 == 55) || (prtcl2 == 57)) {
  336. if (i == FM1_10GEC1 && hwconfig_sub(
  337. "fsl_10gkr_copper", "fm1_10g1"))
  338. fdt_status_okay_by_alias(
  339. fdt, "xfi_pcs_mdio1");
  340. if (i == FM1_10GEC2 && hwconfig_sub(
  341. "fsl_10gkr_copper", "fm1_10g2"))
  342. fdt_status_okay_by_alias(
  343. fdt, "xfi_pcs_mdio2");
  344. if (i == FM2_10GEC1 && hwconfig_sub(
  345. "fsl_10gkr_copper", "fm2_10g1"))
  346. fdt_status_okay_by_alias(
  347. fdt, "xfi_pcs_mdio3");
  348. if (i == FM2_10GEC2 && hwconfig_sub(
  349. "fsl_10gkr_copper", "fm2_10g2"))
  350. fdt_status_okay_by_alias(
  351. fdt, "xfi_pcs_mdio4");
  352. break;
  353. }
  354. switch (i) {
  355. case FM1_10GEC1:
  356. fdt_status_okay_by_alias(fdt, "emi2_xauislot1");
  357. break;
  358. case FM1_10GEC2:
  359. fdt_status_okay_by_alias(fdt, "emi2_xauislot2");
  360. break;
  361. case FM2_10GEC1:
  362. fdt_status_okay_by_alias(fdt, "emi2_xauislot3");
  363. break;
  364. case FM2_10GEC2:
  365. fdt_status_okay_by_alias(fdt, "emi2_xauislot4");
  366. break;
  367. default:
  368. break;
  369. }
  370. break;
  371. default:
  372. break;
  373. }
  374. }
  375. }
  376. static void initialize_qsgmiiphy_fix(void)
  377. {
  378. int i;
  379. unsigned short reg;
  380. for (i = 1; i <= 4; i++) {
  381. /*
  382. * Try to read if a SGMII card is used, we do it slot by slot.
  383. * if a SGMII PHY address is valid on a slot, then we mark
  384. * all ports on the slot, then fix the PHY address for the
  385. * marked port when doing dtb fixup.
  386. */
  387. if (miiphy_read(mdio_names[i],
  388. SGMII_CARD_PORT1_PHY_ADDR, MII_PHYSID2, &reg) != 0) {
  389. debug("Slot%d PHY ID register 2 read failed\n", i);
  390. continue;
  391. }
  392. debug("Slot%d MII_PHYSID2 @ 0x1c= 0x%04x\n", i, reg);
  393. if (reg == 0xFFFF) {
  394. /* No physical device present at this address */
  395. continue;
  396. }
  397. switch (i) {
  398. case 1:
  399. qsgmiiphy_fix[FM1_DTSEC5] = 1;
  400. qsgmiiphy_fix[FM1_DTSEC6] = 1;
  401. qsgmiiphy_fix[FM1_DTSEC9] = 1;
  402. qsgmiiphy_fix[FM1_DTSEC10] = 1;
  403. slot_qsgmii_phyaddr[1][0] = SGMII_CARD_PORT1_PHY_ADDR;
  404. slot_qsgmii_phyaddr[1][1] = SGMII_CARD_PORT2_PHY_ADDR;
  405. slot_qsgmii_phyaddr[1][2] = SGMII_CARD_PORT3_PHY_ADDR;
  406. slot_qsgmii_phyaddr[1][3] = SGMII_CARD_PORT4_PHY_ADDR;
  407. break;
  408. case 2:
  409. qsgmiiphy_fix[FM1_DTSEC1] = 1;
  410. qsgmiiphy_fix[FM1_DTSEC2] = 1;
  411. qsgmiiphy_fix[FM1_DTSEC3] = 1;
  412. qsgmiiphy_fix[FM1_DTSEC4] = 1;
  413. slot_qsgmii_phyaddr[2][0] = SGMII_CARD_PORT1_PHY_ADDR;
  414. slot_qsgmii_phyaddr[2][1] = SGMII_CARD_PORT2_PHY_ADDR;
  415. slot_qsgmii_phyaddr[2][2] = SGMII_CARD_PORT3_PHY_ADDR;
  416. slot_qsgmii_phyaddr[2][3] = SGMII_CARD_PORT4_PHY_ADDR;
  417. break;
  418. case 3:
  419. qsgmiiphy_fix[FM2_DTSEC5] = 1;
  420. qsgmiiphy_fix[FM2_DTSEC6] = 1;
  421. qsgmiiphy_fix[FM2_DTSEC9] = 1;
  422. qsgmiiphy_fix[FM2_DTSEC10] = 1;
  423. slot_qsgmii_phyaddr[3][0] = SGMII_CARD_PORT1_PHY_ADDR;
  424. slot_qsgmii_phyaddr[3][1] = SGMII_CARD_PORT2_PHY_ADDR;
  425. slot_qsgmii_phyaddr[3][2] = SGMII_CARD_PORT3_PHY_ADDR;
  426. slot_qsgmii_phyaddr[3][3] = SGMII_CARD_PORT4_PHY_ADDR;
  427. break;
  428. case 4:
  429. qsgmiiphy_fix[FM2_DTSEC1] = 1;
  430. qsgmiiphy_fix[FM2_DTSEC2] = 1;
  431. qsgmiiphy_fix[FM2_DTSEC3] = 1;
  432. qsgmiiphy_fix[FM2_DTSEC4] = 1;
  433. slot_qsgmii_phyaddr[4][0] = SGMII_CARD_PORT1_PHY_ADDR;
  434. slot_qsgmii_phyaddr[4][1] = SGMII_CARD_PORT2_PHY_ADDR;
  435. slot_qsgmii_phyaddr[4][2] = SGMII_CARD_PORT3_PHY_ADDR;
  436. slot_qsgmii_phyaddr[4][3] = SGMII_CARD_PORT4_PHY_ADDR;
  437. break;
  438. default:
  439. break;
  440. }
  441. }
  442. }
  443. int board_eth_init(bd_t *bis)
  444. {
  445. #if defined(CONFIG_FMAN_ENET)
  446. int i, idx, lane, slot, interface;
  447. struct memac_mdio_info dtsec_mdio_info;
  448. struct memac_mdio_info tgec_mdio_info;
  449. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  450. u32 srds_prtcl_s1, srds_prtcl_s2;
  451. srds_prtcl_s1 = in_be32(&gur->rcwsr[4]) &
  452. FSL_CORENET2_RCWSR4_SRDS1_PRTCL;
  453. srds_prtcl_s1 >>= FSL_CORENET2_RCWSR4_SRDS1_PRTCL_SHIFT;
  454. srds_prtcl_s2 = in_be32(&gur->rcwsr[4]) &
  455. FSL_CORENET2_RCWSR4_SRDS2_PRTCL;
  456. srds_prtcl_s2 >>= FSL_CORENET2_RCWSR4_SRDS2_PRTCL_SHIFT;
  457. /* Initialize the mdio_mux array so we can recognize empty elements */
  458. for (i = 0; i < NUM_FM_PORTS; i++)
  459. mdio_mux[i] = EMI_NONE;
  460. dtsec_mdio_info.regs =
  461. (struct memac_mdio_controller *)CONFIG_SYS_FM2_DTSEC_MDIO_ADDR;
  462. dtsec_mdio_info.name = DEFAULT_FM_MDIO_NAME;
  463. /* Register the 1G MDIO bus */
  464. fm_memac_mdio_init(bis, &dtsec_mdio_info);
  465. tgec_mdio_info.regs =
  466. (struct memac_mdio_controller *)CONFIG_SYS_FM2_TGEC_MDIO_ADDR;
  467. tgec_mdio_info.name = DEFAULT_FM_TGEC_MDIO_NAME;
  468. /* Register the 10G MDIO bus */
  469. fm_memac_mdio_init(bis, &tgec_mdio_info);
  470. /* Register the muxing front-ends to the MDIO buses */
  471. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_RGMII);
  472. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT1);
  473. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT2);
  474. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT3);
  475. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT4);
  476. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT5);
  477. t4240qds_mdio_init(DEFAULT_FM_MDIO_NAME, EMI1_SLOT7);
  478. t4240qds_mdio_init(DEFAULT_FM_TGEC_MDIO_NAME, EMI2);
  479. initialize_qsgmiiphy_fix();
  480. switch (srds_prtcl_s1) {
  481. case 1:
  482. case 2:
  483. case 4:
  484. /* XAUI/HiGig in Slot1 and Slot2 */
  485. fm_info_set_phy_address(FM1_10GEC1, FM1_10GEC1_PHY_ADDR);
  486. fm_info_set_phy_address(FM1_10GEC2, FM1_10GEC2_PHY_ADDR);
  487. break;
  488. case 27:
  489. case 28:
  490. case 35:
  491. case 36:
  492. /* SGMII in Slot1 and Slot2 */
  493. fm_info_set_phy_address(FM1_DTSEC1, slot_qsgmii_phyaddr[2][0]);
  494. fm_info_set_phy_address(FM1_DTSEC2, slot_qsgmii_phyaddr[2][1]);
  495. fm_info_set_phy_address(FM1_DTSEC3, slot_qsgmii_phyaddr[2][2]);
  496. fm_info_set_phy_address(FM1_DTSEC4, slot_qsgmii_phyaddr[2][3]);
  497. fm_info_set_phy_address(FM1_DTSEC5, slot_qsgmii_phyaddr[1][0]);
  498. fm_info_set_phy_address(FM1_DTSEC6, slot_qsgmii_phyaddr[1][1]);
  499. if ((srds_prtcl_s2 != 55) && (srds_prtcl_s2 != 57)) {
  500. fm_info_set_phy_address(FM1_DTSEC9,
  501. slot_qsgmii_phyaddr[1][3]);
  502. fm_info_set_phy_address(FM1_DTSEC10,
  503. slot_qsgmii_phyaddr[1][2]);
  504. }
  505. break;
  506. case 37:
  507. case 38:
  508. fm_info_set_phy_address(FM1_DTSEC1, slot_qsgmii_phyaddr[2][0]);
  509. fm_info_set_phy_address(FM1_DTSEC2, slot_qsgmii_phyaddr[2][1]);
  510. fm_info_set_phy_address(FM1_DTSEC3, slot_qsgmii_phyaddr[2][2]);
  511. fm_info_set_phy_address(FM1_DTSEC4, slot_qsgmii_phyaddr[2][3]);
  512. fm_info_set_phy_address(FM1_DTSEC5, slot_qsgmii_phyaddr[1][0]);
  513. fm_info_set_phy_address(FM1_DTSEC6, slot_qsgmii_phyaddr[1][1]);
  514. if ((srds_prtcl_s2 != 55) && (srds_prtcl_s2 != 57)) {
  515. fm_info_set_phy_address(FM1_DTSEC9,
  516. slot_qsgmii_phyaddr[1][2]);
  517. fm_info_set_phy_address(FM1_DTSEC10,
  518. slot_qsgmii_phyaddr[1][3]);
  519. }
  520. break;
  521. case 39:
  522. case 40:
  523. case 45:
  524. case 46:
  525. case 47:
  526. case 48:
  527. fm_info_set_phy_address(FM1_DTSEC5, slot_qsgmii_phyaddr[1][0]);
  528. fm_info_set_phy_address(FM1_DTSEC6, slot_qsgmii_phyaddr[1][1]);
  529. if ((srds_prtcl_s2 != 55) && (srds_prtcl_s2 != 57)) {
  530. fm_info_set_phy_address(FM1_DTSEC10,
  531. slot_qsgmii_phyaddr[1][2]);
  532. fm_info_set_phy_address(FM1_DTSEC9,
  533. slot_qsgmii_phyaddr[1][3]);
  534. }
  535. fm_info_set_phy_address(FM1_DTSEC1, slot_qsgmii_phyaddr[2][0]);
  536. fm_info_set_phy_address(FM1_DTSEC2, slot_qsgmii_phyaddr[2][1]);
  537. fm_info_set_phy_address(FM1_DTSEC3, slot_qsgmii_phyaddr[2][2]);
  538. fm_info_set_phy_address(FM1_DTSEC4, slot_qsgmii_phyaddr[2][3]);
  539. break;
  540. default:
  541. puts("Invalid SerDes1 protocol for T4240QDS\n");
  542. break;
  543. }
  544. for (i = FM1_DTSEC1; i < FM1_DTSEC1 + CONFIG_SYS_NUM_FM1_DTSEC; i++) {
  545. idx = i - FM1_DTSEC1;
  546. interface = fm_info_get_enet_if(i);
  547. switch (interface) {
  548. case PHY_INTERFACE_MODE_SGMII:
  549. case PHY_INTERFACE_MODE_QSGMII:
  550. if (interface == PHY_INTERFACE_MODE_QSGMII) {
  551. if (idx <= 3)
  552. lane = serdes_get_first_lane(FSL_SRDS_1,
  553. QSGMII_FM1_A);
  554. else
  555. lane = serdes_get_first_lane(FSL_SRDS_1,
  556. QSGMII_FM1_B);
  557. if (lane < 0)
  558. break;
  559. slot = lane_to_slot_fsm1[lane];
  560. debug("FM1@DTSEC%u expects QSGMII in slot %u\n",
  561. idx + 1, slot);
  562. } else {
  563. lane = serdes_get_first_lane(FSL_SRDS_1,
  564. SGMII_FM1_DTSEC1 + idx);
  565. if (lane < 0)
  566. break;
  567. slot = lane_to_slot_fsm1[lane];
  568. debug("FM1@DTSEC%u expects SGMII in slot %u\n",
  569. idx + 1, slot);
  570. }
  571. if (QIXIS_READ(present2) & (1 << (slot - 1)))
  572. fm_disable_port(i);
  573. switch (slot) {
  574. case 1:
  575. mdio_mux[i] = EMI1_SLOT1;
  576. fm_info_set_mdio(i,
  577. mii_dev_for_muxval(mdio_mux[i]));
  578. break;
  579. case 2:
  580. mdio_mux[i] = EMI1_SLOT2;
  581. fm_info_set_mdio(i,
  582. mii_dev_for_muxval(mdio_mux[i]));
  583. break;
  584. };
  585. break;
  586. case PHY_INTERFACE_MODE_RGMII:
  587. /* FM1 DTSEC5 routes to RGMII with EC2 */
  588. debug("FM1@DTSEC%u is RGMII at address %u\n",
  589. idx + 1, 2);
  590. if (i == FM1_DTSEC5)
  591. fm_info_set_phy_address(i, 2);
  592. mdio_mux[i] = EMI1_RGMII;
  593. fm_info_set_mdio(i,
  594. mii_dev_for_muxval(mdio_mux[i]));
  595. break;
  596. default:
  597. break;
  598. }
  599. }
  600. for (i = FM1_10GEC1; i < FM1_10GEC1 + CONFIG_SYS_NUM_FM1_10GEC; i++) {
  601. idx = i - FM1_10GEC1;
  602. switch (fm_info_get_enet_if(i)) {
  603. case PHY_INTERFACE_MODE_XGMII:
  604. if ((srds_prtcl_s2 == 55) || (srds_prtcl_s2 == 57)) {
  605. /* A fake PHY address to make U-Boot happy */
  606. fm_info_set_phy_address(i, i);
  607. } else {
  608. lane = serdes_get_first_lane(FSL_SRDS_1,
  609. XAUI_FM1_MAC9 + idx);
  610. if (lane < 0)
  611. break;
  612. slot = lane_to_slot_fsm1[lane];
  613. if (QIXIS_READ(present2) & (1 << (slot - 1)))
  614. fm_disable_port(i);
  615. }
  616. mdio_mux[i] = EMI2;
  617. fm_info_set_mdio(i, mii_dev_for_muxval(mdio_mux[i]));
  618. break;
  619. default:
  620. break;
  621. }
  622. }
  623. #if (CONFIG_SYS_NUM_FMAN == 2)
  624. switch (srds_prtcl_s2) {
  625. case 1:
  626. case 2:
  627. case 4:
  628. /* XAUI/HiGig in Slot3 and Slot4 */
  629. fm_info_set_phy_address(FM2_10GEC1, FM2_10GEC1_PHY_ADDR);
  630. fm_info_set_phy_address(FM2_10GEC2, FM2_10GEC2_PHY_ADDR);
  631. break;
  632. case 6:
  633. case 7:
  634. case 12:
  635. case 13:
  636. case 14:
  637. case 15:
  638. case 16:
  639. case 21:
  640. case 22:
  641. case 23:
  642. case 24:
  643. case 25:
  644. case 26:
  645. /* XAUI/HiGig in Slot3, SGMII in Slot4 */
  646. fm_info_set_phy_address(FM2_10GEC1, FM2_10GEC1_PHY_ADDR);
  647. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  648. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  649. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  650. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  651. break;
  652. case 27:
  653. case 28:
  654. case 35:
  655. case 36:
  656. /* SGMII in Slot3 and Slot4 */
  657. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  658. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  659. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  660. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  661. fm_info_set_phy_address(FM2_DTSEC5, slot_qsgmii_phyaddr[3][0]);
  662. fm_info_set_phy_address(FM2_DTSEC6, slot_qsgmii_phyaddr[3][1]);
  663. fm_info_set_phy_address(FM2_DTSEC9, slot_qsgmii_phyaddr[3][3]);
  664. fm_info_set_phy_address(FM2_DTSEC10, slot_qsgmii_phyaddr[3][2]);
  665. break;
  666. case 37:
  667. case 38:
  668. /* QSGMII in Slot3 and Slot4 */
  669. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  670. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  671. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  672. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  673. fm_info_set_phy_address(FM2_DTSEC5, slot_qsgmii_phyaddr[3][0]);
  674. fm_info_set_phy_address(FM2_DTSEC6, slot_qsgmii_phyaddr[3][1]);
  675. fm_info_set_phy_address(FM2_DTSEC9, slot_qsgmii_phyaddr[3][2]);
  676. fm_info_set_phy_address(FM2_DTSEC10, slot_qsgmii_phyaddr[3][3]);
  677. break;
  678. case 39:
  679. case 40:
  680. case 45:
  681. case 46:
  682. case 47:
  683. case 48:
  684. /* SGMII in Slot3 */
  685. fm_info_set_phy_address(FM2_DTSEC5, slot_qsgmii_phyaddr[3][0]);
  686. fm_info_set_phy_address(FM2_DTSEC6, slot_qsgmii_phyaddr[3][1]);
  687. fm_info_set_phy_address(FM2_DTSEC9, slot_qsgmii_phyaddr[3][3]);
  688. fm_info_set_phy_address(FM2_DTSEC10, slot_qsgmii_phyaddr[3][2]);
  689. /* QSGMII in Slot4 */
  690. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  691. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  692. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  693. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  694. break;
  695. case 49:
  696. case 50:
  697. case 51:
  698. case 52:
  699. case 53:
  700. case 54:
  701. fm_info_set_phy_address(FM2_10GEC1, FM2_10GEC1_PHY_ADDR);
  702. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  703. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  704. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  705. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  706. break;
  707. case 55:
  708. case 57:
  709. /* XFI in Slot3, SGMII in Slot4 */
  710. fm_info_set_phy_address(FM2_DTSEC1, slot_qsgmii_phyaddr[4][0]);
  711. fm_info_set_phy_address(FM2_DTSEC2, slot_qsgmii_phyaddr[4][1]);
  712. fm_info_set_phy_address(FM2_DTSEC3, slot_qsgmii_phyaddr[4][2]);
  713. fm_info_set_phy_address(FM2_DTSEC4, slot_qsgmii_phyaddr[4][3]);
  714. break;
  715. default:
  716. puts("Invalid SerDes2 protocol for T4240QDS\n");
  717. break;
  718. }
  719. for (i = FM2_DTSEC1; i < FM2_DTSEC1 + CONFIG_SYS_NUM_FM2_DTSEC; i++) {
  720. idx = i - FM2_DTSEC1;
  721. interface = fm_info_get_enet_if(i);
  722. switch (interface) {
  723. case PHY_INTERFACE_MODE_SGMII:
  724. case PHY_INTERFACE_MODE_QSGMII:
  725. if (interface == PHY_INTERFACE_MODE_QSGMII) {
  726. if (idx <= 3)
  727. lane = serdes_get_first_lane(FSL_SRDS_2,
  728. QSGMII_FM2_A);
  729. else
  730. lane = serdes_get_first_lane(FSL_SRDS_2,
  731. QSGMII_FM2_B);
  732. if (lane < 0)
  733. break;
  734. slot = lane_to_slot_fsm2[lane];
  735. debug("FM2@DTSEC%u expects QSGMII in slot %u\n",
  736. idx + 1, slot);
  737. } else {
  738. lane = serdes_get_first_lane(FSL_SRDS_2,
  739. SGMII_FM2_DTSEC1 + idx);
  740. if (lane < 0)
  741. break;
  742. slot = lane_to_slot_fsm2[lane];
  743. debug("FM2@DTSEC%u expects SGMII in slot %u\n",
  744. idx + 1, slot);
  745. }
  746. if (QIXIS_READ(present2) & (1 << (slot - 1)))
  747. fm_disable_port(i);
  748. switch (slot) {
  749. case 3:
  750. mdio_mux[i] = EMI1_SLOT3;
  751. fm_info_set_mdio(i,
  752. mii_dev_for_muxval(mdio_mux[i]));
  753. break;
  754. case 4:
  755. mdio_mux[i] = EMI1_SLOT4;
  756. fm_info_set_mdio(i,
  757. mii_dev_for_muxval(mdio_mux[i]));
  758. break;
  759. };
  760. break;
  761. case PHY_INTERFACE_MODE_RGMII:
  762. /*
  763. * If DTSEC5 is RGMII, then it's routed via via EC1 to
  764. * the first on-board RGMII port. If DTSEC6 is RGMII,
  765. * then it's routed via via EC2 to the second on-board
  766. * RGMII port.
  767. */
  768. debug("FM2@DTSEC%u is RGMII at address %u\n",
  769. idx + 1, i == FM2_DTSEC5 ? 1 : 2);
  770. fm_info_set_phy_address(i, i == FM2_DTSEC5 ? 1 : 2);
  771. mdio_mux[i] = EMI1_RGMII;
  772. fm_info_set_mdio(i, mii_dev_for_muxval(mdio_mux[i]));
  773. break;
  774. default:
  775. break;
  776. }
  777. }
  778. for (i = FM2_10GEC1; i < FM2_10GEC1 + CONFIG_SYS_NUM_FM2_10GEC; i++) {
  779. idx = i - FM2_10GEC1;
  780. switch (fm_info_get_enet_if(i)) {
  781. case PHY_INTERFACE_MODE_XGMII:
  782. if ((srds_prtcl_s2 == 55) || (srds_prtcl_s2 == 57)) {
  783. /* A fake PHY address to make U-Boot happy */
  784. fm_info_set_phy_address(i, i);
  785. } else {
  786. lane = serdes_get_first_lane(FSL_SRDS_2,
  787. XAUI_FM2_MAC9 + idx);
  788. if (lane < 0)
  789. break;
  790. slot = lane_to_slot_fsm2[lane];
  791. if (QIXIS_READ(present2) & (1 << (slot - 1)))
  792. fm_disable_port(i);
  793. }
  794. mdio_mux[i] = EMI2;
  795. fm_info_set_mdio(i, mii_dev_for_muxval(mdio_mux[i]));
  796. break;
  797. default:
  798. break;
  799. }
  800. }
  801. #endif /* CONFIG_SYS_NUM_FMAN */
  802. cpu_eth_init(bis);
  803. #endif /* CONFIG_FMAN_ENET */
  804. return pci_eth_init(bis);
  805. }