p4080.c 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. /*
  2. * Copyright 2011 Freescale Semiconductor, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <phy.h>
  8. #include <fm_eth.h>
  9. #include <asm/io.h>
  10. #include <asm/immap_85xx.h>
  11. #include <asm/fsl_serdes.h>
  12. static u32 port_to_devdisr[] = {
  13. [FM1_DTSEC1] = FSL_CORENET_DEVDISR2_DTSEC1_1,
  14. [FM1_DTSEC2] = FSL_CORENET_DEVDISR2_DTSEC1_2,
  15. [FM1_DTSEC3] = FSL_CORENET_DEVDISR2_DTSEC1_3,
  16. [FM1_DTSEC4] = FSL_CORENET_DEVDISR2_DTSEC1_4,
  17. [FM1_10GEC1] = FSL_CORENET_DEVDISR2_10GEC1,
  18. [FM2_DTSEC1] = FSL_CORENET_DEVDISR2_DTSEC2_1,
  19. [FM2_DTSEC2] = FSL_CORENET_DEVDISR2_DTSEC2_2,
  20. [FM2_DTSEC3] = FSL_CORENET_DEVDISR2_DTSEC2_3,
  21. [FM2_DTSEC4] = FSL_CORENET_DEVDISR2_DTSEC2_4,
  22. [FM2_10GEC1] = FSL_CORENET_DEVDISR2_10GEC2,
  23. };
  24. static int is_device_disabled(enum fm_port port)
  25. {
  26. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  27. u32 devdisr2 = in_be32(&gur->devdisr2);
  28. return port_to_devdisr[port] & devdisr2;
  29. }
  30. void fman_disable_port(enum fm_port port)
  31. {
  32. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  33. /* don't allow disabling of DTSEC1 as its needed for MDIO */
  34. if (port == FM1_DTSEC1)
  35. return;
  36. setbits_be32(&gur->devdisr2, port_to_devdisr[port]);
  37. }
  38. void fman_enable_port(enum fm_port port)
  39. {
  40. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  41. clrbits_be32(&gur->devdisr2, port_to_devdisr[port]);
  42. }
  43. phy_interface_t fman_port_enet_if(enum fm_port port)
  44. {
  45. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  46. u32 rcwsr11 = in_be32(&gur->rcwsr[11]);
  47. if (is_device_disabled(port))
  48. return PHY_INTERFACE_MODE_NONE;
  49. if ((port == FM1_10GEC1) && (is_serdes_configured(XAUI_FM1)))
  50. return PHY_INTERFACE_MODE_XGMII;
  51. if ((port == FM2_10GEC1) && (is_serdes_configured(XAUI_FM2)))
  52. return PHY_INTERFACE_MODE_XGMII;
  53. /* handle RGMII first */
  54. if ((port == FM1_DTSEC1) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC1) ==
  55. FSL_CORENET_RCWSR11_EC1_FM1_DTSEC1))
  56. return PHY_INTERFACE_MODE_RGMII;
  57. if ((port == FM1_DTSEC2) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC2) ==
  58. FSL_CORENET_RCWSR11_EC2_FM1_DTSEC2))
  59. return PHY_INTERFACE_MODE_RGMII;
  60. if ((port == FM2_DTSEC1) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC2) ==
  61. FSL_CORENET_RCWSR11_EC2_FM2_DTSEC1))
  62. return PHY_INTERFACE_MODE_RGMII;
  63. switch (port) {
  64. case FM1_DTSEC1:
  65. case FM1_DTSEC2:
  66. case FM1_DTSEC3:
  67. case FM1_DTSEC4:
  68. if (is_serdes_configured(SGMII_FM1_DTSEC1 + port - FM1_DTSEC1))
  69. return PHY_INTERFACE_MODE_SGMII;
  70. break;
  71. case FM2_DTSEC1:
  72. case FM2_DTSEC2:
  73. case FM2_DTSEC3:
  74. case FM2_DTSEC4:
  75. if (is_serdes_configured(SGMII_FM2_DTSEC1 + port - FM2_DTSEC1))
  76. return PHY_INTERFACE_MODE_SGMII;
  77. break;
  78. default:
  79. return PHY_INTERFACE_MODE_NONE;
  80. }
  81. return PHY_INTERFACE_MODE_NONE;
  82. }