p5020.c 2.3 KB

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