bsc9132_serdes.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright 2013 Freescale Semiconductor, Inc.
  4. * Author: Prabhakar Kushwaha <prabhakar@freescale.com>
  5. */
  6. #include <config.h>
  7. #include <common.h>
  8. #include <asm/io.h>
  9. #include <asm/immap_85xx.h>
  10. #include <asm/fsl_serdes.h>
  11. #define SRDS1_MAX_LANES 4
  12. static u32 serdes1_prtcl_map;
  13. static u8 serdes1_cfg_tbl[][SRDS1_MAX_LANES] = {
  14. [0] = {NONE, NONE, NONE, NONE},
  15. [1] = {PCIE1, PCIE2, CPRI2, CPRI1},
  16. [2] = {PCIE1, PCIE2, CPRI2, CPRI1},
  17. [3] = {PCIE1, PCIE2, CPRI2, CPRI1},
  18. [4] = {PCIE1, PCIE2, CPRI2, CPRI1},
  19. [5] = {PCIE1, PCIE2, CPRI2, CPRI1},
  20. [6] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  21. [7] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  22. [8] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  23. [9] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  24. [10] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  25. [11] = {PCIE1, PCIE2, SGMII_TSEC1, SGMII_TSEC2},
  26. [12] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  27. [13] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  28. [14] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  29. [15] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  30. [16] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  31. [17] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  32. [18] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  33. [19] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  34. [20] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  35. [21] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  36. [22] = {PCIE1, PCIE2, CPRI2, CPRI1},
  37. [23] = {PCIE1, PCIE2, CPRI2, CPRI1},
  38. [24] = {PCIE1, PCIE2, CPRI2, CPRI1},
  39. [25] = {PCIE1, PCIE2, CPRI2, CPRI1},
  40. [26] = {PCIE1, PCIE2, CPRI2, CPRI1},
  41. [27] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  42. [28] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  43. [29] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  44. [30] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  45. [31] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  46. [32] = {PCIE1, PCIE2, SGMII_TSEC1, SGMII_TSEC2},
  47. [33] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  48. [34] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  49. [35] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  50. [36] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  51. [37] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  52. [38] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  53. [39] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  54. [40] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  55. [41] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  56. [42] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  57. [43] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  58. [44] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  59. [45] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  60. [46] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  61. [47] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  62. };
  63. int is_serdes_configured(enum srds_prtcl prtcl)
  64. {
  65. if (!(serdes1_prtcl_map & (1 << NONE)))
  66. fsl_serdes_init();
  67. return (1 << prtcl) & serdes1_prtcl_map;
  68. }
  69. void fsl_serdes_init(void)
  70. {
  71. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  72. u32 pordevsr = in_be32(&gur->pordevsr);
  73. u32 srds_cfg = (pordevsr & MPC85xx_PORDEVSR_IO_SEL) >>
  74. MPC85xx_PORDEVSR_IO_SEL_SHIFT;
  75. int lane;
  76. if (serdes1_prtcl_map & (1 << NONE))
  77. return;
  78. debug("PORDEVSR[IO_SEL_SRDS] = %x\n", srds_cfg);
  79. if (srds_cfg >= ARRAY_SIZE(serdes1_cfg_tbl)) {
  80. printf("Invalid PORDEVSR[IO_SEL_SRDS] = %d\n", srds_cfg);
  81. return;
  82. }
  83. for (lane = 0; lane < SRDS1_MAX_LANES; lane++) {
  84. enum srds_prtcl lane_prtcl = serdes1_cfg_tbl[srds_cfg][lane];
  85. serdes1_prtcl_map |= (1 << lane_prtcl);
  86. }
  87. /* Set the first bit to indicate serdes has been initialized */
  88. serdes1_prtcl_map |= (1 << NONE);
  89. }