apx4devkit.h 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. /*
  2. * Copyright (C) 2012 Bluegiga Technologies Oy
  3. *
  4. * Authors:
  5. * Veli-Pekka Peltola <veli-pekka.peltola@bluegiga.com>
  6. * Lauri Hintsala <lauri.hintsala@bluegiga.com>
  7. *
  8. * Based on m28evk.h:
  9. * Copyright (C) 2011 Marek Vasut <marek.vasut@gmail.com>
  10. * on behalf of DENX Software Engineering GmbH
  11. *
  12. * This program is free software; you can redistribute it and/or
  13. * modify it under the terms of the GNU General Public License as
  14. * published by the Free Software Foundation; either version 2 of
  15. * the License, or (at your option) any later version.
  16. *
  17. * This program is distributed in the hope that it will be useful,
  18. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  19. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  20. * GNU General Public License for more details.
  21. */
  22. #ifndef __CONFIG_H
  23. #define __CONFIG_H
  24. #include <asm/arch/regs-base.h>
  25. /* SoC configurations */
  26. #define CONFIG_MX28 /* i.MX28 SoC */
  27. #define CONFIG_MXS_GPIO /* GPIO control */
  28. #define CONFIG_SYS_HZ 1000 /* Ticks per second */
  29. #define MACH_TYPE_APX4DEVKIT 3712
  30. #define CONFIG_MACH_TYPE MACH_TYPE_APX4DEVKIT
  31. #define CONFIG_SYS_NO_FLASH
  32. #define CONFIG_SYS_ICACHE_OFF
  33. #define CONFIG_SYS_DCACHE_OFF
  34. #define CONFIG_BOARD_EARLY_INIT_F
  35. #define CONFIG_ARCH_CPU_INIT
  36. #define CONFIG_ARCH_MISC_INIT
  37. /* SPL */
  38. #define CONFIG_SPL
  39. #define CONFIG_SPL_NO_CPU_SUPPORT_CODE
  40. #define CONFIG_SPL_START_S_PATH "arch/arm/cpu/arm926ejs/mx28"
  41. #define CONFIG_SPL_LDSCRIPT "arch/arm/cpu/arm926ejs/mx28/u-boot-spl.lds"
  42. #define CONFIG_SPL_LIBCOMMON_SUPPORT
  43. #define CONFIG_SPL_LIBGENERIC_SUPPORT
  44. #define CONFIG_SPL_GPIO_SUPPORT
  45. /* U-Boot Commands */
  46. #include <config_cmd_default.h>
  47. #define CONFIG_DISPLAY_CPUINFO
  48. #define CONFIG_DOS_PARTITION
  49. #define CONFIG_CMD_CACHE
  50. #define CONFIG_CMD_DATE
  51. #define CONFIG_CMD_DHCP
  52. #define CONFIG_CMD_EXT2
  53. #define CONFIG_CMD_FAT
  54. #define CONFIG_CMD_I2C
  55. #define CONFIG_CMD_MII
  56. #define CONFIG_CMD_MMC
  57. #define CONFIG_CMD_NAND
  58. #define CONFIG_CMD_NET
  59. #define CONFIG_CMD_NFS
  60. #define CONFIG_CMD_PING
  61. #define CONFIG_CMD_SAVEENV
  62. #define CONFIG_CMD_USB
  63. /* Memory configurations */
  64. #define CONFIG_NR_DRAM_BANKS 1 /* 1 bank of DRAM */
  65. #define PHYS_SDRAM_1 0x40000000 /* Base address */
  66. #define PHYS_SDRAM_1_SIZE 0x20000000 /* Max 512 MB RAM */
  67. #define CONFIG_SYS_MALLOC_LEN 0x00400000 /* 4 MB for malloc */
  68. #define CONFIG_SYS_MEMTEST_START 0x40000000 /* Memtest start adr */
  69. #define CONFIG_SYS_MEMTEST_END 0x40400000 /* 4 MB RAM test */
  70. #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM_1
  71. /* Point initial SP in SRAM so SPL can use it too. */
  72. #define CONFIG_SYS_INIT_RAM_ADDR 0x00000000
  73. #define CONFIG_SYS_INIT_RAM_SIZE (128 * 1024)
  74. #define CONFIG_SYS_INIT_SP_OFFSET \
  75. (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
  76. #define CONFIG_SYS_INIT_SP_ADDR \
  77. (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
  78. /*
  79. * We need to sacrifice first 4 bytes of RAM here to avoid triggering some
  80. * strange BUG in ROM corrupting first 4 bytes of RAM when loading U-Boot
  81. * binary. In case there was more of this mess, 0x100 bytes are skipped.
  82. */
  83. #define CONFIG_SYS_TEXT_BASE 0x40000100
  84. #define CONFIG_ENV_OVERWRITE
  85. /* U-Boot general configurations */
  86. #define CONFIG_SYS_LONGHELP
  87. #define CONFIG_SYS_PROMPT "=> "
  88. #define CONFIG_SYS_CBSIZE 1024 /* Console I/O buffer size */
  89. #define CONFIG_SYS_PBSIZE \
  90. (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
  91. /* Print buffer size */
  92. #define CONFIG_SYS_MAXARGS 32 /* Max number of command args */
  93. #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
  94. /* Boot argument buffer size */
  95. #define CONFIG_VERSION_VARIABLE /* U-Boot version */
  96. #define CONFIG_AUTO_COMPLETE /* Command auto complete */
  97. #define CONFIG_CMDLINE_EDITING /* Command history etc. */
  98. #define CONFIG_SYS_HUSH_PARSER
  99. #define CONFIG_SYS_PROMPT_HUSH_PS2 "> "
  100. #define CONFIG_OF_LIBFDT
  101. #define CONFIG_ENV_IS_IN_NAND
  102. /* Serial Driver */
  103. #define CONFIG_PL011_SERIAL
  104. #define CONFIG_PL011_CLOCK 24000000
  105. #define CONFIG_PL01x_PORTS { (void *)MXS_UARTDBG_BASE }
  106. #define CONFIG_CONS_INDEX 0
  107. #define CONFIG_BAUDRATE 115200 /* Default baud rate */
  108. #define CONFIG_SYS_BAUDRATE_TABLE { 9600, 19200, 38400, 57600, 115200 }
  109. /* DMA */
  110. #define CONFIG_APBH_DMA
  111. /* MMC Driver */
  112. #ifdef CONFIG_ENV_IS_IN_MMC
  113. #define CONFIG_ENV_OFFSET (256 * 1024)
  114. #define CONFIG_ENV_SIZE (16 * 1024)
  115. #define CONFIG_SYS_MMC_ENV_DEV 0
  116. #endif
  117. #ifdef CONFIG_CMD_MMC
  118. #define CONFIG_MMC
  119. #define CONFIG_GENERIC_MMC
  120. #define CONFIG_MMC_BOUNCE_BUFFER
  121. #define CONFIG_MXS_MMC
  122. #endif
  123. /* NAND Driver */
  124. #ifdef CONFIG_ENV_IS_IN_NAND
  125. #define CONFIG_ENV_SECT_SIZE (128 * 1024)
  126. #define CONFIG_ENV_SIZE (128 * 1024)
  127. #define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE
  128. #define CONFIG_ENV_RANGE (384 * 1024)
  129. #define CONFIG_ENV_OFFSET 0x120000
  130. #define CONFIG_ENV_OFFSET_REDUND \
  131. (CONFIG_ENV_OFFSET + CONFIG_ENV_RANGE)
  132. #endif
  133. #ifdef CONFIG_CMD_NAND
  134. #define CONFIG_NAND_MXS
  135. #define CONFIG_SYS_MAX_NAND_DEVICE 1
  136. #define CONFIG_SYS_NAND_BASE 0x60000000
  137. #define CONFIG_SYS_NAND_5_ADDR_CYCLE
  138. #define CONFIG_CMD_UBI
  139. #define CONFIG_CMD_UBIFS
  140. #define CONFIG_CMD_MTDPARTS
  141. #define CONFIG_RBTREE
  142. #define CONFIG_LZO
  143. #define CONFIG_MTD_DEVICE
  144. #define CONFIG_MTD_PARTITIONS
  145. #define MTDIDS_DEFAULT "nand0=gpmi-nand"
  146. #define MTDPARTS_DEFAULT \
  147. "mtdparts=gpmi-nand:128k(bootstrap),1024k(boot),768k(env),-(root)"
  148. #else
  149. #define MTDPARTS_DEFAULT ""
  150. #endif
  151. /* Ethernet on SOC (FEC) */
  152. #ifdef CONFIG_CMD_NET
  153. #define CONFIG_NET_MULTI
  154. #define CONFIG_ETHPRIME "FEC"
  155. #define CONFIG_FEC_MXC
  156. #define CONFIG_FEC_MXC_PHYADDR 0
  157. #define IMX_FEC_BASE MXS_ENET0_BASE
  158. #define CONFIG_MII
  159. #define CONFIG_DISCOVER_PHY
  160. #define CONFIG_FEC_XCV_TYPE RMII
  161. #endif
  162. /* USB */
  163. #ifdef CONFIG_CMD_USB
  164. #define CONFIG_USB_EHCI
  165. #define CONFIG_USB_EHCI_MXS
  166. #define CONFIG_EHCI_MXS_PORT 1
  167. #define CONFIG_EHCI_IS_TDI
  168. #define CONFIG_USB_STORAGE
  169. #endif
  170. /* I2C */
  171. #ifdef CONFIG_CMD_I2C
  172. #define CONFIG_I2C_MXS
  173. #define CONFIG_HARD_I2C
  174. #define CONFIG_SYS_I2C_SPEED 400000
  175. #endif
  176. /* RTC */
  177. #if defined(CONFIG_CMD_DATE)
  178. #define CONFIG_RTC_PCF8563
  179. #define CONFIG_SYS_I2C_RTC_ADDR 0x51
  180. #endif
  181. /* Boot Linux */
  182. #define CONFIG_CMDLINE_TAG
  183. #define CONFIG_SETUP_MEMORY_TAGS
  184. #define CONFIG_BOOTDELAY 1
  185. #define CONFIG_BOOTFILE "uImage"
  186. #define CONFIG_BOOTCOMMAND "run bootcmd_nand"
  187. #define CONFIG_LOADADDR 0x41000000
  188. #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
  189. #define CONFIG_SERIAL_TAG
  190. #define CONFIG_REVISION_TAG
  191. /* Extra Environments */
  192. #define CONFIG_EXTRA_ENV_SETTINGS \
  193. "mtdparts=" MTDPARTS_DEFAULT "\0" \
  194. "verify=no\0" \
  195. "bootcmd=run bootcmd_nand\0" \
  196. "kernelargs=console=tty0 console=ttyAMA0,115200 consoleblank=0\0" \
  197. "bootargs_nand=" \
  198. "setenv bootargs ${kernelargs} ubi.mtd=3,2048 " \
  199. "root=ubi0:rootfs rootfstype=ubifs ${mtdparts} rw\0" \
  200. "bootcmd_nand=" \
  201. "run bootargs_nand && ubi part root 2048 && " \
  202. "ubifsmount rootfs && ubifsload 41000000 boot/uImage && " \
  203. "bootm 41000000\0" \
  204. "bootargs_mmc=" \
  205. "setenv bootargs ${kernelargs} " \
  206. "root=/dev/mmcblk0p2 rootwait ${mtdparts} rw\0" \
  207. "bootcmd_mmc=" \
  208. "run bootargs_mmc && mmc rescan && " \
  209. "ext2load mmc 0:2 41000000 boot/uImage && bootm 41000000\0" \
  210. ""
  211. #endif /* __CONFIG_H */