eth_ls1088aqds.c 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2017 NXP
  4. */
  5. #include <common.h>
  6. #include <command.h>
  7. #include <netdev.h>
  8. #include <asm/io.h>
  9. #include <asm/arch/fsl_serdes.h>
  10. #include <hwconfig.h>
  11. #include <fsl_mdio.h>
  12. #include <malloc.h>
  13. #include <phy.h>
  14. #include <fm_eth.h>
  15. #include <i2c.h>
  16. #include <miiphy.h>
  17. #include <fsl-mc/fsl_mc.h>
  18. #include <fsl-mc/ldpaa_wriop.h>
  19. #include "../common/qixis.h"
  20. #include "ls1088a_qixis.h"
  21. #ifdef CONFIG_FSL_MC_ENET
  22. #define SFP_TX 0
  23. /* - In LS1088A A there are only 16 SERDES lanes, spread across 2 SERDES banks.
  24. * Bank 1 -> Lanes A, B, C, D,
  25. * Bank 2 -> Lanes A,B, C, D,
  26. */
  27. /* Mapping of 8 SERDES lanes to LS1088A QDS board slots. A value of '0' here
  28. * means that the mapping must be determined dynamically, or that the lane
  29. * maps to something other than a board slot.
  30. */
  31. static u8 lane_to_slot_fsm1[] = {
  32. 0, 0, 0, 0, 0, 0, 0, 0
  33. };
  34. /* On the Vitesse VSC8234XHG SGMII riser card there are 4 SGMII PHYs
  35. * housed.
  36. */
  37. static int xqsgii_riser_phy_addr[] = {
  38. XQSGMII_CARD_PHY1_PORT0_ADDR,
  39. XQSGMII_CARD_PHY2_PORT0_ADDR,
  40. XQSGMII_CARD_PHY3_PORT0_ADDR,
  41. XQSGMII_CARD_PHY4_PORT0_ADDR,
  42. XQSGMII_CARD_PHY3_PORT2_ADDR,
  43. XQSGMII_CARD_PHY1_PORT2_ADDR,
  44. XQSGMII_CARD_PHY4_PORT2_ADDR,
  45. XQSGMII_CARD_PHY2_PORT2_ADDR,
  46. };
  47. static int sgmii_riser_phy_addr[] = {
  48. SGMII_CARD_PORT1_PHY_ADDR,
  49. SGMII_CARD_PORT2_PHY_ADDR,
  50. SGMII_CARD_PORT3_PHY_ADDR,
  51. SGMII_CARD_PORT4_PHY_ADDR,
  52. };
  53. /* Slot2 does not have EMI connections */
  54. #define EMI_NONE 0xFF
  55. #define EMI1_RGMII1 0
  56. #define EMI1_RGMII2 1
  57. #define EMI1_SLOT1 2
  58. static const char * const mdio_names[] = {
  59. "LS1088A_QDS_MDIO0",
  60. "LS1088A_QDS_MDIO1",
  61. "LS1088A_QDS_MDIO2",
  62. DEFAULT_WRIOP_MDIO2_NAME,
  63. };
  64. struct ls1088a_qds_mdio {
  65. u8 muxval;
  66. struct mii_dev *realbus;
  67. };
  68. static void sgmii_configure_repeater(int dpmac)
  69. {
  70. struct mii_dev *bus;
  71. uint8_t a = 0xf;
  72. int i, j, ret;
  73. unsigned short value;
  74. const char *dev = "LS1088A_QDS_MDIO2";
  75. int i2c_addr[] = {0x58, 0x59, 0x5a, 0x5b};
  76. int i2c_phy_addr = 0;
  77. int phy_addr = 0;
  78. uint8_t ch_a_eq[] = {0x1, 0x2, 0x3, 0x7};
  79. uint8_t ch_a_ctl2[] = {0x81, 0x82, 0x83, 0x84};
  80. uint8_t ch_b_eq[] = {0x1, 0x2, 0x3, 0x7};
  81. uint8_t ch_b_ctl2[] = {0x81, 0x82, 0x83, 0x84};
  82. /* Set I2c to Slot 1 */
  83. i2c_write(0x77, 0, 0, &a, 1);
  84. switch (dpmac) {
  85. case 1:
  86. i2c_phy_addr = i2c_addr[1];
  87. phy_addr = 4;
  88. break;
  89. case 2:
  90. i2c_phy_addr = i2c_addr[0];
  91. phy_addr = 0;
  92. break;
  93. case 3:
  94. i2c_phy_addr = i2c_addr[3];
  95. phy_addr = 0xc;
  96. break;
  97. case 7:
  98. i2c_phy_addr = i2c_addr[2];
  99. phy_addr = 8;
  100. break;
  101. }
  102. /* Check the PHY status */
  103. ret = miiphy_set_current_dev(dev);
  104. if (ret > 0)
  105. goto error;
  106. bus = mdio_get_current_dev();
  107. debug("Reading from bus %s\n", bus->name);
  108. ret = miiphy_write(dev, phy_addr, 0x1f, 3);
  109. if (ret > 0)
  110. goto error;
  111. mdelay(10);
  112. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  113. if (ret > 0)
  114. goto error;
  115. mdelay(10);
  116. if ((value & 0xfff) == 0x401) {
  117. miiphy_write(dev, phy_addr, 0x1f, 0);
  118. printf("DPMAC %d:PHY is ..... Configured\n", dpmac);
  119. return;
  120. }
  121. for (i = 0; i < 4; i++) {
  122. for (j = 0; j < 4; j++) {
  123. a = 0x18;
  124. i2c_write(i2c_phy_addr, 6, 1, &a, 1);
  125. a = 0x38;
  126. i2c_write(i2c_phy_addr, 4, 1, &a, 1);
  127. a = 0x4;
  128. i2c_write(i2c_phy_addr, 8, 1, &a, 1);
  129. i2c_write(i2c_phy_addr, 0xf, 1,
  130. &ch_a_eq[i], 1);
  131. i2c_write(i2c_phy_addr, 0x11, 1,
  132. &ch_a_ctl2[j], 1);
  133. i2c_write(i2c_phy_addr, 0x16, 1,
  134. &ch_b_eq[i], 1);
  135. i2c_write(i2c_phy_addr, 0x18, 1,
  136. &ch_b_ctl2[j], 1);
  137. a = 0x14;
  138. i2c_write(i2c_phy_addr, 0x23, 1, &a, 1);
  139. a = 0xb5;
  140. i2c_write(i2c_phy_addr, 0x2d, 1, &a, 1);
  141. a = 0x20;
  142. i2c_write(i2c_phy_addr, 4, 1, &a, 1);
  143. mdelay(100);
  144. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  145. if (ret > 0)
  146. goto error;
  147. mdelay(100);
  148. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  149. if (ret > 0)
  150. goto error;
  151. if ((value & 0xfff) == 0x401) {
  152. printf("DPMAC %d :PHY is configured ",
  153. dpmac);
  154. printf("after setting repeater 0x%x\n",
  155. value);
  156. i = 5;
  157. j = 5;
  158. } else {
  159. printf("DPMAC %d :PHY is failed to ",
  160. dpmac);
  161. printf("configure the repeater 0x%x\n", value);
  162. }
  163. }
  164. }
  165. miiphy_write(dev, phy_addr, 0x1f, 0);
  166. error:
  167. if (ret)
  168. printf("DPMAC %d ..... FAILED to configure PHY\n", dpmac);
  169. return;
  170. }
  171. static void qsgmii_configure_repeater(int dpmac)
  172. {
  173. uint8_t a = 0xf;
  174. int i, j;
  175. int i2c_phy_addr = 0;
  176. int phy_addr = 0;
  177. int i2c_addr[] = {0x58, 0x59, 0x5a, 0x5b};
  178. uint8_t ch_a_eq[] = {0x1, 0x2, 0x3, 0x7};
  179. uint8_t ch_a_ctl2[] = {0x81, 0x82, 0x83, 0x84};
  180. uint8_t ch_b_eq[] = {0x1, 0x2, 0x3, 0x7};
  181. uint8_t ch_b_ctl2[] = {0x81, 0x82, 0x83, 0x84};
  182. const char *dev = mdio_names[EMI1_SLOT1];
  183. int ret = 0;
  184. unsigned short value;
  185. /* Set I2c to Slot 1 */
  186. i2c_write(0x77, 0, 0, &a, 1);
  187. switch (dpmac) {
  188. case 7:
  189. case 8:
  190. case 9:
  191. case 10:
  192. i2c_phy_addr = i2c_addr[2];
  193. phy_addr = 8;
  194. break;
  195. case 3:
  196. case 4:
  197. case 5:
  198. case 6:
  199. i2c_phy_addr = i2c_addr[3];
  200. phy_addr = 0xc;
  201. break;
  202. }
  203. /* Check the PHY status */
  204. ret = miiphy_set_current_dev(dev);
  205. ret = miiphy_write(dev, phy_addr, 0x1f, 3);
  206. mdelay(10);
  207. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  208. mdelay(10);
  209. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  210. mdelay(10);
  211. if ((value & 0xf) == 0xf) {
  212. miiphy_write(dev, phy_addr, 0x1f, 0);
  213. printf("DPMAC %d :PHY is ..... Configured\n", dpmac);
  214. return;
  215. }
  216. for (i = 0; i < 4; i++) {
  217. for (j = 0; j < 4; j++) {
  218. a = 0x18;
  219. i2c_write(i2c_phy_addr, 6, 1, &a, 1);
  220. a = 0x38;
  221. i2c_write(i2c_phy_addr, 4, 1, &a, 1);
  222. a = 0x4;
  223. i2c_write(i2c_phy_addr, 8, 1, &a, 1);
  224. i2c_write(i2c_phy_addr, 0xf, 1, &ch_a_eq[i], 1);
  225. i2c_write(i2c_phy_addr, 0x11, 1, &ch_a_ctl2[j], 1);
  226. i2c_write(i2c_phy_addr, 0x16, 1, &ch_b_eq[i], 1);
  227. i2c_write(i2c_phy_addr, 0x18, 1, &ch_b_ctl2[j], 1);
  228. a = 0x14;
  229. i2c_write(i2c_phy_addr, 0x23, 1, &a, 1);
  230. a = 0xb5;
  231. i2c_write(i2c_phy_addr, 0x2d, 1, &a, 1);
  232. a = 0x20;
  233. i2c_write(i2c_phy_addr, 4, 1, &a, 1);
  234. mdelay(100);
  235. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  236. if (ret > 0)
  237. goto error;
  238. mdelay(1);
  239. ret = miiphy_read(dev, phy_addr, 0x11, &value);
  240. if (ret > 0)
  241. goto error;
  242. mdelay(10);
  243. if ((value & 0xf) == 0xf) {
  244. miiphy_write(dev, phy_addr, 0x1f, 0);
  245. printf("DPMAC %d :PHY is ..... Configured\n",
  246. dpmac);
  247. return;
  248. }
  249. }
  250. }
  251. error:
  252. printf("DPMAC %d :PHY ..... FAILED to configure PHY\n", dpmac);
  253. return;
  254. }
  255. static const char *ls1088a_qds_mdio_name_for_muxval(u8 muxval)
  256. {
  257. return mdio_names[muxval];
  258. }
  259. struct mii_dev *mii_dev_for_muxval(u8 muxval)
  260. {
  261. struct mii_dev *bus;
  262. const char *name = ls1088a_qds_mdio_name_for_muxval(muxval);
  263. if (!name) {
  264. printf("No bus for muxval %x\n", muxval);
  265. return NULL;
  266. }
  267. bus = miiphy_get_dev_by_name(name);
  268. if (!bus) {
  269. printf("No bus by name %s\n", name);
  270. return NULL;
  271. }
  272. return bus;
  273. }
  274. static void ls1088a_qds_enable_SFP_TX(u8 muxval)
  275. {
  276. u8 brdcfg9;
  277. brdcfg9 = QIXIS_READ(brdcfg[9]);
  278. brdcfg9 &= ~BRDCFG9_SFPTX_MASK;
  279. brdcfg9 |= (muxval << BRDCFG9_SFPTX_SHIFT);
  280. QIXIS_WRITE(brdcfg[9], brdcfg9);
  281. }
  282. static void ls1088a_qds_mux_mdio(u8 muxval)
  283. {
  284. u8 brdcfg4;
  285. if (muxval <= 5) {
  286. brdcfg4 = QIXIS_READ(brdcfg[4]);
  287. brdcfg4 &= ~BRDCFG4_EMISEL_MASK;
  288. brdcfg4 |= (muxval << BRDCFG4_EMISEL_SHIFT);
  289. QIXIS_WRITE(brdcfg[4], brdcfg4);
  290. }
  291. }
  292. static int ls1088a_qds_mdio_read(struct mii_dev *bus, int addr,
  293. int devad, int regnum)
  294. {
  295. struct ls1088a_qds_mdio *priv = bus->priv;
  296. ls1088a_qds_mux_mdio(priv->muxval);
  297. return priv->realbus->read(priv->realbus, addr, devad, regnum);
  298. }
  299. static int ls1088a_qds_mdio_write(struct mii_dev *bus, int addr, int devad,
  300. int regnum, u16 value)
  301. {
  302. struct ls1088a_qds_mdio *priv = bus->priv;
  303. ls1088a_qds_mux_mdio(priv->muxval);
  304. return priv->realbus->write(priv->realbus, addr, devad, regnum, value);
  305. }
  306. static int ls1088a_qds_mdio_reset(struct mii_dev *bus)
  307. {
  308. struct ls1088a_qds_mdio *priv = bus->priv;
  309. return priv->realbus->reset(priv->realbus);
  310. }
  311. static int ls1088a_qds_mdio_init(char *realbusname, u8 muxval)
  312. {
  313. struct ls1088a_qds_mdio *pmdio;
  314. struct mii_dev *bus = mdio_alloc();
  315. if (!bus) {
  316. printf("Failed to allocate ls1088a_qds MDIO bus\n");
  317. return -1;
  318. }
  319. pmdio = malloc(sizeof(*pmdio));
  320. if (!pmdio) {
  321. printf("Failed to allocate ls1088a_qds private data\n");
  322. free(bus);
  323. return -1;
  324. }
  325. bus->read = ls1088a_qds_mdio_read;
  326. bus->write = ls1088a_qds_mdio_write;
  327. bus->reset = ls1088a_qds_mdio_reset;
  328. sprintf(bus->name, ls1088a_qds_mdio_name_for_muxval(muxval));
  329. pmdio->realbus = miiphy_get_dev_by_name(realbusname);
  330. if (!pmdio->realbus) {
  331. printf("No bus with name %s\n", realbusname);
  332. free(bus);
  333. free(pmdio);
  334. return -1;
  335. }
  336. pmdio->muxval = muxval;
  337. bus->priv = pmdio;
  338. return mdio_register(bus);
  339. }
  340. /*
  341. * Initialize the dpmac_info array.
  342. *
  343. */
  344. static void initialize_dpmac_to_slot(void)
  345. {
  346. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  347. u32 serdes1_prtcl, cfg;
  348. cfg = in_le32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]) &
  349. FSL_CHASSIS3_SRDS1_PRTCL_MASK;
  350. cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
  351. serdes1_prtcl = serdes_get_number(FSL_SRDS_1, cfg);
  352. switch (serdes1_prtcl) {
  353. case 0x12:
  354. printf("qds: WRIOP: Supported SerDes1 Protocol 0x%02x\n",
  355. serdes1_prtcl);
  356. lane_to_slot_fsm1[0] = EMI1_SLOT1 - 1;
  357. lane_to_slot_fsm1[1] = EMI1_SLOT1 - 1;
  358. lane_to_slot_fsm1[2] = EMI1_SLOT1 - 1;
  359. lane_to_slot_fsm1[3] = EMI1_SLOT1 - 1;
  360. break;
  361. case 0x15:
  362. case 0x1D:
  363. printf("qds: WRIOP: Supported SerDes1 Protocol 0x%02x\n",
  364. serdes1_prtcl);
  365. lane_to_slot_fsm1[0] = EMI1_SLOT1 - 1;
  366. lane_to_slot_fsm1[1] = EMI1_SLOT1 - 1;
  367. lane_to_slot_fsm1[2] = EMI_NONE;
  368. lane_to_slot_fsm1[3] = EMI_NONE;
  369. break;
  370. case 0x1E:
  371. printf("qds: WRIOP: Supported SerDes1 Protocol 0x%02x\n",
  372. serdes1_prtcl);
  373. lane_to_slot_fsm1[0] = EMI1_SLOT1 - 1;
  374. lane_to_slot_fsm1[1] = EMI1_SLOT1 - 1;
  375. lane_to_slot_fsm1[2] = EMI1_SLOT1 - 1;
  376. lane_to_slot_fsm1[3] = EMI_NONE;
  377. break;
  378. case 0x3A:
  379. printf("qds: WRIOP: Supported SerDes1 Protocol 0x%02x\n",
  380. serdes1_prtcl);
  381. lane_to_slot_fsm1[0] = EMI1_SLOT1 - 1;
  382. lane_to_slot_fsm1[1] = EMI_NONE;
  383. lane_to_slot_fsm1[2] = EMI1_SLOT1 - 1;
  384. lane_to_slot_fsm1[3] = EMI1_SLOT1 - 1;
  385. break;
  386. default:
  387. printf("%s qds: WRIOP: Unsupported SerDes1 Protocol 0x%02x\n",
  388. __func__, serdes1_prtcl);
  389. break;
  390. }
  391. }
  392. void ls1088a_handle_phy_interface_sgmii(int dpmac_id)
  393. {
  394. struct mii_dev *bus;
  395. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  396. u32 serdes1_prtcl, cfg;
  397. cfg = in_le32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]) &
  398. FSL_CHASSIS3_SRDS1_PRTCL_MASK;
  399. cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
  400. serdes1_prtcl = serdes_get_number(FSL_SRDS_1, cfg);
  401. int *riser_phy_addr;
  402. char *env_hwconfig = env_get("hwconfig");
  403. if (hwconfig_f("xqsgmii", env_hwconfig))
  404. riser_phy_addr = &xqsgii_riser_phy_addr[0];
  405. else
  406. riser_phy_addr = &sgmii_riser_phy_addr[0];
  407. switch (serdes1_prtcl) {
  408. case 0x12:
  409. case 0x15:
  410. case 0x1E:
  411. case 0x3A:
  412. switch (dpmac_id) {
  413. case 1:
  414. wriop_set_phy_address(dpmac_id, riser_phy_addr[1]);
  415. break;
  416. case 2:
  417. wriop_set_phy_address(dpmac_id, riser_phy_addr[0]);
  418. break;
  419. case 3:
  420. wriop_set_phy_address(dpmac_id, riser_phy_addr[3]);
  421. break;
  422. case 7:
  423. wriop_set_phy_address(dpmac_id, riser_phy_addr[2]);
  424. break;
  425. default:
  426. printf("WRIOP: Wrong DPMAC%d set to SGMII", dpmac_id);
  427. break;
  428. }
  429. break;
  430. default:
  431. printf("%s qds: WRIOP: Unsupported SerDes1 Protocol 0x%02x\n",
  432. __func__, serdes1_prtcl);
  433. return;
  434. }
  435. dpmac_info[dpmac_id].board_mux = EMI1_SLOT1;
  436. bus = mii_dev_for_muxval(EMI1_SLOT1);
  437. wriop_set_mdio(dpmac_id, bus);
  438. }
  439. void ls1088a_handle_phy_interface_qsgmii(int dpmac_id)
  440. {
  441. struct mii_dev *bus;
  442. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  443. u32 serdes1_prtcl, cfg;
  444. cfg = in_le32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]) &
  445. FSL_CHASSIS3_SRDS1_PRTCL_MASK;
  446. cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
  447. serdes1_prtcl = serdes_get_number(FSL_SRDS_1, cfg);
  448. switch (serdes1_prtcl) {
  449. case 0x1D:
  450. case 0x1E:
  451. switch (dpmac_id) {
  452. case 3:
  453. case 4:
  454. case 5:
  455. case 6:
  456. wriop_set_phy_address(dpmac_id, dpmac_id + 9);
  457. break;
  458. case 7:
  459. case 8:
  460. case 9:
  461. case 10:
  462. wriop_set_phy_address(dpmac_id, dpmac_id + 1);
  463. break;
  464. }
  465. dpmac_info[dpmac_id].board_mux = EMI1_SLOT1;
  466. bus = mii_dev_for_muxval(EMI1_SLOT1);
  467. wriop_set_mdio(dpmac_id, bus);
  468. break;
  469. default:
  470. printf("qds: WRIOP: Unsupported SerDes Protocol 0x%02x\n",
  471. serdes1_prtcl);
  472. break;
  473. }
  474. }
  475. void ls1088a_handle_phy_interface_xsgmii(int i)
  476. {
  477. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  478. u32 serdes1_prtcl, cfg;
  479. cfg = in_le32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]) &
  480. FSL_CHASSIS3_SRDS1_PRTCL_MASK;
  481. cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
  482. serdes1_prtcl = serdes_get_number(FSL_SRDS_1, cfg);
  483. switch (serdes1_prtcl) {
  484. case 0x15:
  485. case 0x1D:
  486. case 0x1E:
  487. wriop_set_phy_address(i, i + 26);
  488. ls1088a_qds_enable_SFP_TX(SFP_TX);
  489. break;
  490. default:
  491. printf("qds: WRIOP: Unsupported SerDes Protocol 0x%02x\n",
  492. serdes1_prtcl);
  493. break;
  494. }
  495. }
  496. static void ls1088a_handle_phy_interface_rgmii(int dpmac_id)
  497. {
  498. struct ccsr_gur __iomem *gur = (void *)CONFIG_SYS_FSL_GUTS_ADDR;
  499. u32 serdes1_prtcl, cfg;
  500. struct mii_dev *bus;
  501. cfg = in_le32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]) &
  502. FSL_CHASSIS3_SRDS1_PRTCL_MASK;
  503. cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
  504. serdes1_prtcl = serdes_get_number(FSL_SRDS_1, cfg);
  505. switch (dpmac_id) {
  506. case 4:
  507. wriop_set_phy_address(dpmac_id, RGMII_PHY1_ADDR);
  508. dpmac_info[dpmac_id].board_mux = EMI1_RGMII1;
  509. bus = mii_dev_for_muxval(EMI1_RGMII1);
  510. wriop_set_mdio(dpmac_id, bus);
  511. break;
  512. case 5:
  513. wriop_set_phy_address(dpmac_id, RGMII_PHY2_ADDR);
  514. dpmac_info[dpmac_id].board_mux = EMI1_RGMII2;
  515. bus = mii_dev_for_muxval(EMI1_RGMII2);
  516. wriop_set_mdio(dpmac_id, bus);
  517. break;
  518. default:
  519. printf("qds: WRIOP: Unsupported RGMII SerDes Protocol 0x%02x\n",
  520. serdes1_prtcl);
  521. break;
  522. }
  523. }
  524. #endif
  525. int board_eth_init(bd_t *bis)
  526. {
  527. int error = 0, i;
  528. #ifdef CONFIG_FSL_MC_ENET
  529. struct memac_mdio_info *memac_mdio0_info;
  530. char *env_hwconfig = env_get("hwconfig");
  531. initialize_dpmac_to_slot();
  532. memac_mdio0_info = (struct memac_mdio_info *)malloc(
  533. sizeof(struct memac_mdio_info));
  534. memac_mdio0_info->regs =
  535. (struct memac_mdio_controller *)
  536. CONFIG_SYS_FSL_WRIOP1_MDIO1;
  537. memac_mdio0_info->name = DEFAULT_WRIOP_MDIO1_NAME;
  538. /* Register the real MDIO1 bus */
  539. fm_memac_mdio_init(bis, memac_mdio0_info);
  540. /* Register the muxing front-ends to the MDIO buses */
  541. ls1088a_qds_mdio_init(DEFAULT_WRIOP_MDIO1_NAME, EMI1_RGMII1);
  542. ls1088a_qds_mdio_init(DEFAULT_WRIOP_MDIO1_NAME, EMI1_RGMII2);
  543. ls1088a_qds_mdio_init(DEFAULT_WRIOP_MDIO1_NAME, EMI1_SLOT1);
  544. for (i = WRIOP1_DPMAC1; i < NUM_WRIOP_PORTS; i++) {
  545. switch (wriop_get_enet_if(i)) {
  546. case PHY_INTERFACE_MODE_RGMII:
  547. case PHY_INTERFACE_MODE_RGMII_ID:
  548. ls1088a_handle_phy_interface_rgmii(i);
  549. break;
  550. case PHY_INTERFACE_MODE_QSGMII:
  551. ls1088a_handle_phy_interface_qsgmii(i);
  552. break;
  553. case PHY_INTERFACE_MODE_SGMII:
  554. ls1088a_handle_phy_interface_sgmii(i);
  555. break;
  556. case PHY_INTERFACE_MODE_XGMII:
  557. ls1088a_handle_phy_interface_xsgmii(i);
  558. break;
  559. default:
  560. break;
  561. if (i == 16)
  562. i = NUM_WRIOP_PORTS;
  563. }
  564. }
  565. error = cpu_eth_init(bis);
  566. if (hwconfig_f("xqsgmii", env_hwconfig)) {
  567. for (i = WRIOP1_DPMAC1; i < NUM_WRIOP_PORTS; i++) {
  568. switch (wriop_get_enet_if(i)) {
  569. case PHY_INTERFACE_MODE_QSGMII:
  570. qsgmii_configure_repeater(i);
  571. break;
  572. case PHY_INTERFACE_MODE_SGMII:
  573. sgmii_configure_repeater(i);
  574. break;
  575. default:
  576. break;
  577. }
  578. if (i == 16)
  579. i = NUM_WRIOP_PORTS;
  580. }
  581. }
  582. #endif
  583. error = pci_eth_init(bis);
  584. return error;
  585. }
  586. #if defined(CONFIG_RESET_PHY_R)
  587. void reset_phy(void)
  588. {
  589. mc_env_boot();
  590. }
  591. #endif /* CONFIG_RESET_PHY_R */