eth.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2015-2016 Freescale Semiconductor, Inc.
  4. * Copyright 2017 NXP
  5. */
  6. #include <common.h>
  7. #include <dm.h>
  8. #include <asm/io.h>
  9. #include <netdev.h>
  10. #include <fm_eth.h>
  11. #include <fsl_mdio.h>
  12. #include <malloc.h>
  13. #include <asm/types.h>
  14. #include <fsl_dtsec.h>
  15. #include <asm/arch/soc.h>
  16. #include <asm/arch-fsl-layerscape/config.h>
  17. #include <asm/arch-fsl-layerscape/immap_lsch2.h>
  18. #include <asm/arch/fsl_serdes.h>
  19. #include <net/pfe_eth/pfe_eth.h>
  20. #include <dm/platform_data/pfe_dm_eth.h>
  21. #define DEFAULT_PFE_MDIO_NAME "PFE_MDIO"
  22. #define DEFAULT_PFE_MDIO1_NAME "PFE_MDIO1"
  23. #define MASK_ETH_PHY_RST 0x00000100
  24. static inline void ls1012afrdm_reset_phy(void)
  25. {
  26. unsigned int val;
  27. struct ccsr_gpio *pgpio = (void *)(GPIO1_BASE_ADDR);
  28. setbits_be32(&pgpio->gpdir, MASK_ETH_PHY_RST);
  29. val = in_be32(&pgpio->gpdat);
  30. setbits_be32(&pgpio->gpdat, val & ~MASK_ETH_PHY_RST);
  31. mdelay(10);
  32. val = in_be32(&pgpio->gpdat);
  33. setbits_be32(&pgpio->gpdat, val | MASK_ETH_PHY_RST);
  34. mdelay(50);
  35. }
  36. int pfe_eth_board_init(struct udevice *dev)
  37. {
  38. static int init_done;
  39. struct mii_dev *bus;
  40. struct pfe_mdio_info mac_mdio_info;
  41. struct pfe_eth_dev *priv = dev_get_priv(dev);
  42. if (!init_done) {
  43. ls1012afrdm_reset_phy();
  44. mac_mdio_info.reg_base = (void *)EMAC1_BASE_ADDR;
  45. mac_mdio_info.name = DEFAULT_PFE_MDIO_NAME;
  46. bus = pfe_mdio_init(&mac_mdio_info);
  47. if (!bus) {
  48. printf("Failed to register mdio\n");
  49. return -1;
  50. }
  51. init_done = 1;
  52. }
  53. if (priv->gemac_port) {
  54. mac_mdio_info.reg_base = (void *)EMAC2_BASE_ADDR;
  55. mac_mdio_info.name = DEFAULT_PFE_MDIO1_NAME;
  56. bus = pfe_mdio_init(&mac_mdio_info);
  57. if (!bus) {
  58. printf("Failed to register mdio\n");
  59. return -1;
  60. }
  61. }
  62. pfe_set_mdio(priv->gemac_port,
  63. miiphy_get_dev_by_name(DEFAULT_PFE_MDIO_NAME));
  64. if (!priv->gemac_port)
  65. /* MAC1 */
  66. pfe_set_phy_address_mode(priv->gemac_port,
  67. CONFIG_PFE_EMAC1_PHY_ADDR,
  68. PHY_INTERFACE_MODE_SGMII);
  69. else
  70. /* MAC2 */
  71. pfe_set_phy_address_mode(priv->gemac_port,
  72. CONFIG_PFE_EMAC2_PHY_ADDR,
  73. PHY_INTERFACE_MODE_SGMII);
  74. return 0;
  75. }
  76. static struct pfe_eth_pdata pfe_pdata0 = {
  77. .pfe_eth_pdata_mac = {
  78. .iobase = (phys_addr_t)EMAC1_BASE_ADDR,
  79. .phy_interface = 0,
  80. },
  81. .pfe_ddr_addr = {
  82. .ddr_pfe_baseaddr = (void *)CONFIG_DDR_PFE_BASEADDR,
  83. .ddr_pfe_phys_baseaddr = CONFIG_DDR_PFE_PHYS_BASEADDR,
  84. },
  85. };
  86. static struct pfe_eth_pdata pfe_pdata1 = {
  87. .pfe_eth_pdata_mac = {
  88. .iobase = (phys_addr_t)EMAC2_BASE_ADDR,
  89. .phy_interface = 1,
  90. },
  91. .pfe_ddr_addr = {
  92. .ddr_pfe_baseaddr = (void *)CONFIG_DDR_PFE_BASEADDR,
  93. .ddr_pfe_phys_baseaddr = CONFIG_DDR_PFE_PHYS_BASEADDR,
  94. },
  95. };
  96. U_BOOT_DEVICE(ls1012a_pfe0) = {
  97. .name = "pfe_eth",
  98. .platdata = &pfe_pdata0,
  99. };
  100. U_BOOT_DEVICE(ls1012a_pfe1) = {
  101. .name = "pfe_eth",
  102. .platdata = &pfe_pdata1,
  103. };