p5020.c 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  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_DTSEC5] = FSL_CORENET_DEVDISR2_DTSEC1_5,
  18. [FM1_10GEC1] = FSL_CORENET_DEVDISR2_10GEC1,
  19. };
  20. static int is_device_disabled(enum fm_port port)
  21. {
  22. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  23. u32 devdisr2 = in_be32(&gur->devdisr2);
  24. return port_to_devdisr[port] & devdisr2;
  25. }
  26. void fman_disable_port(enum fm_port port)
  27. {
  28. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  29. /* don't allow disabling of DTSEC1 as its needed for MDIO */
  30. if (port == FM1_DTSEC1)
  31. return;
  32. setbits_be32(&gur->devdisr2, port_to_devdisr[port]);
  33. }
  34. void fman_enable_port(enum fm_port port)
  35. {
  36. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  37. clrbits_be32(&gur->devdisr2, port_to_devdisr[port]);
  38. }
  39. phy_interface_t fman_port_enet_if(enum fm_port port)
  40. {
  41. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  42. u32 rcwsr11 = in_be32(&gur->rcwsr[11]);
  43. if (is_device_disabled(port))
  44. return PHY_INTERFACE_MODE_NONE;
  45. if ((port == FM1_10GEC1) && (is_serdes_configured(XAUI_FM1)))
  46. return PHY_INTERFACE_MODE_XGMII;
  47. /* handle RGMII first */
  48. if ((port == FM1_DTSEC4) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC1) ==
  49. FSL_CORENET_RCWSR11_EC1_FM1_DTSEC4_RGMII))
  50. return PHY_INTERFACE_MODE_RGMII;
  51. if ((port == FM1_DTSEC4) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC1) ==
  52. FSL_CORENET_RCWSR11_EC1_FM1_DTSEC4_MII))
  53. return PHY_INTERFACE_MODE_MII;
  54. if ((port == FM1_DTSEC5) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC2) ==
  55. FSL_CORENET_RCWSR11_EC2_FM1_DTSEC5_RGMII))
  56. return PHY_INTERFACE_MODE_RGMII;
  57. if ((port == FM1_DTSEC5) && ((rcwsr11 & FSL_CORENET_RCWSR11_EC2) ==
  58. FSL_CORENET_RCWSR11_EC2_FM1_DTSEC5_MII))
  59. return PHY_INTERFACE_MODE_MII;
  60. switch (port) {
  61. case FM1_DTSEC1:
  62. case FM1_DTSEC2:
  63. case FM1_DTSEC3:
  64. case FM1_DTSEC4:
  65. case FM1_DTSEC5:
  66. if (is_serdes_configured(SGMII_FM1_DTSEC1 + port - FM1_DTSEC1))
  67. return PHY_INTERFACE_MODE_SGMII;
  68. break;
  69. default:
  70. return PHY_INTERFACE_MODE_NONE;
  71. }
  72. return PHY_INTERFACE_MODE_NONE;
  73. }