mx6sxsabreauto.h 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. /*
  2. * Copyright 2014 Freescale Semiconductor, Inc.
  3. *
  4. * Configuration settings for the Freescale i.MX6SX Sabreauto board.
  5. *
  6. * SPDX-License-Identifier: GPL-2.0+
  7. */
  8. #ifndef __CONFIG_H
  9. #define __CONFIG_H
  10. #include "mx6_common.h"
  11. /* Size of malloc() pool */
  12. #define CONFIG_SYS_MALLOC_LEN (3 * SZ_1M)
  13. #define CONFIG_BOARD_EARLY_INIT_F
  14. #define CONFIG_BOARD_LATE_INIT
  15. #define CONFIG_MXC_UART
  16. #define CONFIG_MXC_UART_BASE UART1_BASE
  17. #define CONFIG_EXTRA_ENV_SETTINGS \
  18. "script=boot.scr\0" \
  19. "image=zImage\0" \
  20. "console=ttymxc0\0" \
  21. "fdt_high=0xffffffff\0" \
  22. "initrd_high=0xffffffff\0" \
  23. "fdt_file=imx6sx-sabreauto.dtb\0" \
  24. "fdt_addr=0x88000000\0" \
  25. "boot_fdt=try\0" \
  26. "ip_dyn=yes\0" \
  27. "mmcdev=0\0" \
  28. "mmcpart=1\0" \
  29. "mmcroot=/dev/mmcblk0p2 rootwait rw\0" \
  30. "mmcargs=setenv bootargs console=${console},${baudrate} " \
  31. "root=${mmcroot}\0" \
  32. "loadbootscript=" \
  33. "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
  34. "bootscript=echo Running bootscript from mmc ...; " \
  35. "source\0" \
  36. "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
  37. "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
  38. "mmcboot=echo Booting from mmc ...; " \
  39. "run mmcargs; " \
  40. "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
  41. "if run loadfdt; then " \
  42. "bootz ${loadaddr} - ${fdt_addr}; " \
  43. "else " \
  44. "if test ${boot_fdt} = try; then " \
  45. "bootz; " \
  46. "else " \
  47. "echo WARN: Cannot load the DT; " \
  48. "fi; " \
  49. "fi; " \
  50. "else " \
  51. "bootz; " \
  52. "fi;\0" \
  53. "netargs=setenv bootargs console=${console},${baudrate} " \
  54. "root=/dev/nfs " \
  55. "ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
  56. "netboot=echo Booting from net ...; " \
  57. "run netargs; " \
  58. "if test ${ip_dyn} = yes; then " \
  59. "setenv get_cmd dhcp; " \
  60. "else " \
  61. "setenv get_cmd tftp; " \
  62. "fi; " \
  63. "${get_cmd} ${image}; " \
  64. "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
  65. "if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
  66. "bootz ${loadaddr} - ${fdt_addr}; " \
  67. "else " \
  68. "if test ${boot_fdt} = try; then " \
  69. "bootz; " \
  70. "else " \
  71. "echo WARN: Cannot load the DT; " \
  72. "fi; " \
  73. "fi; " \
  74. "else " \
  75. "bootz; " \
  76. "fi;\0"
  77. #define CONFIG_BOOTCOMMAND \
  78. "mmc dev ${mmcdev};" \
  79. "mmc dev ${mmcdev}; if mmc rescan; then " \
  80. "if run loadbootscript; then " \
  81. "run bootscript; " \
  82. "else " \
  83. "if run loadimage; then " \
  84. "run mmcboot; " \
  85. "else run netboot; " \
  86. "fi; " \
  87. "fi; " \
  88. "else run netboot; fi"
  89. /* Miscellaneous configurable options */
  90. #define CONFIG_SYS_MEMTEST_START 0x80000000
  91. #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START + 0x10000)
  92. #define CONFIG_STACKSIZE SZ_128K
  93. /* Physical Memory Map */
  94. #define CONFIG_NR_DRAM_BANKS 1
  95. #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
  96. #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
  97. #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
  98. #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
  99. #define CONFIG_SYS_INIT_SP_OFFSET \
  100. (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
  101. #define CONFIG_SYS_INIT_SP_ADDR \
  102. (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
  103. /* MMC Configuration */
  104. #define CONFIG_SYS_FSL_ESDHC_ADDR USDHC3_BASE_ADDR
  105. /* I2C Configs */
  106. #define CONFIG_SYS_I2C
  107. #define CONFIG_SYS_I2C_MXC
  108. #define CONFIG_SYS_I2C_MXC_I2C1 /* enable I2C bus 1 */
  109. #define CONFIG_SYS_I2C_MXC_I2C2 /* enable I2C bus 2 */
  110. #define CONFIG_SYS_I2C_MXC_I2C3 /* enable I2C bus 3 */
  111. #define CONFIG_SYS_I2C_SPEED 100000
  112. /* PMIC */
  113. #define CONFIG_POWER
  114. #define CONFIG_POWER_I2C
  115. #define CONFIG_POWER_PFUZE100
  116. #define CONFIG_POWER_PFUZE100_I2C_ADDR 0x08
  117. /* NAND flash command */
  118. #define CONFIG_CMD_NAND
  119. #define CONFIG_CMD_NAND_TRIMFFS
  120. /* NAND stuff */
  121. #define CONFIG_NAND_MXS
  122. #define CONFIG_SYS_MAX_NAND_DEVICE 1
  123. #define CONFIG_SYS_NAND_BASE 0x40000000
  124. #define CONFIG_SYS_NAND_5_ADDR_CYCLE
  125. #define CONFIG_SYS_NAND_ONFI_DETECTION
  126. /* DMA stuff, needed for GPMI/MXS NAND support */
  127. #define CONFIG_APBH_DMA
  128. #define CONFIG_APBH_DMA_BURST
  129. #define CONFIG_APBH_DMA_BURST8
  130. /* Network */
  131. #define CONFIG_FEC_MXC
  132. #define CONFIG_MII
  133. #define IMX_FEC_BASE ENET2_BASE_ADDR
  134. #define CONFIG_FEC_MXC_PHYADDR 0x0
  135. #define CONFIG_FEC_XCV_TYPE RGMII
  136. #define CONFIG_ETHPRIME "FEC"
  137. #define CONFIG_PHYLIB
  138. #define CONFIG_PHY_ATHEROS
  139. #ifdef CONFIG_CMD_USB
  140. #define CONFIG_USB_EHCI
  141. #define CONFIG_USB_EHCI_MX6
  142. #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
  143. #define CONFIG_USB_HOST_ETHER
  144. #define CONFIG_USB_ETHER_ASIX
  145. #define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
  146. #define CONFIG_MXC_USB_FLAGS 0
  147. #define CONFIG_USB_MAX_CONTROLLER_COUNT 2
  148. #endif
  149. #define CONFIG_IMX_THERMAL
  150. #ifdef CONFIG_FSL_QSPI
  151. #define CONFIG_SYS_FSL_QSPI_AHB
  152. #define CONFIG_SF_DEFAULT_BUS 0
  153. #define CONFIG_SF_DEFAULT_CS 0
  154. #define CONFIG_SF_DEFAULT_SPEED 40000000
  155. #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
  156. #define FSL_QSPI_FLASH_SIZE SZ_32M
  157. #define FSL_QSPI_FLASH_NUM 2
  158. #endif
  159. #define CONFIG_ENV_OFFSET (8 * SZ_64K)
  160. #define CONFIG_ENV_SIZE SZ_8K
  161. #define CONFIG_ENV_IS_IN_MMC
  162. #define CONFIG_SYS_FSL_USDHC_NUM 2
  163. #if defined(CONFIG_ENV_IS_IN_MMC)
  164. #define CONFIG_SYS_MMC_ENV_DEV 0 /*USDHC3*/
  165. #endif
  166. #define CONFIG_PCA953X
  167. #define CONFIG_SYS_I2C_PCA953X_WIDTH { {0x30, 8}, {0x32, 8}, {0x34, 8} }
  168. #endif /* __CONFIG_H */