board.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  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. DECLARE_GLOBAL_DATA_PTR;
  14. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  15. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  16. static xilinx_desc fpga;
  17. /* It can be done differently */
  18. static xilinx_desc fpga007s = XILINX_XC7Z007S_DESC(0x7);
  19. static xilinx_desc fpga010 = XILINX_XC7Z010_DESC(0x10);
  20. static xilinx_desc fpga012s = XILINX_XC7Z012S_DESC(0x12);
  21. static xilinx_desc fpga014s = XILINX_XC7Z014S_DESC(0x14);
  22. static xilinx_desc fpga015 = XILINX_XC7Z015_DESC(0x15);
  23. static xilinx_desc fpga020 = XILINX_XC7Z020_DESC(0x20);
  24. static xilinx_desc fpga030 = XILINX_XC7Z030_DESC(0x30);
  25. static xilinx_desc fpga035 = XILINX_XC7Z035_DESC(0x35);
  26. static xilinx_desc fpga045 = XILINX_XC7Z045_DESC(0x45);
  27. static xilinx_desc fpga100 = XILINX_XC7Z100_DESC(0x100);
  28. #endif
  29. int board_init(void)
  30. {
  31. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  32. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  33. u32 idcode;
  34. idcode = zynq_slcr_get_idcode();
  35. switch (idcode) {
  36. case XILINX_ZYNQ_7007S:
  37. fpga = fpga007s;
  38. break;
  39. case XILINX_ZYNQ_7010:
  40. fpga = fpga010;
  41. break;
  42. case XILINX_ZYNQ_7012S:
  43. fpga = fpga012s;
  44. break;
  45. case XILINX_ZYNQ_7014S:
  46. fpga = fpga014s;
  47. break;
  48. case XILINX_ZYNQ_7015:
  49. fpga = fpga015;
  50. break;
  51. case XILINX_ZYNQ_7020:
  52. fpga = fpga020;
  53. break;
  54. case XILINX_ZYNQ_7030:
  55. fpga = fpga030;
  56. break;
  57. case XILINX_ZYNQ_7035:
  58. fpga = fpga035;
  59. break;
  60. case XILINX_ZYNQ_7045:
  61. fpga = fpga045;
  62. break;
  63. case XILINX_ZYNQ_7100:
  64. fpga = fpga100;
  65. break;
  66. }
  67. #endif
  68. #if (defined(CONFIG_FPGA) && !defined(CONFIG_SPL_BUILD)) || \
  69. (defined(CONFIG_SPL_FPGA_SUPPORT) && defined(CONFIG_SPL_BUILD))
  70. fpga_init();
  71. fpga_add(fpga_xilinx, &fpga);
  72. #endif
  73. return 0;
  74. }
  75. int board_late_init(void)
  76. {
  77. switch ((zynq_slcr_get_boot_mode()) & ZYNQ_BM_MASK) {
  78. case ZYNQ_BM_NOR:
  79. setenv("modeboot", "norboot");
  80. break;
  81. case ZYNQ_BM_SD:
  82. setenv("modeboot", "sdboot");
  83. break;
  84. case ZYNQ_BM_JTAG:
  85. setenv("modeboot", "jtagboot");
  86. break;
  87. default:
  88. setenv("modeboot", "");
  89. break;
  90. }
  91. return 0;
  92. }
  93. #ifdef CONFIG_DISPLAY_BOARDINFO
  94. int checkboard(void)
  95. {
  96. puts("Board: Xilinx Zynq\n");
  97. return 0;
  98. }
  99. #endif
  100. int zynq_board_read_rom_ethaddr(unsigned char *ethaddr)
  101. {
  102. #if defined(CONFIG_ZYNQ_GEM_EEPROM_ADDR) && \
  103. defined(CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET)
  104. if (eeprom_read(CONFIG_ZYNQ_GEM_EEPROM_ADDR,
  105. CONFIG_ZYNQ_GEM_I2C_MAC_OFFSET,
  106. ethaddr, 6))
  107. printf("I2C EEPROM MAC address read failed\n");
  108. #endif
  109. return 0;
  110. }
  111. #if !defined(CONFIG_SYS_SDRAM_BASE) && !defined(CONFIG_SYS_SDRAM_SIZE)
  112. void dram_init_banksize(void)
  113. {
  114. fdtdec_setup_memory_banksize();
  115. }
  116. int dram_init(void)
  117. {
  118. if (fdtdec_setup_memory_size() != 0)
  119. return -EINVAL;
  120. zynq_ddrc_init();
  121. return 0;
  122. }
  123. #else
  124. int dram_init(void)
  125. {
  126. gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
  127. zynq_ddrc_init();
  128. return 0;
  129. }
  130. #endif