board.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2012 Michal Simek <monstr@monstr.eu>
  4. * (C) Copyright 2013 - 2018 Xilinx, Inc.
  5. */
  6. #include <common.h>
  7. #include <dm/uclass.h>
  8. #include <fdtdec.h>
  9. #include <fpga.h>
  10. #include <mmc.h>
  11. #include <watchdog.h>
  12. #include <wdt.h>
  13. #include <zynqpl.h>
  14. #include <asm/arch/hardware.h>
  15. #include <asm/arch/sys_proto.h>
  16. DECLARE_GLOBAL_DATA_PTR;
  17. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_WDT)
  18. static struct udevice *watchdog_dev;
  19. #endif
  20. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_BOARD_EARLY_INIT_F)
  21. int board_early_init_f(void)
  22. {
  23. # if defined(CONFIG_WDT)
  24. /* bss is not cleared at time when watchdog_reset() is called */
  25. watchdog_dev = NULL;
  26. # endif
  27. return 0;
  28. }
  29. #endif
  30. int board_init(void)
  31. {
  32. #if !defined(CONFIG_SPL_BUILD) && defined(CONFIG_WDT)
  33. if (uclass_get_device(UCLASS_WDT, 0, &watchdog_dev)) {
  34. puts("Watchdog: Not found!\n");
  35. } else {
  36. wdt_start(watchdog_dev, 0, 0);
  37. puts("Watchdog: Started\n");
  38. }
  39. # endif
  40. return 0;
  41. }
  42. int board_late_init(void)
  43. {
  44. switch ((zynq_slcr_get_boot_mode()) & ZYNQ_BM_MASK) {
  45. case ZYNQ_BM_QSPI:
  46. env_set("modeboot", "qspiboot");
  47. break;
  48. case ZYNQ_BM_NAND:
  49. env_set("modeboot", "nandboot");
  50. break;
  51. case ZYNQ_BM_NOR:
  52. env_set("modeboot", "norboot");
  53. break;
  54. case ZYNQ_BM_SD:
  55. env_set("modeboot", "sdboot");
  56. break;
  57. case ZYNQ_BM_JTAG:
  58. env_set("modeboot", "jtagboot");
  59. break;
  60. default:
  61. env_set("modeboot", "");
  62. break;
  63. }
  64. return 0;
  65. }
  66. int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
  67. {
  68. #if defined(CONFIG_ZYNQ_GEM_EEPROM_ADDR) && \
  69. defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
  70. if (eeprom_read(CONFIG_ZYNQ_GEM_EEPROM_ADDR,
  71. CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET,
  72. ethaddr, 6))
  73. printf("I2C EEPROM MAC address read failed\n");
  74. #endif
  75. return 0;
  76. }
  77. #if !defined(CONFIG_SYS_SDRAM_BASE) && !defined(CONFIG_SYS_SDRAM_SIZE)
  78. int dram_init_banksize(void)
  79. {
  80. return fdtdec_setup_memory_banksize();
  81. }
  82. int dram_init(void)
  83. {
  84. if (fdtdec_setup_memory_size() != 0)
  85. return -EINVAL;
  86. zynq_ddrc_init();
  87. return 0;
  88. }
  89. #else
  90. int dram_init(void)
  91. {
  92. gd->ram_size = get_ram_size((void *)CONFIG_SYS_SDRAM_BASE,
  93. CONFIG_SYS_SDRAM_SIZE);
  94. zynq_ddrc_init();
  95. return 0;
  96. }
  97. #endif
  98. #if defined(CONFIG_WATCHDOG)
  99. /* Called by macro WATCHDOG_RESET */
  100. void watchdog_reset(void)
  101. {
  102. # if !defined(CONFIG_SPL_BUILD)
  103. static ulong next_reset;
  104. ulong now;
  105. if (!watchdog_dev)
  106. return;
  107. now = timer_get_us();
  108. /* Do not reset the watchdog too often */
  109. if (now > next_reset) {
  110. wdt_reset(watchdog_dev);
  111. next_reset = now + 1000;
  112. }
  113. # endif
  114. }
  115. #endif