xref: /OK3568_Linux_fs/u-boot/include/configs/rockchip-common.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1 /*
2  * (C) Copyright 2016 Rockchip Electronics Co., Ltd
3  *
4  * SPDX-License-Identifier:     GPL-2.0+
5  */
6 
7 #ifndef _ROCKCHIP_COMMON_H_
8 #define _ROCKCHIP_COMMON_H_
9 #include <linux/sizes.h>
10 
11 #define COUNTER_FREQUENCY               24000000
12 
13 #if CONFIG_IS_ENABLED(TINY_FRAMEWORK) && !defined(CONFIG_ARM64)
14 #undef CONFIG_SYS_ARCH_TIMER
15 #else
16 #define CONFIG_SYS_ARCH_TIMER
17 #endif
18 
19 #define CONFIG_SYS_HZ_CLOCK	24000000
20 
21 #define CONFIG_SYS_NS16550_MEM32
22 
23 #ifdef CONFIG_SPL_BUILD
24 #define CONFIG_NR_DRAM_BANKS		2
25 #else
26 #define CONFIG_NR_DRAM_BANKS		12
27 #endif
28 
29 #ifndef CONFIG_SPL_BUILD
30 #include <config_distro_defaults.h>
31 
32 #ifdef CONFIG_CMD_RKNAND
33 #define BOOTENV_SHARED_RKNAND	BOOTENV_SHARED_BLKDEV(rknand)
34 #define BOOTENV_DEV_RKNAND		BOOTENV_DEV_BLKDEV
35 #define BOOTENV_DEV_NAME_RKNAND	BOOTENV_DEV_NAME_BLKDEV
36 #else
37 #define BOOTENV_SHARED_RKNAND
38 #define BOOTENV_DEV_RKNAND \
39 	BOOT_TARGET_DEVICES_references_RKNAND_without_CONFIG_CMD_RKNAND
40 #define BOOTENV_DEV_NAME_RKNAND \
41 	BOOT_TARGET_DEVICES_references_RKNAND_without_CONFIG_CMD_RKNAND
42 #endif
43 
44 #ifdef CONFIG_CMD_MTD_BLK
45 #define BOOTENV_SHARED_MTD				\
46 	"mtd_boot="					\
47 		"if mtd_blk dev ${devnum}; then "	\
48 			"setenv devtype mtd; "		\
49 			"run scan_dev_for_boot_part; "	\
50 		"fi\0"
51 #define BOOTENV_DEV_MTD		BOOTENV_DEV_BLKDEV
52 #define BOOTENV_DEV_NAME_MTD	BOOTENV_DEV_NAME_BLKDEV
53 #else
54 #define BOOTENV_SHARED_MTD
55 #define BOOTENV_DEV_MTD		\
56 	BOOT_TARGET_DEVICES_references_MTD_without_CONFIG_CMD_MTD_BLK
57 #define BOOTENV_DEV_NAME_MTD	\
58 	BOOT_TARGET_DEVICES_references_MTD_without_CONFIG_CMD_MTD_BLK
59 #endif
60 
61 /* First try to boot from SD (index 1), then eMMC (index 0) */
62 #if CONFIG_IS_ENABLED(CMD_MMC)
63 	#define BOOT_TARGET_MMC(func) \
64 		func(MMC, mmc, 1) \
65 		func(MMC, mmc, 0)
66 #else
67 	#define BOOT_TARGET_MMC(func)
68 #endif
69 
70 #if CONFIG_IS_ENABLED(CMD_MTD_BLK)
71 	#define BOOT_TARGET_MTD(func)	\
72 		func(MTD, mtd, 2)	\
73 		func(MTD, mtd, 1)	\
74 		func(MTD, mtd, 0)
75 #else
76 	#define BOOT_TARGET_MTD(func)
77 #endif
78 
79 #if CONFIG_IS_ENABLED(CMD_RKNAND)
80 	#define BOOT_TARGET_RKNAND(func) func(RKNAND, rknand, 0)
81 #else
82 	#define BOOT_TARGET_RKNAND(func)
83 #endif
84 
85 #if CONFIG_IS_ENABLED(CMD_USB)
86 	#define BOOT_TARGET_USB(func) func(USB, usb, 0)
87 #else
88 	#define BOOT_TARGET_USB(func)
89 #endif
90 
91 #if CONFIG_IS_ENABLED(CMD_PXE)
92 	#define BOOT_TARGET_PXE(func) func(PXE, pxe, na)
93 #else
94 	#define BOOT_TARGET_PXE(func)
95 #endif
96 
97 #if CONFIG_IS_ENABLED(CMD_DHCP)
98 	#define BOOT_TARGET_DHCP(func) func(DHCP, dhcp, na)
99 #else
100 	#define BOOT_TARGET_DHCP(func)
101 #endif
102 
103 #define BOOT_TARGET_DEVICES(func) \
104 	BOOT_TARGET_MMC(func) \
105 	BOOT_TARGET_MTD(func) \
106 	BOOT_TARGET_RKNAND(func) \
107 	BOOT_TARGET_USB(func) \
108 	BOOT_TARGET_PXE(func) \
109 	BOOT_TARGET_DHCP(func)
110 
111 #ifdef CONFIG_ARM64
112 #define ROOT_UUID "B921B045-1DF0-41C3-AF44-4C6F280D3FAE;\0"
113 #else
114 #define ROOT_UUID "69DAD710-2CE4-4E3C-B16C-21A1D49ABED3;\0"
115 #endif
116 #define PARTS_DEFAULT \
117 	"uuid_disk=${uuid_gpt_disk};" \
118 	"name=loader1,start=32K,size=4000K,uuid=${uuid_gpt_loader1};" \
119 	"name=loader2,start=8MB,size=4MB,uuid=${uuid_gpt_loader2};" \
120 	"name=trust,size=4M,uuid=${uuid_gpt_atf};" \
121 	"name=boot,size=112M,bootable,uuid=${uuid_gpt_boot};" \
122 	"name=rootfs,size=-,uuid="ROOT_UUID
123 
124 #define PARTS_RKIMG \
125 	"uuid_disk=${uuid_gpt_disk};" \
126 	"name=uboot,start=8MB,size=4MB,uuid=${uuid_gpt_loader2};" \
127 	"name=trust,size=4M,uuid=${uuid_gpt_atf};" \
128 	"name=misc,size=4MB,uuid=${uuid_gpt_misc};" \
129 	"name=resource,size=16MB,uuid=${uuid_gpt_resource};" \
130 	"name=kernel,size=32M,uuid=${uuid_gpt_kernel};" \
131 	"name=boot,size=32M,bootable,uuid=${uuid_gpt_boot};" \
132 	"name=recovery,size=32M,uuid=${uuid_gpt_recovery};" \
133 	"name=backup,size=112M,uuid=${uuid_gpt_backup};" \
134 	"name=cache,size=512M,uuid=${uuid_gpt_cache};" \
135 	"name=system,size=2048M,uuid=${uuid_gpt_system};" \
136 	"name=metadata,size=16M,uuid=${uuid_gpt_metadata};" \
137 	"name=vendor,size=32M,uuid=${uuid_gpt_vendor};" \
138 	"name=oem,size=32M,uuid=${uuid_gpt_oem};" \
139 	"name=frp,size=512K,uuid=${uuid_gpt_frp};" \
140 	"name=security,size=2M,uuid=${uuid_gpt_security};" \
141 	"name=userdata,size=-,uuid=${uuid_gpt_userdata};\0"
142 
143 #define RKIMG_DET_BOOTDEV \
144 	"devnum=0\0" \
145         "devtype=mmc\0" \
146 	"rkimg_bootdev=" \
147 	"if mmc dev 1 && rkimgtest mmc 1; then " \
148 		"setenv devtype mmc; setenv devnum 1; echo Boot from SDcard;" \
149 	"elif mmc dev 0; then " \
150 		"setenv devtype mmc; setenv devnum 0;" \
151 	"elif mtd_blk dev 0; then " \
152 		"setenv devtype mtd; setenv devnum 0;" \
153 	"elif mtd_blk dev 1; then " \
154 		"setenv devtype mtd; setenv devnum 1;" \
155 	"elif mtd_blk dev 2; then " \
156 		"setenv devtype mtd; setenv devnum 2;" \
157 	"elif rknand dev 0; then " \
158 		"setenv devtype rknand; setenv devnum 0;" \
159 	"elif rksfc dev 0; then " \
160 		"setenv devtype spinand; setenv devnum 0;" \
161 	"elif rksfc dev 1; then " \
162 		"setenv devtype spinor; setenv devnum 1;" \
163 	"else;" \
164 		"setenv devtype ramdisk; setenv devnum 0;" \
165 	"fi; \0"
166 
167 #if defined(CONFIG_AVB_VBMETA_PUBLIC_KEY_VALIDATE)
168 #define RKIMG_BOOTCOMMAND			\
169 	"boot_android ${devtype} ${devnum};"
170 #elif defined(CONFIG_FIT_SIGNATURE)
171 #define RKIMG_BOOTCOMMAND			\
172 	"boot_fit;"
173 #else
174 #define RKIMG_BOOTCOMMAND			\
175 	"boot_android ${devtype} ${devnum};"	\
176 	"boot_fit;"				\
177 	"bootrkp;"				\
178 	"run distro_bootcmd;"
179 #endif
180 
181 #endif /* CONFIG_SPL_BUILD */
182 
183 #define CONFIG_DISPLAY_BOARDINFO_LATE
184 #define CONFIG_SYS_AUTOLOAD	"no"
185 #define CONFIG_SPL_LOAD_FIT_ADDRESS		0x2000000
186 
187 #endif /* _ROCKCHIP_COMMON_H_ */
188