xref: /rk3399_rockchip-uboot/include/configs/dragonboard410c.h (revision f58ad98a621ce5059d9608a9b41cfabac277094a)
1626f048bSMateusz Kulikowski /*
2626f048bSMateusz Kulikowski  * Board configuration file for Dragonboard 410C
3626f048bSMateusz Kulikowski  *
4626f048bSMateusz Kulikowski  * (C) Copyright 2015 Mateusz Kulikowski <mateusz.kulikowski@gmail.com>
5626f048bSMateusz Kulikowski  *
6626f048bSMateusz Kulikowski  * SPDX-License-Identifier:	GPL-2.0+
7626f048bSMateusz Kulikowski  */
8626f048bSMateusz Kulikowski 
9626f048bSMateusz Kulikowski #ifndef __CONFIGS_DRAGONBOARD410C_H
10626f048bSMateusz Kulikowski #define __CONFIGS_DRAGONBOARD410C_H
11626f048bSMateusz Kulikowski 
12626f048bSMateusz Kulikowski #include <linux/sizes.h>
13626f048bSMateusz Kulikowski #include <asm/arch/sysmap-apq8016.h>
14626f048bSMateusz Kulikowski 
15626f048bSMateusz Kulikowski #define CONFIG_MISC_INIT_R /* To stop autoboot */
16626f048bSMateusz Kulikowski 
17626f048bSMateusz Kulikowski /* Physical Memory Map */
18626f048bSMateusz Kulikowski #define CONFIG_NR_DRAM_BANKS		1
19626f048bSMateusz Kulikowski #define PHYS_SDRAM_1			0x80000000
20626f048bSMateusz Kulikowski /* 1008 MB (the last ~30Mb are secured for TrustZone by ATF*/
21626f048bSMateusz Kulikowski #define PHYS_SDRAM_1_SIZE		0x3da00000
22626f048bSMateusz Kulikowski #define CONFIG_SYS_SDRAM_BASE		PHYS_SDRAM_1
23626f048bSMateusz Kulikowski #define CONFIG_SYS_TEXT_BASE		0x80080000
24626f048bSMateusz Kulikowski #define CONFIG_SYS_INIT_SP_ADDR		(CONFIG_SYS_SDRAM_BASE + 0x7fff0)
25626f048bSMateusz Kulikowski #define CONFIG_SYS_LOAD_ADDR		(CONFIG_SYS_SDRAM_BASE + 0x80000)
26626f048bSMateusz Kulikowski #define CONFIG_SYS_BOOTM_LEN		0x1000000 /* 16MB max kernel size */
27626f048bSMateusz Kulikowski 
28626f048bSMateusz Kulikowski /* UART */
29626f048bSMateusz Kulikowski 
30626f048bSMateusz Kulikowski /* Generic Timer Definitions */
31626f048bSMateusz Kulikowski #define COUNTER_FREQUENCY		19000000
32626f048bSMateusz Kulikowski 
33626f048bSMateusz Kulikowski #define CONFIG_SYS_LDSCRIPT "board/qualcomm/dragonboard410c/u-boot.lds"
34626f048bSMateusz Kulikowski 
35626f048bSMateusz Kulikowski /* Fixup - in init code we switch from device to host mode,
36626f048bSMateusz Kulikowski  * it has to be done after each HCD reset */
37626f048bSMateusz Kulikowski #define CONFIG_EHCI_HCD_INIT_AFTER_RESET
38626f048bSMateusz Kulikowski 
39626f048bSMateusz Kulikowski /* Support all possible USB ethernet dongles */
40626f048bSMateusz Kulikowski 
41626f048bSMateusz Kulikowski /* Extra Commands */
42626f048bSMateusz Kulikowski /* Enable that for switching of boot partitions */
43626f048bSMateusz Kulikowski /* Disabled by default as some sub-commands can brick eMMC */
44626f048bSMateusz Kulikowski /*#define CONFIG_SUPPORT_EMMC_BOOT */
45626f048bSMateusz Kulikowski 
46626f048bSMateusz Kulikowski /* Partition table support */
47626f048bSMateusz Kulikowski #define HAVE_BLOCK_DEVICE /* Needed for partition commands */
48626f048bSMateusz Kulikowski 
49626f048bSMateusz Kulikowski #include <config_distro_defaults.h>
50626f048bSMateusz Kulikowski 
51626f048bSMateusz Kulikowski /* BOOTP options */
52626f048bSMateusz Kulikowski #define CONFIG_BOOTP_BOOTFILESIZE
53626f048bSMateusz Kulikowski 
54626f048bSMateusz Kulikowski #define BOOT_TARGET_DEVICES(func) \
55626f048bSMateusz Kulikowski 	func(USB, usb, 0) \
56626f048bSMateusz Kulikowski 	func(MMC, mmc, 1) \
575a6f5766SRicardo Salveti de Araujo 	func(MMC, mmc, 0) \
58626f048bSMateusz Kulikowski 	func(DHCP, dhcp, na)
59626f048bSMateusz Kulikowski 
60626f048bSMateusz Kulikowski #include <config_distro_bootcmd.h>
61626f048bSMateusz Kulikowski 
62626f048bSMateusz Kulikowski /* Does what recovery does */
63626f048bSMateusz Kulikowski #define REFLASH(file, part) \
64626f048bSMateusz Kulikowski "part start mmc 0 "#part" start && "\
65626f048bSMateusz Kulikowski "part size mmc 0 "#part" size && "\
66626f048bSMateusz Kulikowski "tftp $loadaddr "#file" && " \
67626f048bSMateusz Kulikowski "mmc write $loadaddr $start $size && "
68626f048bSMateusz Kulikowski 
69626f048bSMateusz Kulikowski #define CONFIG_ENV_REFLASH \
70626f048bSMateusz Kulikowski "mmc dev 0 && "\
71626f048bSMateusz Kulikowski "usb start && "\
72626f048bSMateusz Kulikowski "dhcp && "\
73626f048bSMateusz Kulikowski "tftp $loadaddr dragonboard/rescue/gpt_both0.bin && "\
74626f048bSMateusz Kulikowski "mmc write $loadaddr 0 43 && " \
75626f048bSMateusz Kulikowski "mmc rescan && "\
76626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/NON-HLOS.bin, 1)\
77626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/sbl1.mbn, 2)\
78626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/rpm.mbn, 3)\
79626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/tz.mbn, 4)\
80626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/hyp.mbn, 5)\
81626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/sec.dat, 6)\
82626f048bSMateusz Kulikowski REFLASH(dragonboard/rescue/emmc_appsboot.mbn, 7)\
83626f048bSMateusz Kulikowski REFLASH(dragonboard/u-boot.img, 8)\
84626f048bSMateusz Kulikowski "usb stop &&"\
85626f048bSMateusz Kulikowski "echo Reflash completed"
86626f048bSMateusz Kulikowski 
87626f048bSMateusz Kulikowski /* Environment */
88626f048bSMateusz Kulikowski #define CONFIG_EXTRA_ENV_SETTINGS \
89626f048bSMateusz Kulikowski 	"reflash="CONFIG_ENV_REFLASH"\0"\
90626f048bSMateusz Kulikowski 	"loadaddr=0x81000000\0" \
91626f048bSMateusz Kulikowski 	"fdt_high=0xffffffffffffffff\0" \
92626f048bSMateusz Kulikowski 	"initrd_high=0xffffffffffffffff\0" \
93626f048bSMateusz Kulikowski 	"linux_image=Image\0" \
94093685a9SAndreas Färber 	"kernel_addr_r=0x81000000\0"\
95093685a9SAndreas Färber 	"fdtfile=apq8016-sbc.dtb\0" \
96093685a9SAndreas Färber 	"fdt_addr_r=0x83000000\0"\
97093685a9SAndreas Färber 	"ramdisk_addr_r=0x84000000\0"\
98*a3e2efcbSRicardo Salveti de Araujo 	"scriptaddr=0x90000000\0"\
99*a3e2efcbSRicardo Salveti de Araujo 	"pxefile_addr_r=0x90100000\0"\
100626f048bSMateusz Kulikowski 	BOOTENV
101626f048bSMateusz Kulikowski 
102333463d6SMateusz Kulikowski #define CONFIG_ENV_SIZE			0x2000
103626f048bSMateusz Kulikowski #define CONFIG_ENV_VARS_UBOOT_CONFIG
104626f048bSMateusz Kulikowski 
105626f048bSMateusz Kulikowski /* Size of malloc() pool */
106626f048bSMateusz Kulikowski #define CONFIG_SYS_MALLOC_LEN		(CONFIG_ENV_SIZE + SZ_8M)
107626f048bSMateusz Kulikowski 
108626f048bSMateusz Kulikowski /* Monitor Command Prompt */
109626f048bSMateusz Kulikowski #define CONFIG_SYS_CBSIZE		512	/* Console I/O Buffer Size */
110626f048bSMateusz Kulikowski #define CONFIG_SYS_MAXARGS		64	/* max command args */
111626f048bSMateusz Kulikowski 
112626f048bSMateusz Kulikowski #endif
113