bsc9132_serdes.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. /*
  2. * Copyright 2013 Freescale Semiconductor, Inc.
  3. * Author: Prabhakar Kushwaha <prabhakar@freescale.com>
  4. *
  5. * This program is free software; you can redistribute it and/or modify it
  6. * under the terms of the GNU General Public License as published by the Free
  7. * Software Foundation; either version 2 of the License, or (at your option)
  8. * any later version.
  9. */
  10. #include <config.h>
  11. #include <common.h>
  12. #include <asm/io.h>
  13. #include <asm/immap_85xx.h>
  14. #include <asm/fsl_serdes.h>
  15. #define SRDS1_MAX_LANES 4
  16. static u32 serdes1_prtcl_map;
  17. static u8 serdes1_cfg_tbl[][SRDS1_MAX_LANES] = {
  18. [0] = {NONE, NONE, NONE, NONE},
  19. [1] = {PCIE1, PCIE2, CPRI2, CPRI1},
  20. [2] = {PCIE1, PCIE2, CPRI2, CPRI1},
  21. [3] = {PCIE1, PCIE2, CPRI2, CPRI1},
  22. [4] = {PCIE1, PCIE2, CPRI2, CPRI1},
  23. [5] = {PCIE1, PCIE2, CPRI2, CPRI1},
  24. [6] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  25. [7] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  26. [8] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  27. [9] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  28. [10] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  29. [11] = {PCIE1, PCIE2, SGMII_TSEC1, SGMII_TSEC2},
  30. [12] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  31. [13] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  32. [14] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  33. [15] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  34. [16] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  35. [17] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  36. [18] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  37. [19] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  38. [20] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  39. [21] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  40. [22] = {PCIE1, PCIE2, CPRI2, CPRI1},
  41. [23] = {PCIE1, PCIE2, CPRI2, CPRI1},
  42. [24] = {PCIE1, PCIE2, CPRI2, CPRI1},
  43. [25] = {PCIE1, PCIE2, CPRI2, CPRI1},
  44. [26] = {PCIE1, PCIE2, CPRI2, CPRI1},
  45. [27] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  46. [28] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  47. [29] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  48. [30] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  49. [31] = {PCIE1, PCIE2, SGMII_TSEC1, CPRI1},
  50. [32] = {PCIE1, PCIE2, SGMII_TSEC1, SGMII_TSEC2},
  51. [33] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  52. [34] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  53. [35] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  54. [36] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  55. [37] = {PCIE1, SGMII_TSEC2, CPRI2, CPRI1},
  56. [38] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  57. [39] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  58. [40] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  59. [41] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  60. [42] = {PCIE1, SGMII_TSEC2, SGMII_TSEC1, CPRI1},
  61. [43] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  62. [44] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  63. [45] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  64. [46] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  65. [47] = {SGMII_TSEC1, SGMII_TSEC2, CPRI2, CPRI1},
  66. };
  67. int is_serdes_configured(enum srds_prtcl prtcl)
  68. {
  69. return (1 << prtcl) & serdes1_prtcl_map;
  70. }
  71. void fsl_serdes_init(void)
  72. {
  73. ccsr_gur_t *gur = (void *)(CONFIG_SYS_MPC85xx_GUTS_ADDR);
  74. u32 pordevsr = in_be32(&gur->pordevsr);
  75. u32 srds_cfg = (pordevsr & MPC85xx_PORDEVSR_IO_SEL) >>
  76. MPC85xx_PORDEVSR_IO_SEL_SHIFT;
  77. int lane;
  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. }