am335x_shc.h 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328
  1. /*
  2. * (C) Copyright 2016
  3. * Heiko Schocher, DENX Software Engineering, hs@denx.de.
  4. *
  5. * Based on:
  6. * am335x_evm.h
  7. *
  8. * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/
  9. *
  10. * SPDX-License-Identifier: GPL-2.0+
  11. */
  12. #ifndef __CONFIG_AM335X_SHC_H
  13. #define __CONFIG_AM335X_SHC_H
  14. #include <configs/ti_am335x_common.h>
  15. /* settings we don;t want on this board */
  16. #undef CONFIG_SPL_AM33XX_ENABLE_RTC32K_OSC
  17. #undef CONFIG_CMD_EXT4
  18. #undef CONFIG_CMD_EXT4_WRITE
  19. #undef CONFIG_CMD_MMC_SPI
  20. #undef CONFIG_CMD_SPI
  21. #define CONFIG_CMD_CACHE
  22. #ifndef CONFIG_SPL_BUILD
  23. # define CONFIG_TIMESTAMP
  24. # define CONFIG_LZO
  25. #endif
  26. #define CONFIG_SYS_BOOTM_LEN (16 << 20)
  27. #define MACH_TYPE_BOSCH_SHC_B 9001
  28. #define MACH_TYPE_BOSCH_SHC_B2 9002
  29. #define MACH_TYPE_BOSCH_SHC_C 9003
  30. #define MACH_TYPE_BOSCH_SHC_C2 9004
  31. #define MACH_TYPE_BOSCH_SHC_C3 9005
  32. #define MACH_TYPE_BOSCH_SHC 9006
  33. #ifdef CONFIG_B_SAMPLE
  34. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC_B
  35. #elif defined CONFIG_B2_SAMPLE
  36. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC_B2
  37. #elif defined CONFIG_C_SAMPLE
  38. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC_C
  39. #elif defined CONFIG_C2_SAMPLE
  40. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC_C2
  41. #elif defined CONFIG_C3_SAMPLE
  42. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC_C3
  43. #elif defined CONFIG_SERIES
  44. # define CONFIG_MACH_TYPE MACH_TYPE_BOSCH_SHC
  45. #endif /* #ifdef CONFIG_B_SAMPLE */
  46. #define CONFIG_BOARD_LATE_INIT
  47. /* Clock Defines */
  48. #define V_OSCK 24000000 /* Clock output from T2 */
  49. #define V_SCLK (V_OSCK)
  50. #define CONFIG_ENV_IS_IN_MMC 1
  51. /*
  52. * in case of SD Card or Network boot we want to have a possibility to
  53. * debrick the shc, therefore do not read environment from eMMC
  54. */
  55. #if defined(CONFIG_SHC_SDBOOT) || defined(CONFIG_SHC_NETBOOT)
  56. #define CONFIG_SYS_MMC_ENV_DEV 0
  57. #else
  58. #define CONFIG_SYS_MMC_ENV_DEV 1
  59. #endif
  60. /*
  61. * Info when using boot partitions: As environment resides within first
  62. * 128 kB, MLO must start at 128 kB == 0x20000
  63. * ENV at MMC Boot0 Partition - 0/Undefined=user, 1=boot0, 2=boot1,
  64. * 4..7=general0..3
  65. */
  66. #define CONFIG_ENV_SIZE 0x1000 /* 4 KB */
  67. #define CONFIG_ENV_OFFSET 0x7000 /* 28 kB */
  68. #define CONFIG_HSMMC2_8BIT
  69. #define CONFIG_ENV_OFFSET_REDUND 0x9000 /* 36 kB */
  70. #define CONFIG_ENV_SIZE_REDUND CONFIG_ENV_SIZE
  71. /* Enhance our eMMC support / experience. */
  72. #define CONFIG_CMD_GPT
  73. #define CONFIG_EFI_PARTITION
  74. #ifdef CONFIG_SPL_BUILD
  75. #undef CONFIG_ISO_PARTITION
  76. #endif
  77. #ifndef CONFIG_SHC_ICT
  78. /*
  79. * In builds other than ICT, reset to retry after timeout
  80. * Define a timeout after which a stopped bootloader continues autoboot
  81. * (only works with CONFIG_RESET_TO_RETRY)
  82. */
  83. # define CONFIG_BOOT_RETRY_TIME 30
  84. # define CONFIG_RESET_TO_RETRY
  85. #endif
  86. #define CONFIG_ENV_VARS_UBOOT_CONFIG
  87. #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
  88. #ifndef CONFIG_SPL_BUILD
  89. #define CONFIG_EXTRA_ENV_SETTINGS \
  90. "loadaddr=0x80200000\0" \
  91. "kloadaddr=0x84000000\0" \
  92. "fdtaddr=0x85000000\0" \
  93. "fdt_high=0xffffffff\0" \
  94. "rdaddr=0x81000000\0" \
  95. "bootfile=uImage\0" \
  96. "fdtfile=am335x-shc.dtb\0" \
  97. "verify=no\0" \
  98. "serverip=10.55.152.184\0" \
  99. "rootpath=/srv/nfs/shc-rootfs\0" \
  100. "console=ttyO0,115200n8\0" \
  101. "optargs=quiet\0" \
  102. "mmcdev=1\0" \
  103. "harakiri=0\0" \
  104. "mmcpart=2\0" \
  105. "active_root=root1\0" \
  106. "inactive_root=root2\0" \
  107. "mmcrootfstype=ext4 rootwait\0" \
  108. "nfsopts=nolock\0" \
  109. "static_ip=${ipaddr}:${serverip}:${gatewayip}:${netmask}:${hostname}" \
  110. "::off\0" \
  111. "ip_method=none\0" \
  112. "bootargs_defaults=setenv bootargs " \
  113. "console=${console} " \
  114. "${optargs}\0" \
  115. "mmcargs=run bootargs_defaults;" \
  116. "setenv bootargs ${bootargs} " \
  117. "root=${mmcroot} " \
  118. "rootfstype=${mmcrootfstype} ip=${ip_method}\0" \
  119. "netargs=setenv bootargs console=${console} " \
  120. "${optargs} " \
  121. "root=/dev/nfs " \
  122. "nfsroot=${serverip}:${rootpath},${nfsopts} rw " \
  123. "ip=dhcp\0" \
  124. "bootenv=uEnv.txt\0" \
  125. "loadbootenv=if fatload mmc ${mmcdev} ${loadaddr} ${bootenv}; then " \
  126. "echo Loaded environment from ${bootenv}; " \
  127. "run importbootenv; " \
  128. "fi;\0" \
  129. "importbootenv=echo Importing environment variables from uEnv.txt ...; " \
  130. "env import -t $loadaddr $filesize\0" \
  131. "loaduimagefat=fatload mmc ${mmcdev} ${kloadaddr} ${bootfile}\0" \
  132. "loaduimage=ext2load mmc ${mmcdev}:${mmcpart} ${kloadaddr} /boot/${bootfile}\0" \
  133. "loadfdt=ext2load mmc ${mmcdev}:${mmcpart} ${fdtaddr} /boot/${fdtfile}\0" \
  134. "netloaduimage=tftp ${loadaddr} ${bootfile}\0" \
  135. "netloadfdt=tftp ${fdtaddr} ${fdtfile}\0" \
  136. "mmcboot=echo Booting Linux from ${mmcdevice} ...; " \
  137. "run mmcargs; " \
  138. "if run loadfdt; then " \
  139. "echo device tree detected; " \
  140. "bootm ${kloadaddr} - ${fdtaddr}; " \
  141. "else " \
  142. "bootm ${kloadaddr}; " \
  143. "fi; \0" \
  144. "netboot=echo Booting from network ...; " \
  145. "setenv autoload no; " \
  146. "dhcp; " \
  147. "run netloaduimage; " \
  148. "run netargs; " \
  149. "echo NFS path: ${serverip}:${rootpath};" \
  150. "if run netloadfdt; then " \
  151. "echo device tree detected; " \
  152. "bootm ${loadaddr} - ${fdtaddr}; " \
  153. "else " \
  154. "bootm ${loadaddr}; " \
  155. "fi; \0" \
  156. "emmc_erase=if test ${harakiri} = 1 ; then echo erase emmc ...; setenv mmcdev 1; mmc erase 0 200; reset; fi; \0" \
  157. "mmcpart_gp=mmcpart gp 1 40; \0" \
  158. "mmcpart_enhance=mmcpart enhance 0 64; \0" \
  159. "mmcpart_rel_write=mmcpart rel_write 1f; \0" \
  160. "mmcpart_commit=mmcpart commit 1; \0" \
  161. "mmc_hw_part=run mmcpart_gp; run mmcpart_enhance; run mmcpart_rel_write; run mmcpart_commit; \0" \
  162. "led_success=gpio set 22; \0" \
  163. "fusecmd=mmc dev 1; if mmcpart iscommitted; then echo HW Partitioning already committed; mmcpart list; else run mmc_hw_part; fi; run led_success; \0" \
  164. "uenv_exec=if test -n $uenvcmd; then " \
  165. "echo Running uenvcmd ...; " \
  166. "run uenvcmd; " \
  167. "fi;\0" \
  168. "sd_setup=echo SD/MMC-Card detected on device 0; " \
  169. "setenv mmcdevice SD; " \
  170. "setenv mmcdev 0; " \
  171. "setenv mmcpart 2; " \
  172. "setenv mmcroot /dev/mmcblk${mmcdev}p${mmcpart};\0" \
  173. "emmc_setup=echo eMMC detected on device 1; " \
  174. "setenv mmcdevice eMMC; " \
  175. "setenv mmcdev 1; " \
  176. "run emmc_erase; " \
  177. "if test ${active_root} = root2; then " \
  178. "echo Active root is partition 6 (root2); " \
  179. "setenv mmcpart 6; " \
  180. "else " \
  181. "echo Active root is partition 5 (root1); " \
  182. "setenv mmcpart 5; " \
  183. "fi; " \
  184. "setenv mmcroot /dev/mmcblk${mmcdev}p${mmcpart};\0"
  185. #endif /* #ifndef CONFIG_SPL_BUILD */
  186. #if defined CONFIG_SHC_NETBOOT
  187. /* Network Boot */
  188. # define CONFIG_BOOTCOMMAND \
  189. "run fusecmd; " \
  190. "if run netboot; then " \
  191. "echo Booting from network; " \
  192. "else " \
  193. "echo ERROR: Cannot boot from network!; " \
  194. "panic; " \
  195. "fi; "
  196. #elif defined CONFIG_SHC_SDBOOT /* !defined CONFIG_SHC_NETBOOT */
  197. /* SD-Card Boot */
  198. # define CONFIG_BOOTCOMMAND \
  199. "if mmc dev 0; mmc rescan; then " \
  200. "run sd_setup; " \
  201. "else " \
  202. "echo ERROR: SD/MMC-Card not detected!; " \
  203. "panic; " \
  204. "fi; " \
  205. "if run loaduimage; then " \
  206. "echo Bootable SD/MMC-Card inserted, booting from it!; " \
  207. "run mmcboot; " \
  208. "else " \
  209. "echo ERROR: Unable to load uImage from SD/MMC-Card!; " \
  210. "panic; " \
  211. "fi; "
  212. #elif defined CONFIG_SHC_ICT
  213. /* ICT adapter boots only u-boot and does HW partitioning */
  214. # define CONFIG_BOOTCOMMAND \
  215. "if mmc dev 0; mmc rescan; then " \
  216. "run sd_setup; " \
  217. "else " \
  218. "echo ERROR: SD/MMC-Card not detected!; " \
  219. "panic; " \
  220. "fi; " \
  221. "run fusecmd; "
  222. #else /* !defined CONFIG_SHC_NETBOOT, !defined CONFIG_SHC_SDBOOT */
  223. /* Regular Boot from internal eMMC */
  224. # define CONFIG_BOOTCOMMAND \
  225. "if mmc dev 1; mmc rescan; then " \
  226. "run emmc_setup; " \
  227. "else " \
  228. "echo ERROR: eMMC device not detected!; " \
  229. "panic; " \
  230. "fi; " \
  231. "if run loaduimage; then " \
  232. "run mmcboot; " \
  233. "else " \
  234. "echo ERROR Unable to load uImage from eMMC!; " \
  235. "echo Performing Rollback!; " \
  236. "setenv _active_ ${active_root}; " \
  237. "setenv _inactive_ ${inactive_root}; " \
  238. "setenv active_root ${_inactive_}; " \
  239. "setenv inactive_root ${_active_}; " \
  240. "saveenv; " \
  241. "reset; " \
  242. "fi; "
  243. #endif /* Regular Boot */
  244. /* NS16550 Configuration */
  245. #define CONFIG_SYS_NS16550_COM1 0x44e09000 /* UART0 */
  246. #define CONFIG_SYS_NS16550_COM2 0x48022000 /* UART1 */
  247. #define CONFIG_SYS_NS16550_COM3 0x48024000 /* UART2 */
  248. #define CONFIG_SYS_NS16550_COM4 0x481a6000 /* UART3 */
  249. #define CONFIG_SYS_NS16550_COM5 0x481a8000 /* UART4 */
  250. #define CONFIG_SYS_NS16550_COM6 0x481aa000 /* UART5 */
  251. #define CONFIG_BAUDRATE 115200
  252. #define CONFIG_CONS_INDEX 1
  253. /* PMIC support */
  254. #define CONFIG_POWER_TPS65217
  255. /* SPL */
  256. #define CONFIG_SPL_LDSCRIPT "arch/arm/mach-omap2/u-boot-spl.lds"
  257. #ifndef CONFIG_SPL_USBETH_SUPPORT
  258. #define CONFIG_FASTBOOT_FLASH_MMC_DEV 1
  259. #endif
  260. /*
  261. * Disable MMC DM for SPL build and can be re-enabled after adding
  262. * DM support in SPL
  263. */
  264. #ifdef CONFIG_SPL_BUILD
  265. #undef CONFIG_DM_MMC
  266. #undef CONFIG_TIMER
  267. #endif
  268. #define CONFIG_CMD_DHCP
  269. #define CONFIG_CMD_PING
  270. #define CONFIG_DRIVER_TI_CPSW
  271. #define CONFIG_MII
  272. #define CONFIG_BOOTP_DEFAULT
  273. #define CONFIG_BOOTP_DNS
  274. #define CONFIG_BOOTP_DNS2
  275. #define CONFIG_BOOTP_SEND_HOSTNAME
  276. #define CONFIG_BOOTP_GATEWAY
  277. #define CONFIG_BOOTP_SUBNETMASK
  278. #define CONFIG_NET_RETRY_COUNT 10
  279. #define CONFIG_NET_MULTI
  280. #define CONFIG_PHY_GIGE
  281. #define CONFIG_PHYLIB
  282. #define CONFIG_PHY_ADDR 0
  283. #define CONFIG_PHY_SMSC
  284. /* I2C configuration */
  285. #define CONFIG_SYS_I2C_EEPROM_ADDR 0x50 /* Main EEPROM */
  286. #define CONFIG_SYS_I2C_EEPROM_ADDR_LEN 2
  287. #define CONFIG_SYS_I2C_SPEED 400000
  288. #define CONFIG_SYS_I2C_SLAVE 1
  289. #define CONFIG_SHOW_BOOT_PROGRESS
  290. #if defined CONFIG_SHC_NETBOOT
  291. #ifdef CONFIG_SPL_BUILD
  292. #define CONFIG_ENV_IS_NOWHERE
  293. #undef CONFIG_ENV_IS_IN_MMC
  294. #endif
  295. #endif
  296. #endif /* ! __CONFIG_AM335X_SHC_H */