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
24 #define CONFIG_CMD_FUSE
25 #if defined(CONFIG_CMD_FUSE) || defined(CONFIG_IMX6_THERMAL)
26 #define CONFIG_MXC_OCOTP
30 #define CONFIG_SYS_FSL_ESDHC_ADDR 0
32 #define CONFIG_CMD_PING
33 #define CONFIG_CMD_DHCP
34 #define CONFIG_CMD_MII
35 #define CONFIG_FEC_MXC
37 #define IMX_FEC_BASE ENET_BASE_ADDR
38 #define CONFIG_FEC_XCV_TYPE RGMII
39 #define CONFIG_ETHPRIME "FEC"
40 #define CONFIG_FEC_MXC_PHYADDR 1
43 #define CONFIG_PHY_ATHEROS
47 #define CONFIG_SPI_FLASH
48 #define CONFIG_SPI_FLASH_STMICRO
49 #define CONFIG_MXC_SPI
50 #define CONFIG_SF_DEFAULT_BUS 0
51 #define CONFIG_SF_DEFAULT_CS 0
52 #define CONFIG_SF_DEFAULT_SPEED 20000000
53 #define CONFIG_SF_DEFAULT_MODE SPI_MODE_0
56 /* Command definition */
57 #define CONFIG_CMD_BMODE
59 #ifdef CONFIG_SUPPORT_EMMC_BOOT
62 "update_emmc_firmware=" \
63 "if test ${ip_dyn} = yes; then " \
64 "setenv get_cmd dhcp; " \
66 "setenv get_cmd tftp; " \
68 "if ${get_cmd} ${update_sd_firmware_filename}; then " \
69 "if mmc dev ${emmcdev} 1; then " \
70 "setexpr fw_sz ${filesize} / 0x200; " \
71 "setexpr fw_sz ${fw_sz} + 1; " \
72 "mmc write ${loadaddr} 0x2 ${fw_sz}; " \
83 #ifndef VIDEO_ARGS_SCRIPT
84 #define VIDEO_ARGS_SCRIPT ""
87 #define CONFIG_EXTRA_ENV_SETTINGS \
90 "fdt_file=" CONFIG_DEFAULT_FDT_FILE "\0" \
91 "fdt_addr=0x18000000\0" \
94 "console=" CONFIG_CONSOLE_DEV "\0" \
95 "fdt_high=0xffffffff\0" \
96 "initrd_high=0xffffffff\0" \
97 "mmcdev=" __stringify(CONFIG_SYS_MMC_ENV_DEV) "\0" \
99 "mmcroot=" CONFIG_MMCROOT " rootwait rw\0" \
100 "update_sd_firmware=" \
101 "if test ${ip_dyn} = yes; then " \
102 "setenv get_cmd dhcp; " \
104 "setenv get_cmd tftp; " \
106 "if mmc dev ${mmcdev}; then " \
107 "if ${get_cmd} ${update_sd_firmware_filename}; then " \
108 "setexpr fw_sz ${filesize} / 0x200; " \
109 "setexpr fw_sz ${fw_sz} + 1; " \
110 "mmc write ${loadaddr} 0x2 ${fw_sz}; " \
114 "video_args_hdmi=setenv video_args $video_args " \
115 "video=mxcfb${fb}:dev=hdmi,1280x720M@60,if=RGB24\0" \
116 "video_args_lvds=setenv video_args $video_args " \
117 "video=mxcfb${fb}:dev=ldb,LDB-XGA,if=RGB666\0" \
118 "video_args_lcd=setenv video_args $video_args " \
119 "video=mxcfb${fb}:dev=lcd,CLAA-WVGA,if=RGB666\0" \
121 "video_interfaces=hdmi lvds lcd\0" \
122 "video_args_script=" \
123 "for v in ${video_interfaces}; do " \
124 "run video_args_${v}; " \
125 "setexpr fb $fb + 1; " \
127 "mmcargs=setenv bootargs console=${console},${baudrate} " \
131 "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
132 "bootscript=echo Running bootscript from mmc ...; " \
134 "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
135 "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
136 "mmcboot=echo Booting from mmc ...; " \
139 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
140 "if run loadfdt; then " \
141 "bootz ${loadaddr} - ${fdt_addr}; " \
143 "if test ${boot_fdt} = try; then " \
146 "echo WARN: Cannot load the DT; " \
152 "netargs=setenv bootargs console=${console},${baudrate} " \
154 "ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
155 "netboot=echo Booting from net ...; " \
157 "if test ${ip_dyn} = yes; then " \
158 "setenv get_cmd dhcp; " \
160 "setenv get_cmd tftp; " \
162 "${get_cmd} ${image}; " \
163 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
164 "if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
165 "bootz ${loadaddr} - ${fdt_addr}; " \
167 "if test ${boot_fdt} = try; then " \
170 "echo WARN: Cannot load the DT; " \
177 #define CONFIG_BOOTCOMMAND \
178 "mmc dev ${mmcdev};" \
179 "if mmc rescan; then " \
180 "if run loadbootscript; then " \
183 "if run loadimage; then " \
185 "else run netboot; " \
188 "else run netboot; fi"
190 #define CONFIG_ARP_TIMEOUT 200UL
192 #define CONFIG_SYS_MEMTEST_START 0x10000000
193 #define CONFIG_SYS_MEMTEST_END 0x10010000
194 #define CONFIG_SYS_MEMTEST_SCRATCH 0x10800000
196 #define CONFIG_STACKSIZE (128 * 1024)
198 /* Physical Memory Map */
199 #define CONFIG_NR_DRAM_BANKS 1
200 #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
202 #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
203 #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
204 #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
206 #define CONFIG_SYS_INIT_SP_OFFSET \
207 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
208 #define CONFIG_SYS_INIT_SP_ADDR \
209 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
211 /* Environment organization */
212 #define CONFIG_ENV_SIZE (8 * 1024)
214 #define CONFIG_ENV_IS_IN_MMC
216 #if defined(CONFIG_ENV_IS_IN_MMC)
217 #define CONFIG_ENV_OFFSET (8 * 64 * 1024)
222 #define CONFIG_VIDEO_IPUV3
223 #define CONFIG_CFB_CONSOLE
224 #define CONFIG_VGA_AS_SINGLE_DEVICE
225 #define CONFIG_SYS_CONSOLE_IS_IN_ENV
226 #define CONFIG_SYS_CONSOLE_OVERWRITE_ROUTINE
227 #define CONFIG_VIDEO_BMP_RLE8
228 #define CONFIG_SPLASH_SCREEN
229 #define CONFIG_SPLASH_SCREEN_ALIGN
230 #define CONFIG_BMP_16BPP
231 #define CONFIG_VIDEO_LOGO
232 #define CONFIG_VIDEO_BMP_LOGO
233 #define CONFIG_IPUV3_CLK 260000000
234 #define CONFIG_IMX_HDMI
235 #define CONFIG_IMX_VIDEO_SKIP
238 #define CONFIG_CI_UDC
239 #define CONFIG_USBD_HS
240 #define CONFIG_USB_GADGET_DUALSPEED
242 #define CONFIG_USB_GADGET
243 #define CONFIG_CMD_USB_MASS_STORAGE
244 #define CONFIG_USB_GADGET_MASS_STORAGE
245 #define CONFIG_USBDOWNLOAD_GADGET
246 #define CONFIG_USB_GADGET_VBUS_DRAW 2
248 #define CONFIG_G_DNL_VENDOR_NUM 0x0525
249 #define CONFIG_G_DNL_PRODUCT_NUM 0xa4a5
250 #define CONFIG_G_DNL_MANUFACTURER "FSL"
253 #endif /* __MX6QSABRE_COMMON_CONFIG_H */