xilinx_zynqmp.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296
  1. /*
  2. * Configuration for Xilinx ZynqMP
  3. * (C) Copyright 2014 - 2015 Xilinx, Inc.
  4. * Michal Simek <michal.simek@xilinx.com>
  5. *
  6. * Based on Configuration for Versatile Express
  7. *
  8. * SPDX-License-Identifier: GPL-2.0+
  9. */
  10. #ifndef __XILINX_ZYNQMP_H
  11. #define __XILINX_ZYNQMP_H
  12. #define CONFIG_REMAKE_ELF
  13. /* #define CONFIG_ARMV8_SWITCH_TO_EL1 */
  14. #define CONFIG_SYS_NO_FLASH
  15. /* Generic Interrupt Controller Definitions */
  16. #define CONFIG_GICV2
  17. #define GICD_BASE 0xF9010000
  18. #define GICC_BASE 0xF9020000
  19. #define CONFIG_SYS_ALT_MEMTEST
  20. #define CONFIG_SYS_MEMTEST_SCRATCH 0xfffc0000
  21. #ifndef CONFIG_NR_DRAM_BANKS
  22. # define CONFIG_NR_DRAM_BANKS 2
  23. #endif
  24. #define CONFIG_SYS_MEMTEST_START 0
  25. #define CONFIG_SYS_MEMTEST_END 1000
  26. /* Have release address at the end of 256MB for now */
  27. #define CPU_RELEASE_ADDR 0xFFFFFF0
  28. #define CONFIG_SYS_INIT_SP_ADDR CONFIG_SYS_TEXT_BASE
  29. /* Generic Timer Definitions - setup in EL3. Setup by ATF for other cases */
  30. #if !defined(COUNTER_FREQUENCY)
  31. # define COUNTER_FREQUENCY 100000000
  32. #endif
  33. /* Size of malloc() pool */
  34. #define CONFIG_SYS_MALLOC_LEN (CONFIG_ENV_SIZE + 0x2000000)
  35. /* Serial setup */
  36. #define CONFIG_ARM_DCC
  37. #define CONFIG_CPU_ARMV8
  38. #define CONFIG_ZYNQ_SERIAL
  39. #define CONFIG_CONS_INDEX 0
  40. #define CONFIG_BAUDRATE 115200
  41. #define CONFIG_SYS_BAUDRATE_TABLE \
  42. { 4800, 9600, 19200, 38400, 57600, 115200 }
  43. /* Command line configuration */
  44. #define CONFIG_CMD_ENV
  45. #define CONFIG_DOS_PARTITION
  46. #define CONFIG_EFI_PARTITION
  47. #ifndef CONFIG_SPL_BUILD
  48. # define CONFIG_ISO_PARTITION
  49. #endif
  50. #define CONFIG_MP
  51. /* BOOTP options */
  52. #define CONFIG_BOOTP_BOOTFILESIZE
  53. #define CONFIG_BOOTP_BOOTPATH
  54. #define CONFIG_BOOTP_GATEWAY
  55. #define CONFIG_BOOTP_HOSTNAME
  56. #define CONFIG_BOOTP_MAY_FAIL
  57. #define CONFIG_BOOTP_DNS
  58. #define CONFIG_BOOTP_PXE
  59. #define CONFIG_BOOTP_SUBNETMASK
  60. /* Diff from config_distro_defaults.h */
  61. #define CONFIG_SUPPORT_RAW_INITRD
  62. #if !defined(CONFIG_SPL_BUILD)
  63. #define CONFIG_ENV_VARS_UBOOT_CONFIG
  64. #endif
  65. #define CONFIG_AUTO_COMPLETE
  66. #if defined(CONFIG_ZYNQ_SDHCI)
  67. # define CONFIG_GENERIC_MMC
  68. # define CONFIG_SUPPORT_EMMC_BOOT
  69. # ifndef CONFIG_ZYNQ_SDHCI_MAX_FREQ
  70. # define CONFIG_ZYNQ_SDHCI_MAX_FREQ 200000000
  71. # endif
  72. #endif
  73. #if defined(CONFIG_ZYNQ_SDHCI) || defined(CONFIG_ZYNQMP_USB)
  74. # define CONFIG_FAT_WRITE
  75. #endif
  76. #ifdef CONFIG_NAND_ARASAN
  77. # define CONFIG_CMD_NAND_LOCK_UNLOCK
  78. # define CONFIG_SYS_MAX_NAND_DEVICE 1
  79. # define CONFIG_SYS_NAND_SELF_INIT
  80. # define CONFIG_SYS_NAND_ONFI_DETECTION
  81. # define CONFIG_MTD_DEVICE
  82. #endif
  83. /* Miscellaneous configurable options */
  84. #define CONFIG_SYS_LOAD_ADDR 0x8000000
  85. #if defined(CONFIG_ZYNQMP_USB)
  86. #define CONFIG_SYS_USB_XHCI_MAX_ROOT_PORTS 2
  87. #define CONFIG_USB_XHCI_ZYNQMP
  88. #define CONFIG_SYS_DFU_DATA_BUF_SIZE 0x1800000
  89. #define DFU_DEFAULT_POLL_TIMEOUT 300
  90. #define CONFIG_USB_CABLE_CHECK
  91. #define CONFIG_CMD_THOR_DOWNLOAD
  92. #define CONFIG_USB_FUNCTION_THOR
  93. #define CONFIG_THOR_RESET_OFF
  94. #define DFU_ALT_INFO_RAM \
  95. "dfu_ram_info=" \
  96. "setenv dfu_alt_info " \
  97. "Image ram $kernel_addr $kernel_size\\\\;" \
  98. "system.dtb ram $fdt_addr $fdt_size\0" \
  99. "dfu_ram=run dfu_ram_info && dfu 0 ram 0\0" \
  100. "thor_ram=run dfu_ram_info && thordown 0 ram 0\0"
  101. #define DFU_ALT_INFO \
  102. DFU_ALT_INFO_RAM
  103. #endif
  104. #if !defined(DFU_ALT_INFO)
  105. # define DFU_ALT_INFO
  106. #endif
  107. #define CONFIG_BOARD_LATE_INIT
  108. /* Do not preserve environment */
  109. #define CONFIG_ENV_IS_NOWHERE 1
  110. #define CONFIG_ENV_SIZE 0x1000
  111. /* Monitor Command Prompt */
  112. /* Console I/O Buffer Size */
  113. #define CONFIG_SYS_CBSIZE 2048
  114. #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + \
  115. sizeof(CONFIG_SYS_PROMPT) + 16)
  116. #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
  117. #define CONFIG_SYS_LONGHELP
  118. #define CONFIG_CMDLINE_EDITING
  119. #define CONFIG_SYS_MAXARGS 64
  120. /* Ethernet driver */
  121. #if defined(CONFIG_ZYNQ_GEM)
  122. # define CONFIG_NET_MULTI
  123. # define CONFIG_MII
  124. # define CONFIG_SYS_FAULT_ECHO_LINK_DOWN
  125. # define CONFIG_PHY_MARVELL
  126. # define CONFIG_PHY_NATSEMI
  127. # define CONFIG_PHY_TI
  128. # define CONFIG_PHY_GIGE
  129. # define CONFIG_PHY_VITESSE
  130. # define CONFIG_PHY_REALTEK
  131. # define PHY_ANEG_TIMEOUT 20000
  132. #endif
  133. /* I2C */
  134. #if defined(CONFIG_SYS_I2C_ZYNQ)
  135. # define CONFIG_SYS_I2C
  136. # define CONFIG_SYS_I2C_ZYNQ_SPEED 100000
  137. # define CONFIG_SYS_I2C_ZYNQ_SLAVE 0
  138. #endif
  139. /* EEPROM */
  140. #ifdef CONFIG_ZYNQMP_EEPROM
  141. # define CONFIG_CMD_EEPROM
  142. # define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 2
  143. # define CONFIG_SYS_I2C_EEPROM_ADDR 0x54
  144. # define CONFIG_SYS_EEPROM_PAGE_WRITE_BITS 4
  145. # define CONFIG_SYS_EEPROM_PAGE_WRITE_DELAY_MS 5
  146. # define CONFIG_SYS_EEPROM_SIZE (64 * 1024)
  147. #endif
  148. #ifdef CONFIG_SATA_CEVA
  149. #define CONFIG_LIBATA
  150. #define CONFIG_SCSI_AHCI
  151. #define CONFIG_SYS_SCSI_MAX_SCSI_ID 2
  152. #define CONFIG_SYS_SCSI_MAX_LUN 1
  153. #define CONFIG_SYS_SCSI_MAX_DEVICE (CONFIG_SYS_SCSI_MAX_SCSI_ID * \
  154. CONFIG_SYS_SCSI_MAX_LUN)
  155. #define CONFIG_SCSI
  156. #endif
  157. #define CONFIG_SYS_BOOTM_LEN (60 * 1024 * 1024)
  158. #define CONFIG_CMD_UNZIP
  159. #define CONFIG_BOARD_EARLY_INIT_R
  160. #define CONFIG_CLOCKS
  161. #define ENV_MEM_LAYOUT_SETTINGS \
  162. "fdt_high=10000000\0" \
  163. "initrd_high=10000000\0" \
  164. "fdt_addr_r=0x40000000\0" \
  165. "pxefile_addr_r=0x10000000\0" \
  166. "kernel_addr_r=0x18000000\0" \
  167. "scriptaddr=0x02000000\0" \
  168. "ramdisk_addr_r=0x02100000\0" \
  169. #if defined(CONFIG_ZYNQ_SDHCI)
  170. # define BOOT_TARGET_DEVICES_MMC(func) func(MMC, mmc, 0) func(MMC, mmc, 1)
  171. #else
  172. # define BOOT_TARGET_DEVICES_MMC(func)
  173. #endif
  174. #if defined(CONFIG_SATA_CEVA)
  175. # define BOOT_TARGET_DEVICES_SCSI(func) func(SCSI, scsi, 0)
  176. #else
  177. # define BOOT_TARGET_DEVICES_SCSI(func)
  178. #endif
  179. #if defined(CONFIG_ZYNQMP_USB)
  180. # define BOOT_TARGET_DEVICES_USB(func) func(USB, usb, 0) func(USB, usb, 1)
  181. #else
  182. # define BOOT_TARGET_DEVICES_USB(func)
  183. #endif
  184. #define BOOT_TARGET_DEVICES(func) \
  185. BOOT_TARGET_DEVICES_MMC(func) \
  186. BOOT_TARGET_DEVICES_USB(func) \
  187. BOOT_TARGET_DEVICES_SCSI(func) \
  188. func(PXE, pxe, na) \
  189. func(DHCP, dhcp, na)
  190. #include <config_distro_bootcmd.h>
  191. /* Initial environment variables */
  192. #ifndef CONFIG_EXTRA_ENV_SETTINGS
  193. #define CONFIG_EXTRA_ENV_SETTINGS \
  194. ENV_MEM_LAYOUT_SETTINGS \
  195. BOOTENV \
  196. DFU_ALT_INFO
  197. #endif
  198. /* SPL can't handle all huge variables - define just DFU */
  199. #if defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_DFU_SUPPORT)
  200. #undef CONFIG_EXTRA_ENV_SETTINGS
  201. # define CONFIG_EXTRA_ENV_SETTINGS \
  202. "dfu_alt_info_ram=uboot.bin ram 0x8000000 0x1000000;" \
  203. "atf-uboot.ub ram 0x10000000 0x1000000;" \
  204. "Image ram 0x80000 0x3f80000;" \
  205. "system.dtb ram 0x4000000 0x100000\0" \
  206. "dfu_bufsiz=0x1000\0"
  207. #endif
  208. #define CONFIG_SPL_TEXT_BASE 0xfffc0000
  209. #define CONFIG_SPL_STACK 0xfffffffc
  210. #define CONFIG_SPL_MAX_SIZE 0x40000
  211. /* Just random location in OCM */
  212. #define CONFIG_SPL_BSS_START_ADDR 0x0
  213. #define CONFIG_SPL_BSS_MAX_SIZE 0x80000
  214. #define CONFIG_SPL_FRAMEWORK
  215. #define CONFIG_SPL_BOARD_INIT
  216. #define CONFIG_SPL_RAM_DEVICE
  217. /* u-boot is like dtb */
  218. #define CONFIG_SPL_FS_LOAD_ARGS_NAME "u-boot.bin"
  219. #define CONFIG_SYS_SPL_ARGS_ADDR 0x8000000
  220. /* ATF is my kernel image */
  221. #define CONFIG_SPL_FS_LOAD_KERNEL_NAME "atf-uboot.ub"
  222. /* FIT load address for RAM boot */
  223. #define CONFIG_SPL_LOAD_FIT_ADDRESS 0x10000000
  224. /* MMC support */
  225. #ifdef CONFIG_ZYNQ_SDHCI
  226. # define CONFIG_SYS_MMCSD_FS_BOOT_PARTITION 1
  227. # define CONFIG_SYS_MMCSD_RAW_MODE_ARGS_SECTOR 0 /* unused */
  228. # define CONFIG_SYS_MMCSD_RAW_MODE_ARGS_SECTORS 0 /* unused */
  229. # define CONFIG_SYS_MMCSD_RAW_MODE_KERNEL_SECTOR 0 /* unused */
  230. # define CONFIG_SPL_FS_LOAD_PAYLOAD_NAME "u-boot.img"
  231. #endif
  232. #if defined(CONFIG_SPL_BUILD) && defined(CONFIG_SPL_DFU_SUPPORT)
  233. # undef CONFIG_CMD_BOOTD
  234. # define CONFIG_SPL_ENV_SUPPORT
  235. # define CONFIG_SPL_HASH_SUPPORT
  236. # define CONFIG_ENV_MAX_ENTRIES 10
  237. # define CONFIG_SYS_SPL_MALLOC_START 0x20000000
  238. # define CONFIG_SYS_SPL_MALLOC_SIZE 0x10000000
  239. #ifdef CONFIG_SPL_SYS_MALLOC_SIMPLE
  240. # error "Disable CONFIG_SPL_SYS_MALLOC_SIMPLE. Full malloc needs to be used"
  241. #endif
  242. #endif
  243. #endif /* __XILINX_ZYNQMP_H */