xref: /rk3399_rockchip-uboot/include/configs/mx6slevk.h (revision c82009058bd9d3fd9774cab36e9d89434f9563f4)
157ca432fSFabio Estevam /*
257ca432fSFabio Estevam  * Copyright 2013 Freescale Semiconductor, Inc.
357ca432fSFabio Estevam  *
457ca432fSFabio Estevam  * Configuration settings for the Freescale i.MX6SL EVK board.
557ca432fSFabio Estevam  *
61a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
757ca432fSFabio Estevam  */
857ca432fSFabio Estevam 
957ca432fSFabio Estevam #ifndef __CONFIG_H
1057ca432fSFabio Estevam #define __CONFIG_H
1157ca432fSFabio Estevam 
1257ca432fSFabio Estevam #include <asm/arch/imx-regs.h>
13694c3bc1SFabio Estevam #include <asm/imx-common/gpio.h>
141ace4022SAlexey Brodkin #include <linux/sizes.h>
15a6bbee66SFabio Estevam #include "mx6_common.h"
1657ca432fSFabio Estevam 
1757ca432fSFabio Estevam #define CONFIG_MX6
1857ca432fSFabio Estevam #define CONFIG_DISPLAY_CPUINFO
1957ca432fSFabio Estevam #define CONFIG_DISPLAY_BOARDINFO
2057ca432fSFabio Estevam 
2157ca432fSFabio Estevam #define MACH_TYPE_MX6SLEVK		4307
2257ca432fSFabio Estevam #define CONFIG_MACH_TYPE		MACH_TYPE_MX6SLEVK
2357ca432fSFabio Estevam 
2457ca432fSFabio Estevam #define CONFIG_CMDLINE_TAG
2557ca432fSFabio Estevam #define CONFIG_SETUP_MEMORY_TAGS
2657ca432fSFabio Estevam #define CONFIG_INITRD_TAG
2757ca432fSFabio Estevam #define CONFIG_REVISION_TAG
2857ca432fSFabio Estevam 
294c97f169SYe.Li #define CONFIG_SYS_GENERIC_BOARD
304c97f169SYe.Li 
3157ca432fSFabio Estevam /* Size of malloc() pool */
3257ca432fSFabio Estevam #define CONFIG_SYS_MALLOC_LEN		(3 * SZ_1M)
3357ca432fSFabio Estevam 
3457ca432fSFabio Estevam #define CONFIG_BOARD_EARLY_INIT_F
3557ca432fSFabio Estevam #define CONFIG_MXC_GPIO
3657ca432fSFabio Estevam 
3757ca432fSFabio Estevam #define CONFIG_MXC_UART
3857ca432fSFabio Estevam #define CONFIG_MXC_UART_BASE		UART1_IPS_BASE_ADDR
3957ca432fSFabio Estevam 
4057ca432fSFabio Estevam /* MMC Configs */
4157ca432fSFabio Estevam #define CONFIG_FSL_ESDHC
4257ca432fSFabio Estevam #define CONFIG_FSL_USDHC
4308129d61SPeng Fan #define CONFIG_SYS_FSL_ESDHC_ADDR	USDHC2_BASE_ADDR
4457ca432fSFabio Estevam 
4557ca432fSFabio Estevam #define CONFIG_MMC
4657ca432fSFabio Estevam #define CONFIG_CMD_MMC
4757ca432fSFabio Estevam #define CONFIG_GENERIC_MMC
4857ca432fSFabio Estevam #define CONFIG_CMD_FAT
4957ca432fSFabio Estevam #define CONFIG_DOS_PARTITION
5057ca432fSFabio Estevam 
51*c8200905SPeng Fan /* I2C Configs */
52*c8200905SPeng Fan #define CONFIG_CMD_I2C
53*c8200905SPeng Fan #define CONFIG_SYS_I2C
54*c8200905SPeng Fan #define CONFIG_SYS_I2C_MXC
55*c8200905SPeng Fan #define CONFIG_SYS_I2C_SPEED		  100000
56*c8200905SPeng Fan 
57*c8200905SPeng Fan /* PMIC */
58*c8200905SPeng Fan #define CONFIG_POWER
59*c8200905SPeng Fan #define CONFIG_POWER_I2C
60*c8200905SPeng Fan #define CONFIG_POWER_PFUZE100
61*c8200905SPeng Fan #define CONFIG_POWER_PFUZE100_I2C_ADDR	0x08
62*c8200905SPeng Fan 
6331f07964SFabio Estevam #define CONFIG_CMD_PING
6431f07964SFabio Estevam #define CONFIG_CMD_DHCP
6531f07964SFabio Estevam #define CONFIG_CMD_MII
6631f07964SFabio Estevam #define CONFIG_CMD_NET
6731f07964SFabio Estevam #define CONFIG_FEC_MXC
6831f07964SFabio Estevam #define CONFIG_MII
6931f07964SFabio Estevam #define IMX_FEC_BASE			ENET_BASE_ADDR
7031f07964SFabio Estevam #define CONFIG_FEC_XCV_TYPE		RMII
7131f07964SFabio Estevam #define CONFIG_ETHPRIME			"FEC"
7231f07964SFabio Estevam #define CONFIG_FEC_MXC_PHYADDR		0
7331f07964SFabio Estevam 
7431f07964SFabio Estevam #define CONFIG_PHYLIB
7531f07964SFabio Estevam #define CONFIG_PHY_SMSC
7631f07964SFabio Estevam 
7757ca432fSFabio Estevam /* allow to overwrite serial and ethaddr */
7857ca432fSFabio Estevam #define CONFIG_ENV_OVERWRITE
7957ca432fSFabio Estevam #define CONFIG_CONS_INDEX		1
8057ca432fSFabio Estevam #define CONFIG_BAUDRATE			115200
8157ca432fSFabio Estevam 
8257ca432fSFabio Estevam /* Command definition */
8357ca432fSFabio Estevam #include <config_cmd_default.h>
8457ca432fSFabio Estevam 
8557ca432fSFabio Estevam #undef CONFIG_CMD_IMLS
8657ca432fSFabio Estevam 
8757ca432fSFabio Estevam #define CONFIG_BOOTDELAY		3
8857ca432fSFabio Estevam 
89af0a37ffSFabio Estevam #define CONFIG_LOADADDR			0x82000000
9057ca432fSFabio Estevam #define CONFIG_SYS_TEXT_BASE		0x87800000
9157ca432fSFabio Estevam 
9257ca432fSFabio Estevam #define CONFIG_EXTRA_ENV_SETTINGS \
9357ca432fSFabio Estevam 	"script=boot.scr\0" \
948e184a53SOtavio Salvador 	"image=zImage\0" \
9557ca432fSFabio Estevam 	"console=ttymxc0\0" \
9657ca432fSFabio Estevam 	"fdt_high=0xffffffff\0" \
9757ca432fSFabio Estevam 	"initrd_high=0xffffffff\0" \
9857ca432fSFabio Estevam 	"fdt_file=imx6sl-evk.dtb\0" \
996fc049beSFabio Estevam 	"fdt_addr=0x88000000\0" \
10057ca432fSFabio Estevam 	"boot_fdt=try\0" \
10157ca432fSFabio Estevam 	"ip_dyn=yes\0" \
102adc5a667SYe.Li 	"mmcdev=1\0" \
10394aeb8a6SOtavio Salvador 	"mmcpart=1\0" \
10494aeb8a6SOtavio Salvador 	"mmcroot=/dev/mmcblk0p2 rootwait rw\0" \
10557ca432fSFabio Estevam 	"mmcargs=setenv bootargs console=${console},${baudrate} " \
10657ca432fSFabio Estevam 		"root=${mmcroot}\0" \
10757ca432fSFabio Estevam 	"loadbootscript=" \
10857ca432fSFabio Estevam 		"fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${script};\0" \
10957ca432fSFabio Estevam 	"bootscript=echo Running bootscript from mmc ...; " \
11057ca432fSFabio Estevam 		"source\0" \
1118e184a53SOtavio Salvador 	"loadimage=fatload mmc ${mmcdev}:${mmcpart} ${loadaddr} ${image}\0" \
11257ca432fSFabio Estevam 	"loadfdt=fatload mmc ${mmcdev}:${mmcpart} ${fdt_addr} ${fdt_file}\0" \
11357ca432fSFabio Estevam 	"mmcboot=echo Booting from mmc ...; " \
11457ca432fSFabio Estevam 		"run mmcargs; " \
11557ca432fSFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
11657ca432fSFabio Estevam 			"if run loadfdt; then " \
1178e184a53SOtavio Salvador 				"bootz ${loadaddr} - ${fdt_addr}; " \
11857ca432fSFabio Estevam 			"else " \
11957ca432fSFabio Estevam 				"if test ${boot_fdt} = try; then " \
1208e184a53SOtavio Salvador 					"bootz; " \
12157ca432fSFabio Estevam 				"else " \
12257ca432fSFabio Estevam 					"echo WARN: Cannot load the DT; " \
12357ca432fSFabio Estevam 				"fi; " \
12457ca432fSFabio Estevam 			"fi; " \
12557ca432fSFabio Estevam 		"else " \
1268e184a53SOtavio Salvador 			"bootz; " \
12757ca432fSFabio Estevam 		"fi;\0" \
12857ca432fSFabio Estevam 	"netargs=setenv bootargs console=${console},${baudrate} " \
12957ca432fSFabio Estevam 		"root=/dev/nfs " \
13057ca432fSFabio Estevam 	"ip=dhcp nfsroot=${serverip}:${nfsroot},v3,tcp\0" \
13157ca432fSFabio Estevam 		"netboot=echo Booting from net ...; " \
13257ca432fSFabio Estevam 		"run netargs; " \
13357ca432fSFabio Estevam 		"if test ${ip_dyn} = yes; then " \
13457ca432fSFabio Estevam 			"setenv get_cmd dhcp; " \
13557ca432fSFabio Estevam 		"else " \
13657ca432fSFabio Estevam 			"setenv get_cmd tftp; " \
13757ca432fSFabio Estevam 		"fi; " \
1388e184a53SOtavio Salvador 		"${get_cmd} ${image}; " \
13957ca432fSFabio Estevam 		"if test ${boot_fdt} = yes || test ${boot_fdt} = try; then " \
14057ca432fSFabio Estevam 			"if ${get_cmd} ${fdt_addr} ${fdt_file}; then " \
1418e184a53SOtavio Salvador 				"bootz ${loadaddr} - ${fdt_addr}; " \
14257ca432fSFabio Estevam 			"else " \
14357ca432fSFabio Estevam 				"if test ${boot_fdt} = try; then " \
1448e184a53SOtavio Salvador 					"bootz; " \
14557ca432fSFabio Estevam 				"else " \
14657ca432fSFabio Estevam 					"echo WARN: Cannot load the DT; " \
14757ca432fSFabio Estevam 				"fi; " \
14857ca432fSFabio Estevam 			"fi; " \
14957ca432fSFabio Estevam 		"else " \
1508e184a53SOtavio Salvador 			"bootz; " \
15157ca432fSFabio Estevam 		"fi;\0"
15257ca432fSFabio Estevam 
15357ca432fSFabio Estevam #define CONFIG_BOOTCOMMAND \
15457ca432fSFabio Estevam 	   "mmc dev ${mmcdev};" \
15557ca432fSFabio Estevam 	   "mmc dev ${mmcdev}; if mmc rescan; then " \
15657ca432fSFabio Estevam 		   "if run loadbootscript; then " \
15757ca432fSFabio Estevam 			   "run bootscript; " \
15857ca432fSFabio Estevam 		   "else " \
1598e184a53SOtavio Salvador 			   "if run loadimage; then " \
16057ca432fSFabio Estevam 				   "run mmcboot; " \
16157ca432fSFabio Estevam 			   "else run netboot; " \
16257ca432fSFabio Estevam 			   "fi; " \
16357ca432fSFabio Estevam 		   "fi; " \
16457ca432fSFabio Estevam 	   "else run netboot; fi"
16557ca432fSFabio Estevam 
16657ca432fSFabio Estevam /* Miscellaneous configurable options */
16757ca432fSFabio Estevam #define CONFIG_SYS_LONGHELP
16857ca432fSFabio Estevam #define CONFIG_SYS_HUSH_PARSER
16957ca432fSFabio Estevam #define CONFIG_AUTO_COMPLETE
17057ca432fSFabio Estevam #define CONFIG_SYS_CBSIZE		256
17157ca432fSFabio Estevam 
17257ca432fSFabio Estevam /* Print Buffer Size */
17357ca432fSFabio Estevam #define CONFIG_SYS_PBSIZE (CONFIG_SYS_CBSIZE + sizeof(CONFIG_SYS_PROMPT) + 16)
17457ca432fSFabio Estevam #define CONFIG_SYS_MAXARGS		16
17557ca432fSFabio Estevam #define CONFIG_SYS_BARGSIZE CONFIG_SYS_CBSIZE
17657ca432fSFabio Estevam 
17757ca432fSFabio Estevam #define CONFIG_SYS_MEMTEST_START	0x80000000
17857ca432fSFabio Estevam #define CONFIG_SYS_MEMTEST_END		(CONFIG_SYS_MEMTEST_START + SZ_512M)
17957ca432fSFabio Estevam 
18057ca432fSFabio Estevam #define CONFIG_SYS_LOAD_ADDR		CONFIG_LOADADDR
18157ca432fSFabio Estevam 
18257ca432fSFabio Estevam #define CONFIG_CMDLINE_EDITING
18357ca432fSFabio Estevam #define CONFIG_STACKSIZE		SZ_128K
18457ca432fSFabio Estevam 
18557ca432fSFabio Estevam /* Physical Memory Map */
18657ca432fSFabio Estevam #define CONFIG_NR_DRAM_BANKS		1
18757ca432fSFabio Estevam #define PHYS_SDRAM			MMDC0_ARB_BASE_ADDR
18857ca432fSFabio Estevam #define PHYS_SDRAM_SIZE			SZ_1G
18957ca432fSFabio Estevam 
19057ca432fSFabio Estevam #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM
19157ca432fSFabio Estevam #define CONFIG_SYS_INIT_RAM_ADDR	IRAM_BASE_ADDR
19257ca432fSFabio Estevam #define CONFIG_SYS_INIT_RAM_SIZE	IRAM_SIZE
19357ca432fSFabio Estevam 
19457ca432fSFabio Estevam #define CONFIG_SYS_INIT_SP_OFFSET \
19557ca432fSFabio Estevam 	(CONFIG_SYS_INIT_RAM_SIZE - GENERATED_GBL_DATA_SIZE)
19657ca432fSFabio Estevam #define CONFIG_SYS_INIT_SP_ADDR \
19757ca432fSFabio Estevam 	(CONFIG_SYS_INIT_RAM_ADDR + CONFIG_SYS_INIT_SP_OFFSET)
19857ca432fSFabio Estevam 
19957ca432fSFabio Estevam /* FLASH and environment organization */
20057ca432fSFabio Estevam #define CONFIG_SYS_NO_FLASH
20157ca432fSFabio Estevam 
20257ca432fSFabio Estevam #define CONFIG_ENV_SIZE			SZ_8K
203be2fde60SPeng Fan 
204be2fde60SPeng Fan #if defined CONFIG_SYS_BOOT_SPINOR
205be2fde60SPeng Fan #define CONFIG_ENV_IS_IN_SPI_FLASH
206be2fde60SPeng Fan #define CONFIG_ENV_OFFSET               (768 * 1024)
207be2fde60SPeng Fan #define CONFIG_ENV_SECT_SIZE            (64 * 1024)
208be2fde60SPeng Fan #define CONFIG_ENV_SPI_BUS              CONFIG_SF_DEFAULT_BUS
209be2fde60SPeng Fan #define CONFIG_ENV_SPI_CS               CONFIG_SF_DEFAULT_CS
210be2fde60SPeng Fan #define CONFIG_ENV_SPI_MODE             CONFIG_SF_DEFAULT_MODE
211be2fde60SPeng Fan #define CONFIG_ENV_SPI_MAX_HZ           CONFIG_SF_DEFAULT_SPEED
212be2fde60SPeng Fan #else
2130da040bfSYe.Li #define CONFIG_ENV_OFFSET		(8 * SZ_64K)
21457ca432fSFabio Estevam #define CONFIG_ENV_IS_IN_MMC
215be2fde60SPeng Fan #endif
21657ca432fSFabio Estevam 
21757ca432fSFabio Estevam #define CONFIG_OF_LIBFDT
21857ca432fSFabio Estevam #define CONFIG_CMD_BOOTZ
21957ca432fSFabio Estevam 
22057ca432fSFabio Estevam #ifndef CONFIG_SYS_DCACHE_OFF
22157ca432fSFabio Estevam #define CONFIG_CMD_CACHE
22257ca432fSFabio Estevam #endif
22357ca432fSFabio Estevam 
224694c3bc1SFabio Estevam #define CONFIG_CMD_SF
225694c3bc1SFabio Estevam #ifdef CONFIG_CMD_SF
226694c3bc1SFabio Estevam #define CONFIG_SPI_FLASH
227694c3bc1SFabio Estevam #define CONFIG_SPI_FLASH_STMICRO
228694c3bc1SFabio Estevam #define CONFIG_MXC_SPI
229694c3bc1SFabio Estevam #define CONFIG_SF_DEFAULT_BUS		0
230155fa9afSNikita Kiryanov #define CONFIG_SF_DEFAULT_CS		0
231694c3bc1SFabio Estevam #define CONFIG_SF_DEFAULT_SPEED		20000000
232694c3bc1SFabio Estevam #define CONFIG_SF_DEFAULT_MODE		SPI_MODE_0
233694c3bc1SFabio Estevam #endif
234694c3bc1SFabio Estevam 
2353b9c1a5dSPeng Fan /* USB Configs */
2363b9c1a5dSPeng Fan #define CONFIG_CMD_USB
2373b9c1a5dSPeng Fan #ifdef CONFIG_CMD_USB
2383b9c1a5dSPeng Fan #define CONFIG_USB_EHCI
2393b9c1a5dSPeng Fan #define CONFIG_USB_EHCI_MX6
2403b9c1a5dSPeng Fan #define CONFIG_USB_STORAGE
2413b9c1a5dSPeng Fan #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
2423b9c1a5dSPeng Fan #define CONFIG_USB_HOST_ETHER
2433b9c1a5dSPeng Fan #define CONFIG_USB_ETHER_ASIX
2443b9c1a5dSPeng Fan #define CONFIG_MXC_USB_PORTSC		(PORT_PTS_UTMI | PORT_PTS_PTW)
2453b9c1a5dSPeng Fan #define CONFIG_MXC_USB_FLAGS		0
2463b9c1a5dSPeng Fan #define CONFIG_USB_MAX_CONTROLLER_COUNT	2
2473b9c1a5dSPeng Fan #endif
2483b9c1a5dSPeng Fan 
24936255d67SYe.Li #define CONFIG_SYS_FSL_USDHC_NUM	3
25036255d67SYe.Li #if defined(CONFIG_ENV_IS_IN_MMC)
25136255d67SYe.Li #define CONFIG_SYS_MMC_ENV_DEV		1	/* SDHC2*/
25236255d67SYe.Li #endif
25336255d67SYe.Li 
25457ca432fSFabio Estevam #endif				/* __CONFIG_H */
255