blob: e08e83151fbf545fe07f90b3df14be455e22a42c [file] [log] [blame]
Tom Rini10e47792018-05-06 17:58:06 -04001/* SPDX-License-Identifier: GPL-2.0+ */
Peter Senna Tschudin56d96922017-11-06 19:14:11 +00002/*
3 * Copyright (C) 2011 Freescale Semiconductor, Inc.
4 * Jason Liu <r64343@freescale.com>
5 *
6 * Configuration settings for Freescale MX53 low cost board.
Peter Senna Tschudin56d96922017-11-06 19:14:11 +00007 */
8
9#ifndef __CONFIG_H
10#define __CONFIG_H
11
12#include <asm/arch/imx-regs.h>
13
14#define CONSOLE_DEV "ttymxc0"
15
16#define CONFIG_CMDLINE_TAG
17#define CONFIG_SETUP_MEMORY_TAGS
18#define CONFIG_INITRD_TAG
19
20#define CONFIG_SYS_FSL_CLK
21
22/* Size of malloc() pool */
23#define CONFIG_SYS_MALLOC_LEN (10 * 1024 * 1024)
24
25#define CONFIG_HW_WATCHDOG
26#define CONFIG_IMX_WATCHDOG
27#define CONFIG_WATCHDOG_TIMEOUT_MSECS 8000
28
29#define CONFIG_MISC_INIT_R
30#define CONFIG_BOARD_LATE_INIT
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000031#define CONFIG_REVISION_TAG
32
33#define CONFIG_MXC_UART
34#define CONFIG_MXC_UART_BASE UART1_BASE
35
36/* MMC Configs */
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000037#define CONFIG_SYS_FSL_ESDHC_ADDR 0
38#define CONFIG_SYS_FSL_ESDHC_NUM 2
39
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000040/* Eth Configs */
41#define CONFIG_MII
42
43#define CONFIG_FEC_MXC
44#define IMX_FEC_BASE FEC_BASE_ADDR
45#define CONFIG_FEC_MXC_PHYADDR 0x1F
46
47/* USB Configs */
48#define CONFIG_USB_EHCI_MX5
49#define CONFIG_USB_HOST_ETHER
50#define CONFIG_USB_ETHER_ASIX
51#define CONFIG_USB_ETHER_MCS7830
52#define CONFIG_USB_ETHER_SMSC95XX
53#define CONFIG_MXC_USB_PORT 1
54#define CONFIG_MXC_USB_PORTSC (PORT_PTS_UTMI | PORT_PTS_PTW)
55#define CONFIG_MXC_USB_FLAGS 0
56
57#define CONFIG_SYS_RTC_BUS_NUM 2
58#define CONFIG_SYS_I2C_RTC_ADDR 0x30
59
60/* I2C Configs */
61#define CONFIG_SYS_I2C
62#define CONFIG_SYS_I2C_MXC
63#define CONFIG_SYS_I2C_MXC_I2C1 /* enable I2C bus 1 */
64#define CONFIG_SYS_I2C_MXC_I2C2 /* enable I2C bus 2 */
65#define CONFIG_SYS_I2C_MXC_I2C3 /* enable I2C bus 3 */
66
67/* PMIC Controller */
68#define CONFIG_POWER
69#define CONFIG_POWER_I2C
70#define CONFIG_DIALOG_POWER
71#define CONFIG_POWER_FSL
72#define CONFIG_POWER_FSL_MC13892
73#define CONFIG_SYS_DIALOG_PMIC_I2C_ADDR 0x48
74#define CONFIG_SYS_FSL_PMIC_I2C_ADDR 0x8
75
76/* allow to overwrite serial and ethaddr */
77#define CONFIG_ENV_OVERWRITE
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000078#define CONFIG_BAUDRATE 115200
79
80/* Command definition */
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000081
82#define CONFIG_ETHPRIME "FEC0"
83
84#define CONFIG_LOADADDR 0x72000000 /* loadaddr env var */
Peter Senna Tschudin56d96922017-11-06 19:14:11 +000085
86#define PPD_CONFIG_NFS \
87 "nfsserver=192.168.252.95\0" \
88 "gatewayip=192.168.252.95\0" \
89 "netmask=255.255.255.0\0" \
90 "ipaddr=192.168.252.99\0" \
91 "kernsize=0x2000\0" \
92 "use_dhcp=0\0" \
93 "nfsroot=/opt/springdale/rd\0" \
94 "bootargs_nfs=setenv bootargs ${bootargs} root=/dev/nfs " \
95 "${kern_ipconf} nfsroot=${nfsserver}:${nfsroot},v3,tcp rw\0" \
96 "choose_ip=if test $use_dhcp = 1; then set kern_ipconf ip=dhcp; " \
97 "set getcmd dhcp; else set kern_ipconf " \
98 "ip=${ipaddr}:${nfsserver}:${gatewayip}:${netmask}::eth0:off; " \
99 "set getcmd tftp; fi\0" \
100 "nfs=run choose_ip setargs bootargs_nfs; ${getcmd} ${loadaddr} " \
101 "${nfsserver}:${image}; bootm ${loadaddr}\0" \
102
103#define CONFIG_EXTRA_ENV_SETTINGS \
104 PPD_CONFIG_NFS \
105 "bootlimit=10\0" \
106 "image=/boot/fitImage\0" \
107 "fdt_high=0xffffffff\0" \
108 "dev=mmc\0" \
109 "devnum=0\0" \
110 "rootdev=mmcblk0p\0" \
111 "quiet=quiet loglevel=0\0" \
112 "console=" CONSOLE_DEV "\0" \
113 "lvds=ldb\0" \
114 "setargs=setenv bootargs ${lvds} jtag=on mem=2G " \
115 "vt.global_cursor_default=0 bootcause=${bootcause} ${quiet} " \
116 "console=${console} ${rtc_status}\0" \
117 "bootargs_emmc=setenv bootargs root=/dev/${rootdev}${partnum} ro " \
118 "rootwait ${bootargs}\0" \
119 "doquiet=if ext2load ${dev} ${devnum}:5 0x7000A000 /boot/console; " \
120 "then setenv quiet; fi\0" \
121 "hasfirstboot=ext2load ${dev} ${devnum}:${partnum} 0x7000A000 " \
122 "/boot/bootcause/firstboot\0" \
123 "swappartitions=setexpr partnum 3 - ${partnum}\0" \
124 "failbootcmd=" \
125 "ppd_lcd_enable; " \
126 "msg=\"Monitor failed to start. " \
127 "Try again, or contact GE Service for support.\"; " \
128 "echo $msg; " \
129 "setenv stdout vga; " \
130 "echo \"\n\n\n\n \" $msg; " \
131 "setenv stdout serial; " \
132 "mw.b 0x7000A000 0xbc; " \
133 "mw.b 0x7000A001 0x00; " \
134 "ext4write ${dev} ${devnum}:5 0x7000A000 /boot/failures 2\0" \
135 "altbootcmd=" \
136 "run doquiet; " \
137 "setenv partnum 1; run hasfirstboot || setenv partnum 2; " \
138 "run hasfirstboot || setenv partnum 0; " \
139 "if test ${partnum} != 0; then " \
140 "setenv bootcause REVERT; " \
141 "run swappartitions loadimage doboot; " \
142 "fi; " \
143 "run failbootcmd\0" \
144 "loadimage=" \
145 "ext2load ${dev} ${devnum}:${partnum} ${loadaddr} ${image}\0" \
146 "doboot=" \
147 "echo Booting from ${dev}:${devnum}:${partnum} ...; " \
148 "run setargs; " \
149 "run bootargs_emmc; " \
150 "bootm ${loadaddr}\0" \
151 "tryboot=" \
152 "setenv partnum 1; run hasfirstboot || setenv partnum 2; " \
153 "run loadimage || run swappartitions && run loadimage || " \
154 "setenv partnum 0 && echo MISSING IMAGE;" \
155 "run doboot; " \
156 "run failbootcmd\0" \
157 "video-mode=" \
158 "lcd:800x480-24@60,monitor=lcd\0" \
159
160#define CONFIG_MMCBOOTCOMMAND \
161 "if mmc dev ${devnum}; then " \
162 "run doquiet; " \
163 "run tryboot; " \
164 "fi; " \
165
166#define CONFIG_BOOTCOMMAND CONFIG_MMCBOOTCOMMAND
167
168#define CONFIG_ARP_TIMEOUT 200UL
169
170/* Miscellaneous configurable options */
Peter Senna Tschudin56d96922017-11-06 19:14:11 +0000171#define CONFIG_SYS_CBSIZE 1024 /* Console I/O Buffer Size */
172
173#define CONFIG_SYS_MAXARGS 48 /* max number of command args */
174#define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE /* Boot Argument Buffer Size */
175
176#define CONFIG_SYS_MEMTEST_START 0x70000000
177#define CONFIG_SYS_MEMTEST_END 0x70010000
178
179#define CONFIG_SYS_LOAD_ADDR CONFIG_LOADADDR
180
Peter Senna Tschudin56d96922017-11-06 19:14:11 +0000181/* Physical Memory Map */
182#define CONFIG_NR_DRAM_BANKS 2
183#define PHYS_SDRAM_1 CSD0_BASE_ADDR
184#define PHYS_SDRAM_1_SIZE (gd->bd->bi_dram[0].size)
185#define PHYS_SDRAM_2 CSD1_BASE_ADDR
186#define PHYS_SDRAM_2_SIZE (gd->bd->bi_dram[1].size)
187#define PHYS_SDRAM_SIZE (gd->ram_size)
188
189#define CONFIG_SYS_SDRAM_BASE (PHYS_SDRAM_1)
190#define CONFIG_SYS_INIT_RAM_ADDR (IRAM_BASE_ADDR)
191#define CONFIG_SYS_INIT_RAM_SIZE (IRAM_SIZE)
192
193#define CONFIG_SYS_INIT_SP_OFFSET \
194 (CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
195#define CONFIG_SYS_INIT_SP_ADDR \
196 (CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
197
198/* FLASH and environment organization */
Nandor Han339befa2018-02-15 11:41:21 +0100199#define CONFIG_ENV_OFFSET (12 * 64 * 1024)
200#define CONFIG_ENV_SIZE (10 * 1024)
Peter Senna Tschudin56d96922017-11-06 19:14:11 +0000201#define CONFIG_SYS_MMC_ENV_DEV 0
202
203#define CONFIG_CMD_FUSE
204#define CONFIG_FSL_IIM
205
206#define CONFIG_SYS_I2C_SPEED 100000
207
208/* I2C1 */
209#define CONFIG_SYS_NUM_I2C_BUSES 9
210#define CONFIG_SYS_I2C_MAX_HOPS 1
211#define CONFIG_SYS_I2C_BUSES { {0, {I2C_NULL_HOP} }, \
212 {0, {{I2C_MUX_PCA9547, 0x70, 0} } }, \
213 {0, {{I2C_MUX_PCA9547, 0x70, 1} } }, \
214 {0, {{I2C_MUX_PCA9547, 0x70, 2} } }, \
215 {0, {{I2C_MUX_PCA9547, 0x70, 3} } }, \
216 {0, {{I2C_MUX_PCA9547, 0x70, 4} } }, \
217 {0, {{I2C_MUX_PCA9547, 0x70, 5} } }, \
218 {0, {{I2C_MUX_PCA9547, 0x70, 6} } }, \
219 {0, {{I2C_MUX_PCA9547, 0x70, 7} } }, \
220 }
221
222#define CONFIG_BCH
223
Peter Senna Tschudin56d96922017-11-06 19:14:11 +0000224/* Backlight Control */
225#define CONFIG_PWM_IMX
226#define CONFIG_IMX6_PWM_PER_CLK 66666000
227
228/* Framebuffer and LCD */
229#ifdef CONFIG_VIDEO
230 #define CONFIG_VIDEO_IPUV3
231#endif
232
233#endif /* __CONFIG_H */