2 * Copyright (C) 2016 Amarula Solutions B.V.
3 * Copyright (C) 2016 Engicam S.r.l.
5 * Configuration settings for the Engicam i.CoreM6 QDL RQS Starter Kits.
7 * SPDX-License-Identifier: GPL-2.0+
10 #ifndef __IMX6QLD_ICORE_RQS_CONFIG_H
11 #define __IMX6QLD_ICORE_RQS_CONFIG_H
13 #include <linux/sizes.h>
14 #include "mx6_common.h"
16 /* Size of malloc() pool */
17 #define CONFIG_SYS_MALLOC_LEN (16 * SZ_1M)
19 /* Total Size of Environment Sector */
20 #define CONFIG_ENV_SIZE SZ_128K
22 /* Allow to overwrite serial and ethaddr */
23 #define CONFIG_ENV_OVERWRITE
26 #ifndef CONFIG_ENV_IS_NOWHERE
27 /* Environment in MMC */
28 # if defined(CONFIG_ENV_IS_IN_MMC)
29 # define CONFIG_ENV_OFFSET 0x100000
33 /* Default environment */
34 #define CONFIG_EXTRA_ENV_SETTINGS \
37 "fit_image=fit.itb\0" \
39 "fdt_high=0xffffffff\0" \
40 "fdt_addr=0x18000000\0" \
43 "mmcautodetect=yes\0" \
44 "mmcargs=setenv bootargs console=${console},${baudrate} " \
47 "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
48 "bootscript=echo Running bootscript from mmc ...; " \
50 "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
51 "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
52 "loadfit=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${fit_image}\0" \
53 "fitboot=echo Booting FIT image from mmc ...; " \
55 "bootm ${loadaddr}\0" \
56 "_mmcboot=run mmcargs; " \
57 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
58 "if run loadfdt; then " \
59 "bootm ${loadaddr} - ${fdt_addr}; " \
61 "if test ${boot_fdt} = try; then " \
64 "echo WARN: Cannot load the DT; " \
70 "mmcboot=echo Booting from mmc ...; " \
71 "mmc dev ${mmcdev};" \
72 "if mmc rescan; then " \
73 "if run loadbootscript; then " \
76 "if run loadfit; then " \
79 "if run loadimage; then " \
86 #define CONFIG_BOOTCOMMAND "run $modeboot"
88 /* Miscellaneous configurable options */
89 #define CONFIG_SYS_MEMTEST_START 0x80000000
90 #define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START + 0x8000000)
92 #define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
93 #define CONFIG_SYS_HZ 1000
95 /* Physical Memory Map */
96 #define CONFIG_NR_DRAM_BANKS 1
97 #define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
99 #define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
100 #define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
101 #define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
103 #define CONFIG_SYS_INIT_SP_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - \
104 GENERATED_GBL_DATA_SIZE)
105 #define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INIT_RAM_ADDR + \
106 CONFIG_SYS_INIT_SP_OFFSET)
110 # define CONFIG_HASH_VERIFY
112 # define CONFIG_SHA256
113 # define CONFIG_IMAGE_FORMAT_LEGACY
117 #ifdef CONFIG_MXC_UART
118 # define CONFIG_MXC_UART_BASE UART4_BASE
122 #ifdef CONFIG_FSL_USDHC
123 # define CONFIG_SYS_MMC_ENV_DEV 0
124 # define CONFIG_SYS_FSL_USDHC_NUM 2
125 # define CONFIG_SYS_FSL_ESDHC_ADDR 0
129 #ifdef CONFIG_FEC_MXC
130 # define CONFIG_FEC_MXC_PHYADDR 3
131 # define CONFIG_FEC_XCV_TYPE RGMII
134 # define CONFIG_PHYLIB
135 # define CONFIG_PHY_MICREL
136 # define CONFIG_PHY_MICREL_KSZ9021
141 # define CONFIG_SPL_MMC_SUPPORT
142 # include "imx6_spl.h"
143 # ifdef CONFIG_SPL_BUILD
144 # undef CONFIG_DM_GPIO
145 # undef CONFIG_DM_MMC
149 #endif /* __IMX6QLD_ICORE_RQS_CONFIG_H */