zynq-common.h 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /*
  2. * (C) Copyright 2012 Michal Simek <monstr@monstr.eu>
  3. * (C) Copyright 2013 Xilinx, Inc.
  4. *
  5. * Common configuration options for all Zynq boards.
  6. *
  7. * SPDX-License-Identifier: GPL-2.0+
  8. */
  9. #ifndef __CONFIG_ZYNQ_COMMON_H
  10. #define __CONFIG_ZYNQ_COMMON_H
  11. /* High Level configuration Options */
  12. #define CONFIG_ARMV7
  13. #define CONFIG_ZYNQ
  14. /* CPU clock */
  15. #ifndef CONFIG_CPU_FREQ_HZ
  16. # define CONFIG_CPU_FREQ_HZ 800000000
  17. #endif
  18. /* Cache options */
  19. #define CONFIG_CMD_CACHE
  20. #define CONFIG_SYS_CACHELINE_SIZE 32
  21. #define CONFIG_SYS_L2CACHE_OFF
  22. #ifndef CONFIG_SYS_L2CACHE_OFF
  23. # define CONFIG_SYS_L2_PL310
  24. # define CONFIG_SYS_PL310_BASE 0xf8f02000
  25. #endif
  26. /* Serial drivers */
  27. #define CONFIG_BAUDRATE 115200
  28. /* The following table includes the supported baudrates */
  29. #define CONFIG_SYS_BAUDRATE_TABLE \
  30. {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400}
  31. /* Zynq Serial driver */
  32. #ifdef CONFIG_ZYNQ_SERIAL_UART0
  33. # define CONFIG_ZYNQ_SERIAL_BASEADDR0 0xE0000000
  34. # define CONFIG_ZYNQ_SERIAL_BAUDRATE0 CONFIG_BAUDRATE
  35. # define CONFIG_ZYNQ_SERIAL_CLOCK0 50000000
  36. #endif
  37. #ifdef CONFIG_ZYNQ_SERIAL_UART1
  38. # define CONFIG_ZYNQ_SERIAL_BASEADDR1 0xE0001000
  39. # define CONFIG_ZYNQ_SERIAL_BAUDRATE1 CONFIG_BAUDRATE
  40. # define CONFIG_ZYNQ_SERIAL_CLOCK1 50000000
  41. #endif
  42. #if defined(CONFIG_ZYNQ_SERIAL_UART0) || defined(CONFIG_ZYNQ_SERIAL_UART1)
  43. # define CONFIG_ZYNQ_SERIAL
  44. #endif
  45. /* DCC driver */
  46. #if defined(CONFIG_ZYNQ_DCC)
  47. # define CONFIG_ARM_DCC
  48. # define CONFIG_CPU_V6 /* Required by CONFIG_ARM_DCC */
  49. #endif
  50. /* Ethernet driver */
  51. #if defined(CONFIG_ZYNQ_GEM0) || defined(CONFIG_ZYNQ_GEM1)
  52. # define CONFIG_NET_MULTI
  53. # define CONFIG_ZYNQ_GEM
  54. # define CONFIG_MII
  55. # define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
  56. # define CONFIG_PHYLIB
  57. # define CONFIG_PHY_MARVELL
  58. #endif
  59. /* SPI */
  60. #ifdef CONFIG_ZYNQ_SPI
  61. # define CONFIG_SPI_FLASH
  62. # define CONFIG_SPI_FLASH_SST
  63. # define CONFIG_CMD_SF
  64. #endif
  65. /* NOR */
  66. #ifndef CONFIG_SYS_NO_FLASH
  67. # define CONFIG_SYS_FLASH_BASE 0xE2000000
  68. # define CONFIG_SYS_FLASH_SIZE (16 * 1024 * 1024)
  69. # define CONFIG_SYS_MAX_FLASH_BANKS 1
  70. # define CONFIG_SYS_MAX_FLASH_SECT 512
  71. # define CONFIG_SYS_FLASH_ERASE_TOUT 1000
  72. # define CONFIG_SYS_FLASH_WRITE_TOUT 5000
  73. # define CONFIG_FLASH_SHOW_PROGRESS 10
  74. # define CONFIG_SYS_FLASH_CFI
  75. # undef CONFIG_SYS_FLASH_EMPTY_INFO
  76. # define CONFIG_FLASH_CFI_DRIVER
  77. # undef CONFIG_SYS_FLASH_PROTECTION
  78. # define CONFIG_SYS_FLASH_USE_BUFFER_WRITE
  79. #endif
  80. /* MMC */
  81. #if defined(CONFIG_ZYNQ_SDHCI0) || defined(CONFIG_ZYNQ_SDHCI1)
  82. # define CONFIG_MMC
  83. # define CONFIG_GENERIC_MMC
  84. # define CONFIG_SDHCI
  85. # define CONFIG_ZYNQ_SDHCI
  86. # define CONFIG_CMD_MMC
  87. # define CONFIG_CMD_FAT
  88. # define CONFIG_SUPPORT_VFAT
  89. # define CONFIG_CMD_EXT2
  90. # define CONFIG_DOS_PARTITION
  91. #endif
  92. /* I2C */
  93. #if defined(CONFIG_ZYNQ_I2C0) || defined(CONFIG_ZYNQ_I2C1)
  94. # define CONFIG_CMD_I2C
  95. # define CONFIG_SYS_I2C
  96. # define CONFIG_SYS_I2C_ZYNQ
  97. # define CONFIG_SYS_I2C_ZYNQ_SPEED 100000
  98. # define CONFIG_SYS_I2C_ZYNQ_SLAVE 1
  99. #endif
  100. /* EEPROM */
  101. #ifdef CONFIG_ZYNQ_EEPROM
  102. # define CONFIG_CMD_EEPROM
  103. # define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 1
  104. # define CONFIG_SYS_I2C_EEPROM_ADDR 0x54
  105. # define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 4
  106. # define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 5
  107. # define CONFIG_SYS_EEPROM_SIZE 1024 /* Bytes */
  108. #endif
  109. #define CONFIG_BOOTP_SERVERIP
  110. #define CONFIG_BOOTP_BOOTPATH
  111. #define CONFIG_BOOTP_GATEWAY
  112. #define CONFIG_BOOTP_HOSTNAME
  113. #define CONFIG_BOOTP_MAY_FAIL
  114. /* Environment */
  115. #define CONFIG_ENV_SIZE 0x10000 /* Env. sector size */
  116. #define CONFIG_ENV_IS_NOWHERE
  117. #define CONFIG_SYS_LOAD_ADDR 0
  118. /* Miscellaneous configurable options */
  119. #define CONFIG_SYS_PROMPT "zynq-uboot> "
  120. #define CONFIG_SYS_HUSH_PARSER
  121. #define CONFIG_CMDLINE_EDITING
  122. #define CONFIG_AUTO_COMPLETE
  123. #define CONFIG_BOARD_LATE_INIT
  124. #define CONFIG_SYS_LONGHELP
  125. #define CONFIG_SYS_MAXARGS 15 /* max number of command args */
  126. #define CONFIG_SYS_CBSIZE 256 /* Console I/O Buffer Size */
  127. #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \
  128. sizeof(CONFIG_SYS_PROMPT) + 16)
  129. /* Physical Memory map */
  130. #define CONFIG_SYS_TEXT_BASE 0x4000000
  131. #define CONFIG_NR_DRAM_BANKS 1
  132. #define CONFIG_SYS_SDRAM_BASE 0
  133. #define CONFIG_SYS_MEMTEST_START CONFIG_SYS_SDRAM_BASE
  134. #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_SDRAM_BASE + 0x1000)
  135. #define CONFIG_SYS_MALLOC_LEN 0x400000
  136. #define CONFIG_SYS_INIT_RAM_ADDR CONFIG_SYS_SDRAM_BASE
  137. #define CONFIG_SYS_INIT_RAM_SIZE CONFIG_SYS_MALLOC_LEN
  138. #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INIT_RAM_ADDR + \
  139. CONFIG_SYS_INIT_RAM_SIZE - \
  140. GENERATED_GBL_DATA_SIZE)
  141. /* Enable the PL to be downloaded */
  142. #define CONFIG_FPGA
  143. #define CONFIG_FPGA_XILINX
  144. #define CONFIG_FPGA_ZYNQPL
  145. #define CONFIG_CMD_FPGA
  146. /* Open Firmware flat tree */
  147. #define CONFIG_OF_LIBFDT
  148. /* FIT support */
  149. #define CONFIG_FIT
  150. #define CONFIG_FIT_VERBOSE 1 /* enable fit_format_{error,warning}() */
  151. /* Boot FreeBSD/vxWorks from an ELF image */
  152. #if defined(CONFIG_ZYNQ_BOOT_FREEBSD)
  153. # define CONFIG_API
  154. # define CONFIG_CMD_ELF
  155. # define CONFIG_SYS_MMC_MAX_DEVICE 1
  156. #endif
  157. /* Commands */
  158. #include <config_cmd_default.h>
  159. #define CONFIG_CMD_PING
  160. #define CONFIG_CMD_DHCP
  161. #define CONFIG_CMD_MII
  162. #endif /* __CONFIG_ZYNQ_COMMON_H */