mx28evk.h 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. /*
  2. * (C) Copyright 2011 Freescale Semiconductor, Inc.
  3. * Author: Fabio Estevam <fabio.estevam@freescale.com>
  4. *
  5. * Based on m28evk.h:
  6. * Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
  7. * on behalf of DENX Software Engineering GmbH
  8. *
  9. * SPDX-License-Identifier: GPL-2.0+
  10. */
  11. #ifndef __CONFIGS_MX28EVK_H__
  12. #define __CONFIGS_MX28EVK_H__
  13. /* System configurations */
  14. #define CONFIG_MX28 /* i.MX28 SoC */
  15. #define CONFIG_MACH_TYPE MACH_TYPE_MX28EVK
  16. /* U-Boot Commands */
  17. #define CONFIG_SYS_NO_FLASH
  18. #define CONFIG_DOS_PARTITION
  19. #define CONFIG_CMD_DATE
  20. #define CONFIG_CMD_NAND
  21. #define CONFIG_CMD_NAND_TRIMFFS
  22. /* Memory configuration */
  23. #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */
  24. #define PHYS_SDRAM_1 0x40000000 /* Base address */
  25. #define PHYS_SDRAM_1_SIZE 0x40000000 /* Max 1 GB RAM */
  26. #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
  27. /* Environment */
  28. #ifndef CONFIG_ENV_IS_IN_SPI_FLASH
  29. #define CONFIG_ENV_SIZE (16 * 1024)
  30. #else
  31. #define CONFIG_ENV_SIZE (4 * 1024)
  32. #endif
  33. #define CONFIG_ENV_OVERWRITE
  34. /* Environment is in MMC */
  35. #if defined(CONFIG_CMD_MMC) && defined(CONFIG_ENV_IS_IN_MMC)
  36. #define CONFIG_ENV_OFFSET (256 * 1024)
  37. #define CONFIG_SYS_MMC_ENV_DEV 0
  38. #endif
  39. /* Environment is in NAND */
  40. #if defined(CONFIG_CMD_NAND) && defined(CONFIG_ENV_IS_IN_NAND)
  41. #define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE
  42. #define CONFIG_ENV_SECT_SIZE (128 * 1024)
  43. #define CONFIG_ENV_RANGE (512 * 1024)
  44. #define CONFIG_ENV_OFFSET 0x300000
  45. #define CONFIG_ENV_OFFSET_REDUND \
  46. (CONFIG_ENV_OFFSET + CONFIG_ENV_RANGE)
  47. #endif
  48. /* Environemnt is in SPI flash */
  49. #if defined(CONFIG_CMD_SF) && defined(CONFIG_ENV_IS_IN_SPI_FLASH)
  50. #define CONFIG_SYS_REDUNDAND_ENVIRONMENT
  51. #define CONFIG_ENV_OFFSET 0x40000 /* 256K */
  52. #define CONFIG_ENV_OFFSET_REDUND (CONFIG_ENV_OFFSET + CONFIG_ENV_SIZE)
  53. #define CONFIG_ENV_SECT_SIZE 0x1000
  54. #define CONFIG_ENV_SPI_CS 0
  55. #define CONFIG_ENV_SPI_BUS 2
  56. #define CONFIG_ENV_SPI_MAX_HZ 24000000
  57. #define CONFIG_ENV_SPI_MODE SPI_MODE_0
  58. #endif
  59. /* UBI and NAND partitioning */
  60. #ifdef CONFIG_CMD_NAND
  61. #define CONFIG_CMD_UBIFS
  62. #define CONFIG_CMD_MTDPARTS
  63. #define CONFIG_RBTREE
  64. #define CONFIG_LZO
  65. #define CONFIG_MTD_DEVICE
  66. #define CONFIG_MTD_PARTITIONS
  67. #define MTDIDS_DEFAULT "nand0=gpmi-nand"
  68. #define MTDPARTS_DEFAULT \
  69. "mtdparts=gpmi-nand:" \
  70. "3m(bootloader)ro," \
  71. "512k(environment)," \
  72. "512k(redundant-environment)," \
  73. "4m(kernel)," \
  74. "512k(fdt)," \
  75. "8m(ramdisk)," \
  76. "-(filesystem)"
  77. #endif
  78. /* FEC Ethernet on SoC */
  79. #ifdef CONFIG_CMD_NET
  80. #define CONFIG_FEC_MXC
  81. #define CONFIG_MX28_FEC_MAC_IN_OCOTP
  82. #endif
  83. /* RTC */
  84. #ifdef CONFIG_CMD_DATE
  85. #define CONFIG_RTC_MXS
  86. #endif
  87. /* USB */
  88. #ifdef CONFIG_CMD_USB
  89. #define CONFIG_EHCI_MXS_PORT1
  90. #define CONFIG_USB_MAX_CONTROLLER_COUNT 1
  91. #define CONFIG_USB_HOST_ETHER
  92. #define CONFIG_USB_ETHER_ASIX
  93. #define CONFIG_USB_ETHER_SMSC95XX
  94. #endif
  95. /* SPI */
  96. #ifdef CONFIG_CMD_SPI
  97. #define CONFIG_DEFAULT_SPI_BUS 2
  98. #define CONFIG_DEFAULT_SPI_MODE SPI_MODE_0
  99. /* SPI Flash */
  100. #ifdef CONFIG_CMD_SF
  101. #define CONFIG_SF_DEFAULT_BUS 2
  102. #define CONFIG_SF_DEFAULT_CS 0
  103. /* this may vary and depends on the installed chip */
  104. #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
  105. #define CONFIG_SF_DEFAULT_SPEED 24000000
  106. #endif
  107. #endif
  108. /* Framebuffer support */
  109. #ifdef CONFIG_VIDEO
  110. #define CONFIG_VIDEO_LOGO
  111. #define CONFIG_SPLASH_SCREEN
  112. #define CONFIG_CMD_BMP
  113. #define CONFIG_BMP_16BPP
  114. #define CONFIG_VIDEO_BMP_RLE8
  115. #define CONFIG_VIDEO_BMP_GZIP
  116. #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (512 << 10)
  117. #endif
  118. /* Boot Linux */
  119. #define CONFIG_BOOTFILE "uImage"
  120. #define CONFIG_LOADADDR 0x42000000
  121. #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
  122. /* Extra Environment */
  123. #define CONFIG_EXTRA_ENV_SETTINGS \
  124. "ubifs_file=filesystem.ubifs\0" \
  125. "update_nand_full_filename=u-boot.nand\0" \
  126. "update_nand_firmware_filename=u-boot.sb\0" \
  127. "update_nand_firmware_maxsz=0x100000\0" \
  128. "update_nand_stride=0x40\0" /* MX28 datasheet ch. 12.12 */ \
  129. "update_nand_count=0x4\0" /* MX28 datasheet ch. 12.12 */ \
  130. "update_nand_get_fcb_size=" /* Get size of FCB blocks */ \
  131. "nand device 0 ; " \
  132. "nand info ; " \
  133. "setexpr fcb_sz ${update_nand_stride} * ${update_nand_count};" \
  134. "setexpr update_nand_fcb ${fcb_sz} * ${nand_writesize}\0" \
  135. "update_nand_firmware_full=" /* Update FCB, DBBT and FW */ \
  136. "if tftp ${update_nand_full_filename} ; then " \
  137. "run update_nand_get_fcb_size ; " \
  138. "nand scrub -y 0x0 ${filesize} ; " \
  139. "nand write.raw ${loadaddr} 0x0 ${fcb_sz} ; " \
  140. "setexpr update_off ${loadaddr} + ${update_nand_fcb} ; " \
  141. "setexpr update_sz ${filesize} - ${update_nand_fcb} ; " \
  142. "nand write ${update_off} ${update_nand_fcb} ${update_sz} ; " \
  143. "fi\0" \
  144. "update_nand_firmware=" /* Update only firmware */ \
  145. "if tftp ${update_nand_firmware_filename} ; then " \
  146. "run update_nand_get_fcb_size ; " \
  147. "setexpr fcb_sz ${update_nand_fcb} * 2 ; " /* FCB + DBBT */ \
  148. "setexpr fw_sz ${update_nand_firmware_maxsz} * 2 ; " \
  149. "setexpr fw_off ${fcb_sz} + ${update_nand_firmware_maxsz};" \
  150. "nand erase ${fcb_sz} ${fw_sz} ; " \
  151. "nand write ${loadaddr} ${fcb_sz} ${filesize} ; " \
  152. "nand write ${loadaddr} ${fw_off} ${filesize} ; " \
  153. "fi\0" \
  154. "update_nand_kernel=" /* Update kernel */ \
  155. "mtdparts default; " \
  156. "nand erase.part kernel; " \
  157. "if test ${ip_dyn} = yes; then " \
  158. "setenv get_cmd dhcp; " \
  159. "else " \
  160. "setenv get_cmd tftp; " \
  161. "fi; " \
  162. "${get_cmd} ${image}; " \
  163. "nand write ${loadaddr} kernel ${filesize}\0" \
  164. "update_nand_fdt=" /* Update fdt */ \
  165. "mtdparts default; " \
  166. "nand erase.part fdt; " \
  167. "if test ${ip_dyn} = yes; then " \
  168. "setenv get_cmd dhcp; " \
  169. "else " \
  170. "setenv get_cmd tftp; " \
  171. "fi; " \
  172. "${get_cmd} ${fdt_file}; " \
  173. "nand write ${loadaddr} fdt ${filesize}\0" \
  174. "update_nand_filesystem=" /* Update filesystem */ \
  175. "mtdparts default; " \
  176. "nand erase.part filesystem; " \
  177. "if test ${ip_dyn} = yes; then " \
  178. "setenv get_cmd dhcp; " \
  179. "else " \
  180. "setenv get_cmd tftp; " \
  181. "fi; " \
  182. "${get_cmd} ${ubifs_file}; " \
  183. "ubi part filesystem; " \
  184. "ubi create filesystem; " \
  185. "ubi write ${loadaddr} filesystem ${filesize}\0" \
  186. "nandargs=setenv bootargs console=${console_mainline},${baudrate} " \
  187. "rootfstype=ubifs ubi.mtd=6 root=ubi0_0 ${mtdparts}\0" \
  188. "nandboot=" /* Boot from NAND */ \
  189. "mtdparts default; " \
  190. "run nandargs; " \
  191. "nand read ${loadaddr} kernel 0x00400000; " \
  192. "if test ${boot_fdt} = yes; then " \
  193. "nand read ${fdt_addr} fdt 0x00080000; " \
  194. "bootz ${loadaddr} - ${fdt_addr}; " \
  195. "else " \
  196. "if test ${boot_fdt} = no; then " \
  197. "bootz; " \
  198. "else " \
  199. "echo \"ERROR: Set boot_fdt to yes or no.\"; " \
  200. "fi; " \
  201. "fi\0" \
  202. "update_sd_firmware_filename=u-boot.sd\0" \
  203. "update_sd_firmware=" /* Update the SD firmware partition */ \
  204. "if mmc rescan ; then " \
  205. "if tftp ${update_sd_firmware_filename} ; then " \
  206. "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \
  207. "setexpr fw_sz ${fw_sz} + 1 ; " \
  208. "mmc write ${loadaddr} 0x800 ${fw_sz} ; " \
  209. "fi ; " \
  210. "fi\0" \
  211. "script=boot.scr\0" \
  212. "image=zImage\0" \
  213. "console_fsl=ttyAM0\0" \
  214. "console_mainline=ttyAMA0\0" \
  215. "fdt_file=imx28-evk.dtb\0" \
  216. "fdt_addr=0x41000000\0" \
  217. "boot_fdt=try\0" \
  218. "ip_dyn=yes\0" \
  219. "mmcdev=0\0" \
  220. "mmcpart=2\0" \
  221. "mmcroot=/dev/mmcblk0p3 rw rootwait\0" \
  222. "mmcargs=setenv bootargs console=${console_mainline},${baudrate} " \
  223. "root=${mmcroot}\0" \
  224. "loadbootscript=" \
  225. "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
  226. "bootscript=echo Running bootscript from mmc ...; " \
  227. "source\0" \
  228. "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
  229. "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
  230. "mmcboot=echo Booting from mmc ...; " \
  231. "run mmcargs; " \
  232. "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
  233. "if run loadfdt; then " \
  234. "bootz ${loadaddr} - ${fdt_addr}; " \
  235. "else " \
  236. "if test ${boot_fdt} = try; then " \
  237. "bootz; " \
  238. "else " \
  239. "echo WARN: Cannot load the DT; " \
  240. "fi; " \
  241. "fi; " \
  242. "else " \
  243. "bootz; " \
  244. "fi;\0" \
  245. "netargs=setenv bootargs console=${console_mainline},${baudrate} " \
  246. "root=/dev/nfs " \
  247. "ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
  248. "netboot=echo Booting from net ...; " \
  249. "run netargs; " \
  250. "if test ${ip_dyn} = yes; then " \
  251. "setenv get_cmd dhcp; " \
  252. "else " \
  253. "setenv get_cmd tftp; " \
  254. "fi; " \
  255. "${get_cmd} ${image}; " \
  256. "if test ${boot_fdt} = yes; then " \
  257. "if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
  258. "bootz ${loadaddr} - ${fdt_addr}; " \
  259. "else " \
  260. "if test ${boot_fdt} = try; then " \
  261. "bootz; " \
  262. "else " \
  263. "echo WARN: Cannot load the DT; " \
  264. "fi;" \
  265. "fi; " \
  266. "else " \
  267. "bootz; " \
  268. "fi;\0"
  269. #define CONFIG_BOOTCOMMAND \
  270. "mmc dev ${mmcdev}; if mmc rescan; then " \
  271. "if run loadbootscript; then " \
  272. "run bootscript; " \
  273. "else " \
  274. "if run loadimage; then " \
  275. "run mmcboot; " \
  276. "else run netboot; " \
  277. "fi; " \
  278. "fi; " \
  279. "else run netboot; fi"
  280. /* The rest of the configuration is shared */
  281. #include <configs/mxs.h>
  282. #endif /* __CONFIGS_MX28EVK_H__ */