p2041_serdes.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. /*
  2. * Copyright 2010-2011 Freescale Semiconductor, Inc.
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <asm/fsl_serdes.h>
  8. #include <asm/processor.h>
  9. #include <asm/io.h>
  10. #include "fsl_corenet_serdes.h"
  11. static u8 serdes_cfg_tbl[][SRDS_MAX_LANES] = {
  12. [0x2] = {NONE, NONE, PCIE1, PCIE1, SRIO1, SRIO1, SRIO1, SRIO1,
  13. NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2,
  14. SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE, NONE, NONE, },
  15. [0x5] = {NONE, NONE, PCIE1, PCIE3, PCIE2, PCIE2, PCIE2, PCIE2,
  16. NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2,
  17. SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE, NONE, NONE, },
  18. [0x8] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, PCIE2,
  19. PCIE2, PCIE2, PCIE2, NONE, NONE, NONE, NONE, SATA1,
  20. SATA2, NONE, NONE, NONE, NONE, },
  21. [0x9] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, PCIE2,
  22. PCIE2, PCIE2, PCIE2, NONE, NONE, XAUI_FM1, XAUI_FM1,
  23. XAUI_FM1, XAUI_FM1, NONE, NONE, NONE, NONE, },
  24. [0xa] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, PCIE2,
  25. PCIE2, PCIE2, PCIE2, NONE, NONE, PCIE3, PCIE3, PCIE3,
  26. PCIE3, NONE, NONE, NONE, NONE, },
  27. [0xf] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, SRIO2,
  28. SRIO2, SRIO1, SRIO1, NONE, NONE, PCIE3, SGMII_FM1_DTSEC5,
  29. SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE, NONE, NONE, },
  30. [0x14] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, PCIE2,
  31. PCIE2, SRIO1, SRIO1, NONE, NONE, AURORA,
  32. SGMII_FM1_DTSEC5, SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE,
  33. NONE, NONE, NONE, },
  34. [0x16] = {NONE, NONE, PCIE1, PCIE3, PCIE2, PCIE2, SGMII_FM1_DTSEC3,
  35. SGMII_FM1_DTSEC4, NONE, NONE, NONE, NONE, SATA1, SATA2, NONE,
  36. NONE, NONE, NONE, },
  37. [0x17] = {NONE, NONE, PCIE1, PCIE3, PCIE2, PCIE2, SGMII_FM1_DTSEC3,
  38. SGMII_FM1_DTSEC4, NONE, NONE, XAUI_FM1, XAUI_FM1, XAUI_FM1,
  39. XAUI_FM1, NONE, NONE, NONE, NONE, },
  40. [0x19] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, PCIE2,
  41. PCIE2, SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE,
  42. NONE, NONE, SATA1, SATA2, NONE, NONE, NONE, NONE, },
  43. [0x1a] = {NONE, NONE, SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, SRIO2,
  44. SRIO2, SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE,
  45. NONE, NONE, SATA1, SATA2, NONE, NONE, NONE, NONE, },
  46. [0x1c] = {NONE, NONE, PCIE1, SGMII_FM1_DTSEC2, PCIE2, PCIE2,
  47. SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, NONE, NONE, AURORA,
  48. SGMII_FM1_DTSEC5, NONE, NONE, NONE, NONE, NONE, NONE, },
  49. };
  50. enum srds_prtcl serdes_get_prtcl(int cfg, int lane)
  51. {
  52. enum srds_prtcl prtcl;
  53. u32 svr = get_svr();
  54. u32 ver = SVR_SOC_VER(svr);
  55. if (!serdes_lane_enabled(lane))
  56. return NONE;
  57. prtcl = serdes_cfg_tbl[cfg][lane];
  58. /* P2040[e] does not support XAUI */
  59. if (ver == SVR_P2040 && prtcl == XAUI_FM1)
  60. prtcl = NONE;
  61. return prtcl;
  62. }
  63. int is_serdes_prtcl_valid(u32 prtcl)
  64. {
  65. int i;
  66. u32 svr = get_svr();
  67. u32 ver = SVR_SOC_VER(svr);
  68. if (prtcl >= ARRAY_SIZE(serdes_cfg_tbl))
  69. return 0;
  70. /* P2040[e] does not support XAUI */
  71. if (ver == SVR_P2040 && prtcl == XAUI_FM1)
  72. return 0;
  73. for (i = 0; i < SRDS_MAX_LANES; i++) {
  74. if (serdes_cfg_tbl[prtcl][i] != NONE)
  75. return 1;
  76. }
  77. return 0;
  78. }