m28evk.h 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263
  1. /*
  2. * Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
  3. * on behalf of DENX Software Engineering GmbH
  4. *
  5. * SPDX-License-Identifier: GPL-2.0+
  6. */
  7. #ifndef __CONFIGS_M28EVK_H__
  8. #define __CONFIGS_M28EVK_H__
  9. /* System configurations */
  10. #define CONFIG_MX28 /* i.MX28 SoC */
  11. #define MACH_TYPE_M28EVK 3613
  12. #define CONFIG_MACH_TYPE MACH_TYPE_M28EVK
  13. #define CONFIG_TIMESTAMP /* Print image info with timestamp */
  14. /* U-Boot Commands */
  15. #define CONFIG_SYS_NO_FLASH
  16. #define CONFIG_DOS_PARTITION
  17. #define CONFIG_FAT_WRITE
  18. #define CONFIG_CMD_BMP
  19. #define CONFIG_CMD_DATE
  20. #define CONFIG_CMD_EEPROM
  21. #define CONFIG_CMD_NAND
  22. #define CONFIG_CMD_NAND_TRIMFFS
  23. /* Memory configuration */
  24. #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */
  25. #define PHYS_SDRAM_1 0x40000000 /* Base address */
  26. #define PHYS_SDRAM_1_SIZE 0x20000000 /* Max 512 MB RAM */
  27. #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
  28. /* Environment */
  29. #define CONFIG_ENV_SIZE (16 * 1024)
  30. #define CONFIG_ENV_IS_IN_NAND
  31. /* Environment is in NAND */
  32. #if defined(CONFIG_CMD_NAND) && defined(CONFIG_ENV_IS_IN_NAND)
  33. #define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE
  34. #define CONFIG_ENV_SECT_SIZE (128 * 1024)
  35. #define CONFIG_ENV_RANGE (4 * CONFIG_ENV_SECT_SIZE)
  36. #define CONFIG_ENV_OFFSET (24 * CONFIG_ENV_SECT_SIZE) /* 3 MiB */
  37. #define CONFIG_ENV_OFFSET_REDUND \
  38. (CONFIG_ENV_OFFSET + CONFIG_ENV_RANGE)
  39. #define CONFIG_CMD_UBIFS
  40. #define CONFIG_CMD_MTDPARTS
  41. #define CONFIG_RBTREE
  42. #define CONFIG_LZO
  43. #define CONFIG_MTD_DEVICE
  44. #define CONFIG_MTD_PARTITIONS
  45. #define MTDIDS_DEFAULT "nand0=gpmi-nand"
  46. #define MTDPARTS_DEFAULT \
  47. "mtdparts=gpmi-nand:" \
  48. "3m(u-boot)," \
  49. "512k(env1)," \
  50. "512k(env2)," \
  51. "14m(boot)," \
  52. "238m(data)," \
  53. "-@4096k(UBI)"
  54. #else
  55. #define CONFIG_ENV_IS_NOWHERE
  56. #endif
  57. /* FEC Ethernet on SoC */
  58. #ifdef CONFIG_CMD_NET
  59. #define CONFIG_FEC_MXC
  60. #endif
  61. /* EEPROM */
  62. #ifdef CONFIG_CMD_EEPROM
  63. #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 2
  64. #endif
  65. /* RTC */
  66. #ifdef CONFIG_CMD_DATE
  67. /* Use the internal RTC in the MXS chip */
  68. #define CONFIG_RTC_INTERNAL
  69. #ifdef CONFIG_RTC_INTERNAL
  70. #define CONFIG_RTC_MXS
  71. #else
  72. #define CONFIG_RTC_M41T62
  73. #define CONFIG_SYS_I2C_RTC_ADDR 0x68
  74. #define CONFIG_SYS_M41T11_BASE_YEAR 2000
  75. #endif
  76. #endif
  77. /* USB */
  78. #ifdef CONFIG_CMD_USB
  79. #define CONFIG_EHCI_MXS_PORT0
  80. #define CONFIG_EHCI_MXS_PORT1
  81. #define CONFIG_USB_MAX_CONTROLLER_COUNT 2
  82. #endif
  83. /* SPI */
  84. #ifdef CONFIG_CMD_SPI
  85. #define CONFIG_DEFAULT_SPI_BUS 2
  86. #define CONFIG_DEFAULT_SPI_CS 0
  87. #define CONFIG_DEFAULT_SPI_MODE SPI_MODE_0
  88. /* SPI FLASH */
  89. #ifdef CONFIG_CMD_SF
  90. #define CONFIG_SF_DEFAULT_BUS 2
  91. #define CONFIG_SF_DEFAULT_CS 0
  92. #define CONFIG_SF_DEFAULT_SPEED 40000000
  93. #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
  94. #define CONFIG_ENV_SPI_BUS 2
  95. #define CONFIG_ENV_SPI_CS 0
  96. #define CONFIG_ENV_SPI_MAX_HZ 40000000
  97. #define CONFIG_ENV_SPI_MODE SPI_MODE_0
  98. #endif
  99. #endif
  100. /* LCD */
  101. #ifdef CONFIG_VIDEO
  102. #define CONFIG_VIDEO_LOGO
  103. #define CONFIG_SPLASH_SCREEN
  104. #define CONFIG_CMD_BMP
  105. #define CONFIG_BMP_16BPP
  106. #define CONFIG_VIDEO_BMP_RLE8
  107. #define CONFIG_VIDEO_BMP_GZIP
  108. #define CONFIG_SYS_VIDEO_LOGO_MAX_SIZE (2 << 20)
  109. #endif
  110. /* Booting Linux */
  111. #define CONFIG_BOOTFILE "fitImage"
  112. #define CONFIG_BOOTARGS "console=ttyAMA0,115200n8 "
  113. #define CONFIG_BOOTCOMMAND "run mmc_mmc"
  114. #define CONFIG_LOADADDR 0x42000000
  115. #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
  116. /* Extra Environment */
  117. #define CONFIG_PREBOOT "run try_bootscript"
  118. #define CONFIG_HOSTNAME m28evk
  119. #define CONFIG_EXTRA_ENV_SETTINGS \
  120. "consdev=ttyAMA0\0" \
  121. "baudrate=115200\0" \
  122. "bootscript=boot.scr\0" \
  123. "bootdev=/dev/mmcblk0p2\0" \
  124. "rootdev=/dev/mmcblk0p3\0" \
  125. "netdev=eth0\0" \
  126. "hostname=m28evk\0" \
  127. "rootpath=/opt/eldk-5.5/armv5te/rootfs-qte-sdk\0" \
  128. "kernel_addr_r=0x42000000\0" \
  129. "videomode=video=ctfb:x:800,y:480,depth:18,mode:0,pclk:30066," \
  130. "le:0,ri:256,up:0,lo:45,hs:1,vs:1,sync:100663296," \
  131. "vmode:0\0" \
  132. "update_nand_full_filename=u-boot.nand\0" \
  133. "update_nand_firmware_filename=u-boot.sb\0" \
  134. "update_sd_firmware_filename=u-boot.sd\0" \
  135. "update_nand_firmware_maxsz=0x100000\0" \
  136. "update_nand_stride=0x40\0" /* MX28 datasheet ch. 12.12 */ \
  137. "update_nand_count=0x4\0" /* MX28 datasheet ch. 12.12 */ \
  138. "update_nand_get_fcb_size=" /* Get size of FCB blocks */ \
  139. "nand device 0 ; " \
  140. "nand info ; " \
  141. "setexpr fcb_sz ${update_nand_stride} * ${update_nand_count};" \
  142. "setexpr update_nand_fcb ${fcb_sz} * ${nand_writesize}\0" \
  143. "update_nand_full=" /* Update FCB, DBBT and FW */ \
  144. "if tftp ${update_nand_full_filename} ; then " \
  145. "run update_nand_get_fcb_size ; " \
  146. "nand scrub -y 0x0 ${filesize} ; " \
  147. "nand write.raw ${loadaddr} 0x0 ${fcb_sz} ; " \
  148. "setexpr update_off ${loadaddr} + ${update_nand_fcb} ; " \
  149. "setexpr update_sz ${filesize} - ${update_nand_fcb} ; " \
  150. "nand write ${update_off} ${update_nand_fcb} ${update_sz} ; " \
  151. "fi\0" \
  152. "update_nand_firmware=" /* Update only firmware */ \
  153. "if tftp ${update_nand_firmware_filename} ; then " \
  154. "run update_nand_get_fcb_size ; " \
  155. "setexpr fcb_sz ${update_nand_fcb} * 2 ; " /* FCB + DBBT */ \
  156. "setexpr fw_sz ${update_nand_firmware_maxsz} * 2 ; " \
  157. "setexpr fw_off ${fcb_sz} + ${update_nand_firmware_maxsz};" \
  158. "nand erase ${fcb_sz} ${fw_sz} ; " \
  159. "nand write ${loadaddr} ${fcb_sz} ${filesize} ; " \
  160. "nand write ${loadaddr} ${fw_off} ${filesize} ; " \
  161. "fi\0" \
  162. "update_sd_firmware=" /* Update the SD firmware partition */ \
  163. "if mmc rescan ; then " \
  164. "if tftp ${update_sd_firmware_filename} ; then " \
  165. "setexpr fw_sz ${filesize} / 0x200 ; " /* SD block size */ \
  166. "setexpr fw_sz ${fw_sz} + 1 ; " \
  167. "mmc write ${loadaddr} 0x800 ${fw_sz} ; " \
  168. "fi ; " \
  169. "fi\0" \
  170. "addcons=" \
  171. "setenv bootargs ${bootargs} " \
  172. "console=${consdev},${baudrate}\0" \
  173. "addip=" \
  174. "setenv bootargs ${bootargs} " \
  175. "ip=${ipaddr}:${serverip}:${gatewayip}:" \
  176. "${netmask}:${hostname}:${netdev}:off\0" \
  177. "addmisc=" \
  178. "setenv bootargs ${bootargs} ${miscargs}\0" \
  179. "adddfltmtd=" \
  180. "if test \"x${mtdparts}\" == \"x\" ; then " \
  181. "mtdparts default ; " \
  182. "fi\0" \
  183. "addmtd=" \
  184. "run adddfltmtd ; " \
  185. "setenv bootargs ${bootargs} ${mtdparts}\0" \
  186. "addargs=run addcons addmtd addmisc\0" \
  187. "mmcload=" \
  188. "mmc rescan ; " \
  189. "load mmc 0:2 ${kernel_addr_r} ${bootfile}\0" \
  190. "ubiload=" \
  191. "ubi part UBI ; ubifsmount ubi0:rootfs ; " \
  192. "ubifsload ${kernel_addr_r} /boot/${bootfile}\0" \
  193. "netload=" \
  194. "tftp ${kernel_addr_r} ${hostname}/${bootfile}\0" \
  195. "miscargs=nohlt panic=1\0" \
  196. "mmcargs=setenv bootargs root=${rootdev} rw rootwait\0" \
  197. "ubiargs=" \
  198. "setenv bootargs ubi.mtd=5 " \
  199. "root=ubi0:rootfs rootfstype=ubifs\0" \
  200. "nfsargs=" \
  201. "setenv bootargs root=/dev/nfs rw " \
  202. "nfsroot=${serverip}:${rootpath},v3,tcp\0" \
  203. "mmc_mmc=" \
  204. "run mmcload mmcargs addargs ; " \
  205. "bootm ${kernel_addr_r}\0" \
  206. "mmc_ubi=" \
  207. "run mmcload ubiargs addargs ; " \
  208. "bootm ${kernel_addr_r}\0" \
  209. "mmc_nfs=" \
  210. "run mmcload nfsargs addip addargs ; " \
  211. "bootm ${kernel_addr_r}\0" \
  212. "ubi_mmc=" \
  213. "run ubiload mmcargs addargs ; " \
  214. "bootm ${kernel_addr_r}\0" \
  215. "ubi_ubi=" \
  216. "run ubiload ubiargs addargs ; " \
  217. "bootm ${kernel_addr_r}\0" \
  218. "ubi_nfs=" \
  219. "run ubiload nfsargs addip addargs ; " \
  220. "bootm ${kernel_addr_r}\0" \
  221. "net_mmc=" \
  222. "run netload mmcargs addargs ; " \
  223. "bootm ${kernel_addr_r}\0" \
  224. "net_ubi=" \
  225. "run netload ubiargs addargs ; " \
  226. "bootm ${kernel_addr_r}\0" \
  227. "net_nfs=" \
  228. "run netload nfsargs addip addargs ; " \
  229. "bootm ${kernel_addr_r}\0" \
  230. "try_bootscript=" \
  231. "mmc rescan;" \
  232. "if test -e mmc 0:2 ${bootscript} ; then " \
  233. "if load mmc 0:2 ${kernel_addr_r} ${bootscript};" \
  234. "then ; " \
  235. "echo Running bootscript... ; " \
  236. "source ${kernel_addr_r} ; " \
  237. "fi ; " \
  238. "fi\0"
  239. /* The rest of the configuration is shared */
  240. #include <configs/mxs.h>
  241. #endif /* __CONFIGS_M28EVK_H__ */