microblaze-generic.h 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. /*
  2. * (C) Copyright 2007-2010 Michal Simek
  3. *
  4. * Michal SIMEK <monstr@monstr.eu>
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #ifndef __CONFIG_H
  9. #define __CONFIG_H
  10. #include "../board/xilinx/microblaze-generic/xparameters.h"
  11. /* MicroBlaze CPU */
  12. #define MICROBLAZE_V5 1
  13. /* linear and spi flash memory */
  14. #ifdef XILINX_FLASH_START
  15. #define FLASH
  16. #undef SPIFLASH
  17. #undef RAMENV /* hold environment in flash */
  18. #else
  19. #ifdef XILINX_SPI_FLASH_BASEADDR
  20. #undef FLASH
  21. #define SPIFLASH
  22. #undef RAMENV /* hold environment in flash */
  23. #else
  24. #undef FLASH
  25. #undef SPIFLASH
  26. #define RAMENV /* hold environment in RAM */
  27. #endif
  28. #endif
  29. /* uart */
  30. # define CONFIG_BAUDRATE 115200
  31. /* The following table includes the supported baudrates */
  32. # define CONFIG_SYS_BAUDRATE_TABLE \
  33. {300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400}
  34. /* setting reset address */
  35. /*#define CONFIG_SYS_RESET_ADDRESS CONFIG_SYS_TEXT_BASE*/
  36. /* gpio */
  37. #ifdef XILINX_GPIO_BASEADDR
  38. # define CONFIG_XILINX_GPIO
  39. # define CONFIG_SYS_GPIO_0_ADDR XILINX_GPIO_BASEADDR
  40. #endif
  41. #define CONFIG_BOARD_LATE_INIT
  42. /* watchdog */
  43. #if defined(XILINX_WATCHDOG_BASEADDR) && defined(XILINX_WATCHDOG_IRQ)
  44. # define CONFIG_WATCHDOG_BASEADDR XILINX_WATCHDOG_BASEADDR
  45. # define CONFIG_WATCHDOG_IRQ XILINX_WATCHDOG_IRQ
  46. # ifndef CONFIG_SPL_BUILD
  47. # define CONFIG_HW_WATCHDOG
  48. # define CONFIG_XILINX_TB_WATCHDOG
  49. # endif
  50. #endif
  51. #define CONFIG_SYS_MALLOC_LEN 0xC0000
  52. /* Stack location before relocation */
  53. #define CONFIG_SYS_INIT_SP_OFFSET (CONFIG_SYS_TEXT_BASE - \
  54. CONFIG_SYS_MALLOC_F_LEN)
  55. /*
  56. * CFI flash memory layout - Example
  57. * CONFIG_SYS_FLASH_BASE = 0x2200_0000;
  58. * CONFIG_SYS_FLASH_SIZE = 0x0080_0000; 8MB
  59. *
  60. * SECT_SIZE = 0x20000; 128kB is one sector
  61. * CONFIG_ENV_SIZE = SECT_SIZE; 128kB environment store
  62. *
  63. * 0x2200_0000 CONFIG_SYS_FLASH_BASE
  64. * FREE 256kB
  65. * 0x2204_0000 CONFIG_ENV_ADDR
  66. * ENV_AREA 128kB
  67. * 0x2206_0000
  68. * FREE
  69. * 0x2280_0000 CONFIG_SYS_FLASH_BASE + CONFIG_SYS_FLASH_SIZE
  70. *
  71. */
  72. #ifdef FLASH
  73. # define CONFIG_SYS_FLASH_BASE XILINX_FLASH_START
  74. # define CONFIG_SYS_FLASH_SIZE XILINX_FLASH_SIZE
  75. # define CONFIG_SYS_FLASH_CFI 1
  76. # define CONFIG_FLASH_CFI_DRIVER 1
  77. /* ?empty sector */
  78. # define CONFIG_SYS_FLASH_EMPTY_INFO 1
  79. /* max number of memory banks */
  80. # define CONFIG_SYS_MAX_FLASH_BANKS 1
  81. /* max number of sectors on one chip */
  82. # define CONFIG_SYS_MAX_FLASH_SECT 512
  83. /* hardware flash protection */
  84. # define CONFIG_SYS_FLASH_PROTECTION
  85. /* use buffered writes (20x faster) */
  86. # define CONFIG_SYS_FLASH_USE_BUFFER_WRITE 1
  87. # ifdef RAMENV
  88. # define CONFIG_ENV_IS_NOWHERE 1
  89. # define CONFIG_ENV_SIZE 0x1000
  90. # define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SIZE)
  91. # else /* FLASH && !RAMENV */
  92. # define CONFIG_ENV_IS_IN_FLASH 1
  93. /* 128K(one sector) for env */
  94. # define CONFIG_ENV_SECT_SIZE 0x20000
  95. # define CONFIG_ENV_ADDR \
  96. (CONFIG_SYS_FLASH_BASE + (2 * CONFIG_ENV_SECT_SIZE))
  97. # define CONFIG_ENV_SIZE 0x20000
  98. # endif /* FLASH && !RAMBOOT */
  99. #else /* !FLASH */
  100. #ifdef SPIFLASH
  101. # define CONFIG_SYS_NO_FLASH 1
  102. # define CONFIG_SYS_SPI_BASE XILINX_SPI_FLASH_BASEADDR
  103. # define CONFIG_SPI 1
  104. # define CONFIG_SF_DEFAULT_MODE SPI_MODE_3
  105. # define CONFIG_SF_DEFAULT_SPEED XILINX_SPI_FLASH_MAX_FREQ
  106. # define CONFIG_SF_DEFAULT_CS XILINX_SPI_FLASH_CS
  107. # ifdef RAMENV
  108. # define CONFIG_ENV_IS_NOWHERE 1
  109. # define CONFIG_ENV_SIZE 0x1000
  110. # define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SIZE)
  111. # else /* SPIFLASH && !RAMENV */
  112. # define CONFIG_ENV_IS_IN_SPI_FLASH 1
  113. # define CONFIG_ENV_SPI_MODE SPI_MODE_3
  114. # define CONFIG_ENV_SPI_MAX_HZ CONFIG_SF_DEFAULT_SPEED
  115. # define CONFIG_ENV_SPI_CS CONFIG_SF_DEFAULT_CS
  116. /* 128K(two sectors) for env */
  117. # define CONFIG_ENV_SECT_SIZE 0x10000
  118. # define CONFIG_ENV_SIZE (2 * CONFIG_ENV_SECT_SIZE)
  119. /* Warning: adjust the offset in respect of other flash content and size */
  120. # define CONFIG_ENV_OFFSET (128 * CONFIG_ENV_SECT_SIZE) /* at 8MB */
  121. # endif /* SPIFLASH && !RAMBOOT */
  122. #else /* !SPIFLASH */
  123. /* ENV in RAM */
  124. # define CONFIG_SYS_NO_FLASH 1
  125. # define CONFIG_ENV_IS_NOWHERE 1
  126. # define CONFIG_ENV_SIZE 0x1000
  127. # define CONFIG_ENV_ADDR (CONFIG_SYS_MONITOR_BASE - CONFIG_ENV_SIZE)
  128. #endif /* !SPIFLASH */
  129. #endif /* !FLASH */
  130. #if defined(XILINX_USE_ICACHE)
  131. # define CONFIG_ICACHE
  132. #else
  133. # undef CONFIG_ICACHE
  134. #endif
  135. #if defined(XILINX_USE_DCACHE)
  136. # define CONFIG_DCACHE
  137. #else
  138. # undef CONFIG_DCACHE
  139. #endif
  140. #ifndef XILINX_DCACHE_BYTE_SIZE
  141. #define XILINX_DCACHE_BYTE_SIZE 32768
  142. #endif
  143. /*
  144. * BOOTP options
  145. */
  146. #define CONFIG_BOOTP_BOOTFILESIZE
  147. #define CONFIG_BOOTP_BOOTPATH
  148. #define CONFIG_BOOTP_GATEWAY
  149. #define CONFIG_BOOTP_HOSTNAME
  150. /*
  151. * Command line configuration.
  152. */
  153. #define CONFIG_CMD_IRQ
  154. #define CONFIG_CMD_MFSL
  155. #if defined(FLASH)
  156. # define CONFIG_CMD_JFFS2
  157. # undef CONFIG_CMD_UBIFS
  158. # if !defined(RAMENV)
  159. # define CONFIG_CMD_SAVES
  160. # endif
  161. #else
  162. #if defined(SPIFLASH)
  163. # if !defined(RAMENV)
  164. # define CONFIG_CMD_SAVES
  165. # endif
  166. #else
  167. # undef CONFIG_CMD_JFFS2
  168. # undef CONFIG_CMD_UBIFS
  169. #endif
  170. #endif
  171. #if defined(CONFIG_CMD_JFFS2)
  172. # define CONFIG_MTD_PARTITIONS
  173. #endif
  174. #if defined(CONFIG_CMD_UBIFS)
  175. # define CONFIG_LZO
  176. #endif
  177. #if defined(CONFIG_CMD_UBI)
  178. # define CONFIG_MTD_PARTITIONS
  179. # define CONFIG_RBTREE
  180. #endif
  181. #if defined(CONFIG_MTD_PARTITIONS)
  182. /* MTD partitions */
  183. #define CONFIG_CMD_MTDPARTS /* mtdparts command line support */
  184. #define CONFIG_MTD_DEVICE /* needed for mtdparts commands */
  185. #define CONFIG_FLASH_CFI_MTD
  186. #define MTDIDS_DEFAULT "nor0=flash-0"
  187. /* default mtd partition table */
  188. #define MTDPARTS_DEFAULT "mtdparts=flash-0:256k(u-boot),"\
  189. "256k(env),3m(kernel),1m(romfs),"\
  190. "1m(cramfs),-(jffs2)"
  191. #endif
  192. /* size of console buffer */
  193. #define CONFIG_SYS_CBSIZE 512
  194. /* print buffer size */
  195. #define CONFIG_SYS_PBSIZE \
  196. (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
  197. /* max number of command args */
  198. #define CONFIG_SYS_MAXARGS 15
  199. #define CONFIG_SYS_LONGHELP
  200. /* default load address */
  201. #define CONFIG_SYS_LOAD_ADDR 0
  202. #define CONFIG_BOOTARGS "root=romfs"
  203. #define CONFIG_HOSTNAME XILINX_BOARD_NAME
  204. #define CONFIG_BOOTCOMMAND "base 0;tftp 11000000 image.img;bootm"
  205. #define CONFIG_IPADDR 192.168.0.3
  206. #define CONFIG_SERVERIP 192.168.0.5
  207. #define CONFIG_GATEWAYIP 192.168.0.1
  208. /* architecture dependent code */
  209. #define CONFIG_SYS_USR_EXCEP /* user exception */
  210. #define CONFIG_PREBOOT "echo U-BOOT for ${hostname};setenv preboot;echo"
  211. #define CONFIG_EXTRA_ENV_SETTINGS "unlock=yes\0" \
  212. "nor0=flash-0\0"\
  213. "mtdparts=mtdparts=flash-0:"\
  214. "256k(u-boot),256k(env),3m(kernel),"\
  215. "1m(romfs),1m(cramfs),-(jffs2)\0"\
  216. "nc=setenv stdout nc;"\
  217. "setenv stdin nc\0" \
  218. "serial=setenv stdout serial;"\
  219. "setenv stdin serial\0"
  220. #define CONFIG_CMDLINE_EDITING
  221. /* Enable flat device tree support */
  222. #define CONFIG_LMB 1
  223. #if defined(CONFIG_XILINX_AXIEMAC)
  224. # define CONFIG_MII 1
  225. # define CONFIG_PHY_GIGE 1
  226. # define CONFIG_SYS_FAULT_ECHO_LINK_DOWN 1
  227. # define CONFIG_PHY_ATHEROS 1
  228. # define CONFIG_PHY_BROADCOM 1
  229. # define CONFIG_PHY_DAVICOM 1
  230. # define CONFIG_PHY_LXT 1
  231. # define CONFIG_PHY_MARVELL 1
  232. # define CONFIG_PHY_MICREL 1
  233. # define CONFIG_PHY_MICREL_KSZ9021
  234. # define CONFIG_PHY_NATSEMI 1
  235. # define CONFIG_PHY_REALTEK 1
  236. # define CONFIG_PHY_VITESSE 1
  237. #else
  238. # undef CONFIG_MII
  239. #endif
  240. /* SPL part */
  241. #define CONFIG_CMD_SPL
  242. #define CONFIG_SPL_FRAMEWORK
  243. #define CONFIG_SPL_BOARD_INIT
  244. #define CONFIG_SPL_LDSCRIPT "arch/microblaze/cpu/u-boot-spl.lds"
  245. #define CONFIG_SPL_RAM_DEVICE
  246. #ifdef CONFIG_SYS_FLASH_BASE
  247. # define CONFIG_SYS_UBOOT_BASE CONFIG_SYS_FLASH_BASE
  248. #endif
  249. /* for booting directly linux */
  250. #define CONFIG_SYS_FDT_BASE (CONFIG_SYS_FLASH_BASE + \
  251. 0x40000)
  252. #define CONFIG_SYS_FDT_SIZE (16<<10)
  253. #define CONFIG_SYS_SPL_ARGS_ADDR (CONFIG_SYS_TEXT_BASE + \
  254. 0x1000000)
  255. /* SP location before relocation, must use scratch RAM */
  256. /* BRAM start */
  257. #define CONFIG_SYS_INIT_RAM_ADDR 0x0
  258. /* BRAM size - will be generated */
  259. #define CONFIG_SYS_INIT_RAM_SIZE 0x100000
  260. # define CONFIG_SPL_STACK_ADDR (CONFIG_SYS_INIT_RAM_ADDR + \
  261. CONFIG_SYS_INIT_RAM_SIZE - \
  262. CONFIG_SYS_MALLOC_F_LEN)
  263. /* Just for sure that there is a space for stack */
  264. #define CONFIG_SPL_STACK_SIZE 0x100
  265. #define CONFIG_SYS_UBOOT_START CONFIG_SYS_TEXT_BASE
  266. #define CONFIG_SPL_MAX_FOOTPRINT (CONFIG_SYS_INIT_RAM_SIZE - \
  267. CONFIG_SYS_INIT_RAM_ADDR - \
  268. CONFIG_SYS_MALLOC_F_LEN - \
  269. CONFIG_SPL_STACK_SIZE)
  270. #endif /* __CONFIG_H */