2 * Copyright (C) 2012 Freescale Semiconductor, Inc.
4 * Configuration settings for the Freescale i.MX6Q SabreSD board.
6 * SPDX-License-Identifier: GPL-2.0+
9 #ifndef __MX6QSABRE_COMMON_CONFIG_H
10 #define __MX6QSABRE_COMMON_CONFIG_H
12 #include "mx6_common.h"
14 #define CONFIG_IMX6_THERMAL
16 /* Size of malloc() pool */
17 #define CONFIG_SYS_MALLOC_LEN (10 * SZ_1M)
19 #define CONFIG_BOARD_EARLY_INIT_F
20 #define CONFIG_BOARD_LATE_INIT
22 #define CONFIG_MXC_UART
25 #define CONFIG_SYS_FSL_ESDHC_ADDR 0
27 #define CONFIG_CMD_PING
28 #define CONFIG_CMD_DHCP
29 #define CONFIG_CMD_MII
30 #define CONFIG_FEC_MXC
32 #define IMX_FEC_BASE ENET_BASE_ADDR
33 #define CONFIG_FEC_XCV_TYPE RGMII
34 #define CONFIG_ETHPRIME "FEC"
35 #define CONFIG_FEC_MXC_PHYADDR 1
38 #define CONFIG_PHY_ATHEROS
42 #define CONFIG_SPI_FLASH_STMICRO
43 #define CONFIG_MXC_SPI
44 #define CONFIG_SF_DEFAULT_BUS 0
45 #define CONFIG_SF_DEFAULT_CS 0
46 #define CONFIG_SF_DEFAULT_SPEED 20000000
47 #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
50 /* Command definition */
51 #define CONFIG_CMD_BMODE
53 #ifdef CONFIG_SUPPORT_EMMC_BOOT
56 "update_emmc_firmware=" \
57 "if test ${ip_dyn} = yes; then " \
58 "setenv get_cmd dhcp; " \
60 "setenv get_cmd tftp; " \
62 "if ${get_cmd} ${update_sd_firmware_filename}; then " \
63 "if mmc dev ${emmcdev} 1; then " \
64 "setexpr fw_sz ${filesize} / 0x200; " \
65 "setexpr fw_sz ${fw_sz} + 1; " \
66 "mmc write ${loadaddr} 0x2 ${fw_sz}; " \
73 #define CONFIG_ENV_VARS_UBOOT_RUNTIME_CONFIG
75 #define CONFIG_EXTRA_ENV_SETTINGS \
78 "fdt_file=undefined\0" \
79 "fdt_addr=0x18000000\0" \
82 "console=" CONFIG_CONSOLE_DEV "\0" \
83 "fdt_high=0xffffffff\0" \
84 "initrd_high=0xffffffff\0" \
85 "mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
87 "mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
88 "update_sd_firmware=" \
89 "if test ${ip_dyn} = yes; then " \
90 "setenv get_cmd dhcp; " \
92 "setenv get_cmd tftp; " \
94 "if mmc dev ${mmcdev}; then " \
95 "if ${get_cmd} ${update_sd_firmware_filename}; then " \
96 "setexpr fw_sz ${filesize} / 0x200; " \
97 "setexpr fw_sz ${fw_sz} + 1; " \
98 "mmc write ${loadaddr} 0x2 ${fw_sz}; " \
102 "video_args_hdmi=setenv video_args $video_args " \
103 "video=mxcfb${fb}:dev=hdmi,1280x720M@60,if=RGB24\0" \
104 "video_args_lvds=setenv video_args $video_args " \
105 "video=mxcfb${fb}:dev=ldb,LDB-XGA,if=RGB666\0" \
106 "video_args_lcd=setenv video_args $video_args " \
107 "video=mxcfb${fb}:dev=lcd,CLAA-WVGA,if=RGB666\0" \
109 "video_interfaces=hdmi lvds lcd\0" \
110 "video_args_script=" \
111 "for v in ${video_interfaces}; do " \
112 "run video_args_${v}; " \
113 "setexpr fb $fb + 1; " \
115 "mmcargs=setenv bootargs console=${console},${baudrate} " \
119 "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
120 "bootscript=echo Running bootscript from mmc ...; " \
122 "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
123 "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
124 "mmcboot=echo Booting from mmc ...; " \
127 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
128 "if run loadfdt; then " \
129 "bootz ${loadaddr} - ${fdt_addr}; " \
131 "if test ${boot_fdt} = try; then " \
134 "echo WARN: Cannot load the DT; " \
140 "netargs=setenv bootargs console=${console},${baudrate} " \
142 "ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
143 "netboot=echo Booting from net ...; " \
145 "if test ${ip_dyn} = yes; then " \
146 "setenv get_cmd dhcp; " \
148 "setenv get_cmd tftp; " \
150 "${get_cmd} ${image}; " \
151 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
152 "if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
153 "bootz ${loadaddr} - ${fdt_addr}; " \
155 "if test ${boot_fdt} = try; then " \
158 "echo WARN: Cannot load the DT; " \
165 "if test $fdt_file = undefined; then " \
166 "if test $board_name = SABREAUTO && test $board_rev = MX6QP; then " \
167 "setenv fdt_file imx6qp-sabreauto.dtb; fi; " \
168 "if test $board_name = SABREAUTO && test $board_rev = MX6Q; then " \
169 "setenv fdt_file imx6q-sabreauto.dtb; fi; " \
170 "if test $board_name = SABREAUTO && test $board_rev = MX6DL; then " \
171 "setenv fdt_file imx6dl-sabreauto.dtb; fi; " \
172 "if test $board_name = SABRESD && test $board_rev = MX6Q; then " \
173 "setenv fdt_file imx6q-sabresd.dtb; fi; " \
174 "if test $board_name = SABRESD && test $board_rev = MX6DL; then " \
175 "setenv fdt_file imx6dl-sabresd.dtb; fi; " \
176 "if test $fdt_file = undefined; then " \
177 "echo WARNING: Could not determine dtb to use; fi; " \
181 #define CONFIG_BOOTCOMMAND \
183 "mmc dev ${mmcdev};" \
184 "if mmc rescan; then " \
185 "if run loadbootscript; then " \
188 "if run loadimage; then " \
190 "else run netboot; " \
193 "else run netboot; fi"
195 #define CONFIG_ARP_TIMEOUT 200UL
197 #define CONFIG_SYS_MEMTEST_START 0x10000000
198 #define CONFIG_SYS_MEMTEST_END 0x10010000
199 #define CONFIG_SYS_MEMTEST_SCRATCH 0x10800000
201 #define CONFIG_STACKSIZE (128 * 1024)
203 /* Physical Memory Map */
204 #define CONFIG_NR_DRAM_BANKS 1
205 #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
207 #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
208 #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
209 #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
211 #define CONFIG_SYS_INIT_SP_OFFSET \
212 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
213 #define CONFIG_SYS_INIT_SP_ADDR \
214 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
216 /* Environment organization */
217 #define CONFIG_ENV_SIZE (8 * 1024)
219 #define CONFIG_ENV_IS_IN_MMC
221 #if defined(CONFIG_ENV_IS_IN_MMC)
222 #define CONFIG_ENV_OFFSET (8 * 64 * 1024)
227 #define CONFIG_VIDEO_IPUV3
228 #define CONFIG_CFB_CONSOLE
229 #define CONFIG_VGA_AS_SINGLE_DEVICE
230 #define CONFIG_SYS_CONSOLE_IS_IN_ENV
231 #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
232 #define CONFIG_VIDEO_BMP_RLE8
233 #define CONFIG_SPLASH_SCREEN
234 #define CONFIG_SPLASH_SCREEN_ALIGN
235 #define CONFIG_BMP_16BPP
236 #define CONFIG_VIDEO_LOGO
237 #define CONFIG_VIDEO_BMP_LOGO
238 #define CONFIG_IPUV3_CLK 260000000
239 #define CONFIG_IMX_HDMI
240 #define CONFIG_IMX_VIDEO_SKIP
243 #define CONFIG_CI_UDC
244 #define CONFIG_USBD_HS
245 #define CONFIG_USB_GADGET_DUALSPEED
247 #define CONFIG_USB_GADGET
248 #define CONFIG_CMD_USB_MASS_STORAGE
249 #define CONFIG_USB_FUNCTION_MASS_STORAGE
250 #define CONFIG_USB_GADGET_DOWNLOAD
251 #define CONFIG_USB_GADGET_VBUS_DRAW 2
253 #define CONFIG_G_DNL_VENDOR_NUM 0x0525
254 #define CONFIG_G_DNL_PRODUCT_NUM 0xa4a5
255 #define CONFIG_G_DNL_MANUFACTURER "FSL"
258 #endif /* __MX6QSABRE_COMMON_CONFIG_H */