board.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. /*
  2. * (C) Copyright 2012 Michal Simek <monstr@monstr.eu>
  3. *
  4. * SPDX-License-Identifier: GPL-2.0+
  5. */
  6. #include <common.h>
  7. #include <fdtdec.h>
  8. #include <fpga.h>
  9. #include <mmc.h>
  10. #include <zynqpl.h>
  11. #include <asm/arch/hardware.h>
  12. #include <asm/arch/sys_proto.h>
  13. #include <asm/arch/ps7_init_gpl.h>
  14. DECLARE_GLOBAL_DATA_PTR;
  15. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  16. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  17. static xilinx_desc fpga;
  18. /* It can be done differently */
  19. static xilinx_desc fpga007s = XILINX_XC7Z007S_DESC(0x7);
  20. static xilinx_desc fpga010 = XILINX_XC7Z010_DESC(0x10);
  21. static xilinx_desc fpga012s = XILINX_XC7Z012S_DESC(0x12);
  22. static xilinx_desc fpga014s = XILINX_XC7Z014S_DESC(0x14);
  23. static xilinx_desc fpga015 = XILINX_XC7Z015_DESC(0x15);
  24. static xilinx_desc fpga020 = XILINX_XC7Z020_DESC(0x20);
  25. static xilinx_desc fpga030 = XILINX_XC7Z030_DESC(0x30);
  26. static xilinx_desc fpga035 = XILINX_XC7Z035_DESC(0x35);
  27. static xilinx_desc fpga045 = XILINX_XC7Z045_DESC(0x45);
  28. static xilinx_desc fpga100 = XILINX_XC7Z100_DESC(0x100);
  29. #endif
  30. int board_init(void)
  31. {
  32. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  33. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  34. u32 idcode;
  35. idcode = zynq_slcr_get_idcode();
  36. switch (idcode) {
  37. case XILINX_ZYNQ_7007S:
  38. fpga = fpga007s;
  39. break;
  40. case XILINX_ZYNQ_7010:
  41. fpga = fpga010;
  42. break;
  43. case XILINX_ZYNQ_7012S:
  44. fpga = fpga012s;
  45. break;
  46. case XILINX_ZYNQ_7014S:
  47. fpga = fpga014s;
  48. break;
  49. case XILINX_ZYNQ_7015:
  50. fpga = fpga015;
  51. break;
  52. case XILINX_ZYNQ_7020:
  53. fpga = fpga020;
  54. break;
  55. case XILINX_ZYNQ_7030:
  56. fpga = fpga030;
  57. break;
  58. case XILINX_ZYNQ_7035:
  59. fpga = fpga035;
  60. break;
  61. case XILINX_ZYNQ_7045:
  62. fpga = fpga045;
  63. break;
  64. case XILINX_ZYNQ_7100:
  65. fpga = fpga100;
  66. break;
  67. }
  68. #endif
  69. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  70. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  71. fpga_init();
  72. fpga_add(fpga_xilinx, &fpga);
  73. #endif
  74. return 0;
  75. }
  76. int board_late_init(void)
  77. {
  78. switch ((zynq_slcr_get_boot_mode()) & ZYNQ_BM_MASK) {
  79. case ZYNQ_BM_QSPI:
  80. env_set("modeboot", "qspiboot");
  81. break;
  82. case ZYNQ_BM_NAND:
  83. env_set("modeboot", "nandboot");
  84. break;
  85. case ZYNQ_BM_NOR:
  86. env_set("modeboot", "norboot");
  87. break;
  88. case ZYNQ_BM_SD:
  89. env_set("modeboot", "sdboot");
  90. break;
  91. case ZYNQ_BM_JTAG:
  92. env_set("modeboot", "jtagboot");
  93. break;
  94. default:
  95. env_set("modeboot", "");
  96. break;
  97. }
  98. return 0;
  99. }
  100. #ifdef CONFIG_DISPLAY_BOARDINFO
  101. int checkboard(void)
  102. {
  103. u32 version = zynq_get_silicon_version();
  104. version <<= 1;
  105. if (version > (PCW_SILICON_VERSION_3 << 1))
  106. version += 1;
  107. puts("Board: Xilinx Zynq\n");
  108. printf("Silicon: v%d.%d\n", version >> 1, version & 1);
  109. return 0;
  110. }
  111. #endif
  112. int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
  113. {
  114. #if defined(CONFIG_ZYNQ_GEM_EEPROM_ADDR) && \
  115. defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
  116. if (eeprom_read(CONFIG_ZYNQ_GEM_EEPROM_ADDR,
  117. CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET,
  118. ethaddr, 6))
  119. printf("I2C EEPROM MAC address read failed\n");
  120. #endif
  121. return 0;
  122. }
  123. #if !defined(CONFIG_SYS_SDRAM_BASE) && !defined(CONFIG_SYS_SDRAM_SIZE)
  124. int dram_init_banksize(void)
  125. {
  126. return fdtdec_setup_memory_banksize();
  127. }
  128. int dram_init(void)
  129. {
  130. if (fdtdec_setup_memory_size() != 0)
  131. return -EINVAL;
  132. zynq_ddrc_init();
  133. return 0;
  134. }
  135. #else
  136. int dram_init(void)
  137. {
  138. gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
  139. zynq_ddrc_init();
  140. return 0;
  141. }
  142. #endif