board.c 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. /*
  2. * (C) Copyright 2012 Michal Simek <monstr@monstr.eu>
  3. * (C) Copyright 2013 - 2018 Xilinx, Inc.
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #include <common.h>
  8. #include <dm/uclass.h>
  9. #include <fdtdec.h>
  10. #include <fpga.h>
  11. #include <mmc.h>
  12. #include <wdt.h>
  13. #include <zynqpl.h>
  14. #include <asm/arch/hardware.h>
  15. #include <asm/arch/sys_proto.h>
  16. #include <asm/arch/ps7_init_gpl.h>
  17. DECLARE_GLOBAL_DATA_PTR;
  18. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  19. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  20. static xilinx_desc fpga;
  21. /* It can be done differently */
  22. static xilinx_desc fpga007s = XILINX_XC7Z007S_DESC(0x7);
  23. static xilinx_desc fpga010 = XILINX_XC7Z010_DESC(0x10);
  24. static xilinx_desc fpga012s = XILINX_XC7Z012S_DESC(0x12);
  25. static xilinx_desc fpga014s = XILINX_XC7Z014S_DESC(0x14);
  26. static xilinx_desc fpga015 = XILINX_XC7Z015_DESC(0x15);
  27. static xilinx_desc fpga020 = XILINX_XC7Z020_DESC(0x20);
  28. static xilinx_desc fpga030 = XILINX_XC7Z030_DESC(0x30);
  29. static xilinx_desc fpga035 = XILINX_XC7Z035_DESC(0x35);
  30. static xilinx_desc fpga045 = XILINX_XC7Z045_DESC(0x45);
  31. static xilinx_desc fpga100 = XILINX_XC7Z100_DESC(0x100);
  32. #endif
  33. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_WDT)
  34. static struct udevice *watchdog_dev;
  35. #endif
  36. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_BOARD_EARLY_INIT_F)
  37. int board_early_init_f(void)
  38. {
  39. # if defined(CONFIG_WDT)
  40. /* bss is not cleared at time when watchdog_reset() is called */
  41. watchdog_dev = NULL;
  42. # endif
  43. return 0;
  44. }
  45. #endif
  46. int board_init(void)
  47. {
  48. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  49. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  50. u32 idcode;
  51. idcode = zynq_slcr_get_idcode();
  52. switch (idcode) {
  53. case XILINX_ZYNQ_7007S:
  54. fpga = fpga007s;
  55. break;
  56. case XILINX_ZYNQ_7010:
  57. fpga = fpga010;
  58. break;
  59. case XILINX_ZYNQ_7012S:
  60. fpga = fpga012s;
  61. break;
  62. case XILINX_ZYNQ_7014S:
  63. fpga = fpga014s;
  64. break;
  65. case XILINX_ZYNQ_7015:
  66. fpga = fpga015;
  67. break;
  68. case XILINX_ZYNQ_7020:
  69. fpga = fpga020;
  70. break;
  71. case XILINX_ZYNQ_7030:
  72. fpga = fpga030;
  73. break;
  74. case XILINX_ZYNQ_7035:
  75. fpga = fpga035;
  76. break;
  77. case XILINX_ZYNQ_7045:
  78. fpga = fpga045;
  79. break;
  80. case XILINX_ZYNQ_7100:
  81. fpga = fpga100;
  82. break;
  83. }
  84. #endif
  85. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_WDT)
  86. if (uclass_get_device(UCLASS_WDT, 0, &watchdog_dev)) {
  87. puts("Watchdog: Not found!\n");
  88. } else {
  89. wdt_start(watchdog_dev, 0, 0);
  90. puts("Watchdog: Started\n");
  91. }
  92. # endif
  93. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  94. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  95. fpga_init();
  96. fpga_add(fpga_xilinx, &fpga);
  97. #endif
  98. return 0;
  99. }
  100. int board_late_init(void)
  101. {
  102. switch ((zynq_slcr_get_boot_mode()) & ZYNQ_BM_MASK) {
  103. case ZYNQ_BM_QSPI:
  104. env_set("modeboot", "qspiboot");
  105. break;
  106. case ZYNQ_BM_NAND:
  107. env_set("modeboot", "nandboot");
  108. break;
  109. case ZYNQ_BM_NOR:
  110. env_set("modeboot", "norboot");
  111. break;
  112. case ZYNQ_BM_SD:
  113. env_set("modeboot", "sdboot");
  114. break;
  115. case ZYNQ_BM_JTAG:
  116. env_set("modeboot", "jtagboot");
  117. break;
  118. default:
  119. env_set("modeboot", "");
  120. break;
  121. }
  122. return 0;
  123. }
  124. #ifdef CONFIG_DISPLAY_BOARDINFO
  125. int checkboard(void)
  126. {
  127. u32 version = zynq_get_silicon_version();
  128. version <<= 1;
  129. if (version > (PCW_SILICON_VERSION_3 << 1))
  130. version += 1;
  131. puts("Board: Xilinx Zynq\n");
  132. printf("Silicon: v%d.%d\n", version >> 1, version & 1);
  133. return 0;
  134. }
  135. #endif
  136. int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
  137. {
  138. #if defined(CONFIG_ZYNQ_GEM_EEPROM_ADDR) && \
  139. defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
  140. if (eeprom_read(CONFIG_ZYNQ_GEM_EEPROM_ADDR,
  141. CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET,
  142. ethaddr, 6))
  143. printf("I2C EEPROM MAC address read failed\n");
  144. #endif
  145. return 0;
  146. }
  147. #if !defined(CONFIG_SYS_SDRAM_BASE) && !defined(CONFIG_SYS_SDRAM_SIZE)
  148. int dram_init_banksize(void)
  149. {
  150. return fdtdec_setup_memory_banksize();
  151. }
  152. int dram_init(void)
  153. {
  154. if (fdtdec_setup_memory_size() != 0)
  155. return -EINVAL;
  156. zynq_ddrc_init();
  157. return 0;
  158. }
  159. #else
  160. int dram_init(void)
  161. {
  162. gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
  163. zynq_ddrc_init();
  164. return 0;
  165. }
  166. #endif
  167. #if defined(CONFIG_WATCHDOG)
  168. /* Called by macro WATCHDOG_RESET */
  169. void watchdog_reset(void)
  170. {
  171. # if !defined(CONFIG_SPL_BUILD)
  172. static ulong next_reset;
  173. ulong now;
  174. if (!watchdog_dev)
  175. return;
  176. now = timer_get_us();
  177. /* Do not reset the watchdog too often */
  178. if (now > next_reset) {
  179. wdt_reset(watchdog_dev);
  180. next_reset = now + 1000;
  181. }
  182. # endif
  183. }
  184. #endif