]> git.ipfire.org Git - people/ms/u-boot.git/blame - include/configs/imx6ul_isiot.h
engicam: Set console env on board_late_init
[people/ms/u-boot.git] / include / configs / imx6ul_isiot.h
CommitLineData
e9dfa1e1
JT
1/*
2 * Copyright (C) 2016 Amarula Solutions B.V.
3 * Copyright (C) 2016 Engicam S.r.l.
4 *
5 * Configuration settings for the Engicam Is.IoT MX6UL Starter Kits.
6 *
7 * SPDX-License-Identifier: GPL-2.0+
8 */
9
10#ifndef __IMX6UL_ISIOT_CONFIG_H
11#define __IMX6UL_ISIOT_CONFIG_H
12
13#include <linux/sizes.h>
14#include "mx6_common.h"
15
16/* Size of malloc() pool */
17#define CONFIG_SYS_MALLOC_LEN (16 * SZ_1M)
18
19/* Total Size of Environment Sector */
20#define CONFIG_ENV_SIZE SZ_128K
21
22/* Allow to overwrite serial and ethaddr */
23#define CONFIG_ENV_OVERWRITE
24
25/* Environment */
26#ifndef CONFIG_ENV_IS_NOWHERE
27/* Environment in MMC */
28# if defined(CONFIG_ENV_IS_IN_MMC)
29# define CONFIG_ENV_OFFSET 0x100000
6788a7e4
JT
30/* Environment in NAND */
31# elif defined(CONFIG_ENV_IS_IN_NAND)
32# define CONFIG_ENV_OFFSET 0x400000
33# define CONFIG_ENV_SECT_SIZE CONFIG_ENV_SIZE
e9dfa1e1
JT
34# endif
35#endif
36
37/* Default environment */
38#define CONFIG_EXTRA_ENV_SETTINGS \
39 "script=boot.scr\0" \
40 "image=uImage\0" \
41 "fit_image=fit.itb\0" \
42 "splashpos=m,m\0" \
e9dfa1e1 43 "fdt_high=0xffffffff\0" \
e9dfa1e1
JT
44 "fdt_addr=0x87800000\0" \
45 "boot_fdt=try\0" \
e9dfa1e1 46 "mmcpart=1\0" \
949cfefb 47 "nandroot=ubi0:rootfs rootfstype=ubifs\0" \
e9dfa1e1
JT
48 "mmcautodetect=yes\0" \
49 "mmcargs=setenv bootargs console=${console},${baudrate} " \
50 "root=${mmcroot}\0" \
949cfefb
JT
51 "ubiargs=setenv bootargs console=${console},${baudrate} " \
52 "ubi.mtd=5 root=${nandroot} ${mtdparts}\0" \
e9dfa1e1
JT
53 "loadbootscript=" \
54 "fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
55 "bootscript=echo Running bootscript from mmc ...; " \
56 "source\0" \
57 "loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
58 "loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
59 "loadfit=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${fit_image}\0" \
60 "fitboot=echo Booting FIT image from mmc ...; " \
61 "run mmcargs; " \
62 "bootm ${loadaddr}\0" \
2e2a8dc6 63 "_mmcboot=run mmcargs; " \
e9dfa1e1
JT
64 "if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
65 "if run loadfdt; then " \
66 "bootm ${loadaddr} - ${fdt_addr}; " \
67 "else " \
68 "if test ${boot_fdt} = try; then " \
69 "bootm; " \
70 "else " \
71 "echo WARN: Cannot load the DT; " \
72 "fi; " \
73 "fi; " \
74 "else " \
75 "bootm; " \
949cfefb 76 "fi\0" \
2e2a8dc6
JT
77 "mmcboot=echo Booting from mmc ...; " \
78 "if mmc rescan; then " \
79 "if run loadbootscript; then " \
80 "run bootscript; " \
81 "else " \
82 "if run loadfit; then " \
83 "run fitboot; " \
84 "else " \
85 "if run loadimage; then " \
86 "run _mmcboot; " \
87 "fi; " \
88 "fi; " \
89 "fi; " \
90 "fi\0" \
949cfefb
JT
91 "nandboot=echo Booting from nand ...; " \
92 "if mtdparts; then " \
93 "echo Starting nand boot ...; " \
94 "else " \
95 "mtdparts default; " \
96 "fi; " \
97 "run ubiargs; " \
98 "nand read ${loadaddr} kernel 0x800000; " \
99 "nand read ${fdt_addr} dtb 0x100000; " \
100 "bootm ${loadaddr} - ${fdt_addr}\0"
e9dfa1e1 101
2e2a8dc6 102#define CONFIG_BOOTCOMMAND "run $modeboot"
e9dfa1e1
JT
103
104/* Miscellaneous configurable options */
105#define CONFIG_SYS_MEMTEST_START 0x80000000
106#define CONFIG_SYS_MEMTEST_END (CONFIG_SYS_MEMTEST_START + 0x8000000)
107
108#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
109#define CONFIG_SYS_HZ 1000
110
111/* Physical Memory Map */
112#define CONFIG_NR_DRAM_BANKS 1
113#define PHYS_SDRAM MMDC0_ARB_BASE_ADDR
114
115#define CONFIG_SYS_SDRAM_BASE PHYS_SDRAM
116#define CONFIG_SYS_INIT_RAM_ADDR IRAM_BASE_ADDR
117#define CONFIG_SYS_INIT_RAM_SIZE IRAM_SIZE
118
119#define CONFIG_SYS_INIT_SP_OFFSET (CONFIG_SYS_INIT_RAM_SIZE - \
120 GENERATED_GBL_DATA_SIZE)
121#define CONFIG_SYS_INIT_SP_ADDR (CONFIG_SYS_INIT_RAM_ADDR + \
122 CONFIG_SYS_INIT_SP_OFFSET)
123
124/* FIT */
125#ifdef CONFIG_FIT
126# define CONFIG_HASH_VERIFY
e9dfa1e1
JT
127# define CONFIG_IMAGE_FORMAT_LEGACY
128#endif
129
130/* UART */
131#ifdef CONFIG_MXC_UART
132# define CONFIG_MXC_UART_BASE UART1_BASE
133#endif
134
135/* MMC */
136#ifdef CONFIG_FSL_USDHC
137# define CONFIG_SYS_MMC_ENV_DEV 0
e9dfa1e1
JT
138#endif
139
6788a7e4
JT
140/* NAND */
141#ifdef CONFIG_NAND_MXS
142# define CONFIG_SYS_MAX_NAND_DEVICE 1
143# define CONFIG_SYS_NAND_BASE 0x40000000
144# define CONFIG_SYS_NAND_5_ADDR_CYCLE
145# define CONFIG_SYS_NAND_ONFI_DETECTION
146# define CONFIG_SYS_NAND_U_BOOT_START CONFIG_SYS_TEXT_BASE
147# define CONFIG_SYS_NAND_U_BOOT_OFFS 0x200000
148
949cfefb
JT
149/* MTD device */
150# define CONFIG_MTD_DEVICE
151# define CONFIG_CMD_MTDPARTS
152# define CONFIG_MTD_PARTITIONS
153# define MTDIDS_DEFAULT "nand0=gpmi-nand"
154# define MTDPARTS_DEFAULT "mtdparts=gpmi-nand:2m(spl),2m(uboot)," \
155 "1m(env),8m(kernel),1m(dtb),-(rootfs)"
156
157/* UBI */
158# define CONFIG_CMD_UBIFS
159# define CONFIG_RBTREE
160# define CONFIG_LZO
161
6788a7e4
JT
162/* APBH DMA */
163# define CONFIG_APBH_DMA
164# define CONFIG_APBH_DMA_BURST
165# define CONFIG_APBH_DMA_BURST8
166#endif
167
0421a164
JT
168/* Ethernet */
169#ifdef CONFIG_FEC_MXC
170# define CONFIG_FEC_MXC_PHYADDR 0
171# define CONFIG_FEC_XCV_TYPE RMII
172
173# define CONFIG_MII
0421a164
JT
174#endif
175
e9dfa1e1
JT
176/* SPL */
177#ifdef CONFIG_SPL
6788a7e4
JT
178# ifdef CONFIG_NAND_MXS
179# define CONFIG_SPL_NAND_SUPPORT
180# else
181# define CONFIG_SPL_MMC_SUPPORT
182# endif
e9dfa1e1
JT
183
184# include "imx6_spl.h"
185# ifdef CONFIG_SPL_BUILD
6d931fd5
JT
186# define CONFIG_SYS_FSL_USDHC_NUM 2
187# define CONFIG_SYS_FSL_ESDHC_ADDR 0
e9dfa1e1
JT
188# undef CONFIG_DM_GPIO
189# undef CONFIG_DM_MMC
190# endif
191#endif
192
193#endif /* __IMX6UL_ISIOT_CONFIG_H */