xref: /rk3399_ARM-atf/plat/qemu/qemu_sbsa/include/platform_def.h (revision 6a4da2905872c3087f0fdc4696ab1969ca3ff472)
1 /* SPDX-License-Identifier: BSD-3-Clause
2  *
3  * Copyright (c) 2019-2020, Linaro Limited and Contributors.
4  * All rights reserved.
5  */
6 
7 #ifndef PLATFORM_DEF_H
8 #define PLATFORM_DEF_H
9 
10 #include <arch.h>
11 #include <plat/common/common_def.h>
12 #include <tbbr_img_def.h>
13 
14 /* Special value used to verify platform parameters from BL2 to BL3-1 */
15 #define QEMU_BL31_PLAT_PARAM_VAL	0x0f1e2d3c4b5a6978ULL
16 
17 #define PLATFORM_STACK_SIZE		0x1000
18 
19 #define PLATFORM_MAX_CPUS_PER_CLUSTER	U(8)
20 /*
21  * Define the number of cores per cluster used in calculating core position.
22  * The cluster number is shifted by this value and added to the core ID,
23  * so its value represents log2(cores/cluster).
24  * Default is 2**(3) = 8 cores per cluster.
25  */
26 #define PLATFORM_CPU_PER_CLUSTER_SHIFT	U(3)
27 #define PLATFORM_CLUSTER_COUNT		U(64)
28 #define PLATFORM_CORE_COUNT		(PLATFORM_CLUSTER_COUNT * \
29 					PLATFORM_MAX_CPUS_PER_CLUSTER)
30 #define QEMU_PRIMARY_CPU		U(0)
31 
32 #define PLAT_NUM_PWR_DOMAINS		(PLATFORM_CLUSTER_COUNT + \
33 					PLATFORM_CORE_COUNT)
34 #define PLAT_MAX_PWR_LVL		MPIDR_AFFLVL1
35 
36 #define PLAT_MAX_RET_STATE		1
37 #define PLAT_MAX_OFF_STATE		2
38 
39 /* Local power state for power domains in Run state. */
40 #define PLAT_LOCAL_STATE_RUN		0
41 /* Local power state for retention. Valid only for CPU power domains */
42 #define PLAT_LOCAL_STATE_RET		1
43 /*
44  * Local power state for OFF/power-down. Valid for CPU and cluster power
45  * domains.
46  */
47 #define PLAT_LOCAL_STATE_OFF		2
48 
49 /*
50  * Macros used to parse state information from State-ID if it is using the
51  * recommended encoding for State-ID.
52  */
53 #define PLAT_LOCAL_PSTATE_WIDTH		4
54 #define PLAT_LOCAL_PSTATE_MASK		((1 << PLAT_LOCAL_PSTATE_WIDTH) - 1)
55 
56 /*
57  * Some data must be aligned on the biggest cache line size in the platform.
58  * This is known only to the platform as it might have a combination of
59  * integrated and external caches.
60  */
61 #define CACHE_WRITEBACK_SHIFT		6
62 #define CACHE_WRITEBACK_GRANULE		(1 << CACHE_WRITEBACK_SHIFT)
63 
64 /*
65  * Define the max number of memory nodes.
66  */
67 #define PLAT_MAX_MEM_NODES	128
68 
69 /*
70  * Partition memory into secure ROM, non-secure DRAM, secure "SRAM",
71  * and secure DRAM.
72  */
73 #define SEC_ROM_BASE			0x00000000
74 #define SEC_ROM_SIZE			0x00020000
75 
76 #define NS_DRAM0_BASE			0x10000000000ULL
77 #define NS_DRAM0_SIZE			0x00020000000
78 
79 #define SEC_SRAM_BASE			0x20000000
80 #define SEC_SRAM_SIZE			0x20000000
81 
82 /*
83  * RAD just placeholders, need to be chosen after finalizing mem map
84  */
85 #define SEC_DRAM_BASE			0x1000
86 #define SEC_DRAM_SIZE			0x1000
87 
88 /* Load pageable part of OP-TEE 2MB above secure DRAM base */
89 #define QEMU_OPTEE_PAGEABLE_LOAD_BASE	(SEC_DRAM_BASE + 0x00200000)
90 #define QEMU_OPTEE_PAGEABLE_LOAD_SIZE	0x00400000
91 
92 /*
93  * ARM-TF lives in SRAM, partition it here
94  */
95 
96 #define SHARED_RAM_BASE			SEC_SRAM_BASE
97 #define SHARED_RAM_SIZE			0x00002000
98 
99 #define PLAT_QEMU_TRUSTED_MAILBOX_BASE	SHARED_RAM_BASE
100 #define PLAT_QEMU_TRUSTED_MAILBOX_SIZE	(8 + PLAT_QEMU_HOLD_SIZE)
101 #define PLAT_QEMU_HOLD_BASE		(PLAT_QEMU_TRUSTED_MAILBOX_BASE + 8)
102 #define PLAT_QEMU_HOLD_SIZE		(PLATFORM_CORE_COUNT * \
103 					 PLAT_QEMU_HOLD_ENTRY_SIZE)
104 #define PLAT_QEMU_HOLD_ENTRY_SHIFT	3
105 #define PLAT_QEMU_HOLD_ENTRY_SIZE	(1 << PLAT_QEMU_HOLD_ENTRY_SHIFT)
106 #define PLAT_QEMU_HOLD_STATE_WAIT	0
107 #define PLAT_QEMU_HOLD_STATE_GO		1
108 
109 #define BL_RAM_BASE			(SHARED_RAM_BASE + SHARED_RAM_SIZE)
110 #define BL_RAM_SIZE			(SEC_SRAM_SIZE - SHARED_RAM_SIZE)
111 
112 /*
113  * BL1 specific defines.
114  *
115  * BL1 RW data is relocated from ROM to RAM at runtime so we need 2 sets of
116  * addresses.
117  * Put BL1 RW at the top of the Secure SRAM. BL1_RW_BASE is calculated using
118  * the current BL1 RW debug size plus a little space for growth.
119  */
120 #define BL1_SIZE			0x12000
121 #define BL1_RO_BASE			SEC_ROM_BASE
122 #define BL1_RO_LIMIT			(SEC_ROM_BASE + SEC_ROM_SIZE)
123 #define BL1_RW_BASE			(BL1_RW_LIMIT - BL1_SIZE)
124 #define BL1_RW_LIMIT			(BL_RAM_BASE + BL_RAM_SIZE)
125 
126 /*
127  * BL2 specific defines.
128  *
129  * Put BL2 just below BL3-1. BL2_BASE is calculated using the current BL2 debug
130  * size plus a little space for growth.
131  */
132 #define BL2_SIZE			0x1D000
133 #define BL2_BASE			(BL31_BASE - BL2_SIZE)
134 #define BL2_LIMIT			BL31_BASE
135 
136 /*
137  * BL3-1 specific defines.
138  *
139  * Put BL3-1 at the top of the Trusted SRAM. BL31_BASE is calculated using the
140  * current BL3-1 debug size plus a little space for growth.
141  */
142 #define BL31_SIZE			0x300000
143 #define BL31_BASE			(BL31_LIMIT - BL31_SIZE)
144 #define BL31_LIMIT			(BL1_RW_BASE)
145 #define BL31_PROGBITS_LIMIT		BL1_RW_BASE
146 
147 
148 /*
149  * BL3-2 specific defines.
150  *
151  * BL3-2 can execute from Secure SRAM, or Secure DRAM.
152  */
153 #define BL32_SRAM_BASE			BL_RAM_BASE
154 #define BL32_SRAM_LIMIT			BL2_BASE
155 
156 #define BL32_MEM_BASE			BL_RAM_BASE
157 #define BL32_MEM_SIZE			(BL_RAM_SIZE - BL1_SIZE - \
158 					BL2_SIZE - BL31_SIZE)
159 #define BL32_BASE			BL32_SRAM_BASE
160 #define BL32_LIMIT			BL32_SRAM_LIMIT
161 
162 #define NS_IMAGE_OFFSET			(NS_DRAM0_BASE + 0x20000000)
163 #define NS_IMAGE_MAX_SIZE		(NS_DRAM0_SIZE - 0x20000000)
164 
165 #define PLAT_PHY_ADDR_SPACE_SIZE	(1ull << 42)
166 #define PLAT_VIRT_ADDR_SPACE_SIZE	(1ull << 42)
167 #if SPM_MM
168 #define MAX_MMAP_REGIONS		12
169 #define MAX_XLAT_TABLES			12
170 #else
171 #define MAX_MMAP_REGIONS		11
172 #define MAX_XLAT_TABLES			11
173 #endif
174 #define MAX_IO_DEVICES			3
175 #define MAX_IO_HANDLES			4
176 
177 #if SPM_MM && defined(IMAGE_BL31)
178 # define PLAT_SP_IMAGE_MMAP_REGIONS	30
179 # define PLAT_SP_IMAGE_MAX_XLAT_TABLES	50
180 #endif
181 
182 /*
183  * PL011 related constants
184  */
185 #define UART0_BASE			0x60000000
186 #define UART1_BASE			0x60030000
187 #define UART0_CLK_IN_HZ			1
188 #define UART1_CLK_IN_HZ			1
189 
190 /* Secure UART */
191 #define UART2_BASE			0x60040000
192 #define UART2_CLK_IN_HZ			1
193 
194 #define PLAT_QEMU_BOOT_UART_BASE	UART0_BASE
195 #define PLAT_QEMU_BOOT_UART_CLK_IN_HZ	UART0_CLK_IN_HZ
196 
197 #define PLAT_QEMU_CRASH_UART_BASE	UART1_BASE
198 #define PLAT_QEMU_CRASH_UART_CLK_IN_HZ	UART1_CLK_IN_HZ
199 
200 #define PLAT_QEMU_CONSOLE_BAUDRATE	115200
201 
202 #define QEMU_FLASH0_BASE		0x00000000
203 #define QEMU_FLASH0_SIZE		0x10000000
204 #define QEMU_FLASH1_BASE		0x10000000
205 #define QEMU_FLASH1_SIZE		0x10000000
206 
207 #define PLAT_QEMU_FIP_BASE		BL1_SIZE
208 #define PLAT_QEMU_FIP_MAX_SIZE		0x00400000
209 
210 /* This is map from GIC_DIST up to last CPU (255) GIC_REDISTR */
211 #define DEVICE0_BASE			0x40000000
212 #define DEVICE0_SIZE			0x04080000
213 /* This is map from NORMAL_UART up to SECURE_UART_MM */
214 #define DEVICE1_BASE			0x60000000
215 #define DEVICE1_SIZE			0x10041000
216 /* This is a map for SECURE_EC */
217 #define DEVICE2_BASE			0x50000000
218 #define DEVICE2_SIZE			0x00001000
219 
220 /*
221  * GIC related constants
222  * We use GICv3 where CPU Interface registers are not memory mapped
223  *
224  * Legacy values - on platform version 0.1+ they are read from DT
225  */
226 #define GICD_BASE			0x40060000
227 #define GICR_BASE			0x40080000
228 #define GICC_BASE			0x0
229 
230 #define QEMU_IRQ_SEC_SGI_0		8
231 #define QEMU_IRQ_SEC_SGI_1		9
232 #define QEMU_IRQ_SEC_SGI_2		10
233 #define QEMU_IRQ_SEC_SGI_3		11
234 #define QEMU_IRQ_SEC_SGI_4		12
235 #define QEMU_IRQ_SEC_SGI_5		13
236 #define QEMU_IRQ_SEC_SGI_6		14
237 #define QEMU_IRQ_SEC_SGI_7		15
238 
239 /******************************************************************************
240  * On a GICv2 system, the Group 1 secure interrupts are treated as Group 0
241  * interrupts.
242  *****************************************************************************/
243 #define PLATFORM_G1S_PROPS(grp)						\
244 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_0, GIC_HIGHEST_SEC_PRIORITY,	\
245 					   grp, GIC_INTR_CFG_EDGE),	\
246 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_1, GIC_HIGHEST_SEC_PRIORITY,	\
247 					   grp, GIC_INTR_CFG_EDGE),	\
248 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_2, GIC_HIGHEST_SEC_PRIORITY,	\
249 					   grp, GIC_INTR_CFG_EDGE),	\
250 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_3, GIC_HIGHEST_SEC_PRIORITY,	\
251 					   grp, GIC_INTR_CFG_EDGE),	\
252 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_4, GIC_HIGHEST_SEC_PRIORITY,	\
253 					   grp, GIC_INTR_CFG_EDGE),	\
254 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_5, GIC_HIGHEST_SEC_PRIORITY,	\
255 					   grp, GIC_INTR_CFG_EDGE),	\
256 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_6, GIC_HIGHEST_SEC_PRIORITY,	\
257 					   grp, GIC_INTR_CFG_EDGE),	\
258 	INTR_PROP_DESC(QEMU_IRQ_SEC_SGI_7, GIC_HIGHEST_SEC_PRIORITY,	\
259 					   grp, GIC_INTR_CFG_EDGE)
260 
261 #define PLATFORM_G0_PROPS(grp)
262 
263 /*
264  * DT related constants
265  */
266 #define PLAT_QEMU_DT_BASE		NS_DRAM0_BASE
267 #define PLAT_QEMU_DT_MAX_SIZE		0x100000
268 
269 #if SPM_MM
270 #define PLAT_QEMU_SP_IMAGE_BASE		BL_RAM_BASE
271 #define PLAT_QEMU_SP_IMAGE_SIZE		ULL(0x300000)
272 
273 #ifdef IMAGE_BL2
274 /* In BL2 all memory allocated to the SPM Payload image is marked as RW. */
275 # define QEMU_SP_IMAGE_MMAP		MAP_REGION_FLAT( \
276 						PLAT_QEMU_SP_IMAGE_BASE, \
277 						PLAT_QEMU_SP_IMAGE_SIZE, \
278 						MT_MEMORY | MT_RW | \
279 						MT_SECURE)
280 #elif IMAGE_BL31
281 /* All SPM Payload memory is marked as code in S-EL0 */
282 # define QEMU_SP_IMAGE_MMAP		MAP_REGION2(PLAT_QEMU_SP_IMAGE_BASE, \
283 						PLAT_QEMU_SP_IMAGE_BASE, \
284 						PLAT_QEMU_SP_IMAGE_SIZE, \
285 						MT_CODE | MT_SECURE | \
286 						MT_USER,		\
287 						PAGE_SIZE)
288 #endif
289 
290 /*
291  * EL3 -> S-EL0 secure shared memory
292  */
293 #define PLAT_SPM_BUF_PCPU_SIZE		ULL(0x10000)
294 #define PLAT_SPM_BUF_SIZE		(PLATFORM_CORE_COUNT * \
295 					PLAT_SPM_BUF_PCPU_SIZE)
296 #define PLAT_SPM_BUF_BASE		(BL32_LIMIT - PLAT_SPM_BUF_SIZE)
297 
298 #define QEMU_SPM_BUF_EL3_MMAP		MAP_REGION_FLAT(PLAT_SPM_BUF_BASE, \
299 						PLAT_SPM_BUF_SIZE, \
300 						MT_RW_DATA | MT_SECURE)
301 
302 #define QEMU_SPM_BUF_EL0_MMAP		MAP_REGION2(PLAT_SPM_BUF_BASE,	\
303 						PLAT_SPM_BUF_BASE,	\
304 						PLAT_SPM_BUF_SIZE,	\
305 						MT_RO_DATA | MT_SECURE | \
306 						MT_USER,		\
307 						PAGE_SIZE)
308 
309 /*
310  * Shared memory between Normal world and S-EL0 for
311  * passing data during service requests. It will be marked as RW and NS.
312  * This buffer is allocated at the top of NS_DRAM, the base address is
313  * overridden in SPM initialization.
314  */
315 #define PLAT_QEMU_SP_IMAGE_NS_BUF_BASE	(PLAT_QEMU_DT_BASE +		\
316 						PLAT_QEMU_DT_MAX_SIZE)
317 #define PLAT_QEMU_SP_IMAGE_NS_BUF_SIZE	ULL(0x200000)
318 
319 #define QEMU_SP_IMAGE_NS_BUF_MMAP	MAP_REGION2( \
320 					PLAT_QEMU_SP_IMAGE_NS_BUF_BASE, \
321 					PLAT_QEMU_SP_IMAGE_NS_BUF_BASE, \
322 					PLAT_QEMU_SP_IMAGE_NS_BUF_SIZE, \
323 					MT_RW_DATA | MT_NS | \
324 					MT_USER, \
325 					PAGE_SIZE)
326 
327 #define PLAT_SP_IMAGE_NS_BUF_BASE	PLAT_QEMU_SP_IMAGE_NS_BUF_BASE
328 #define PLAT_SP_IMAGE_NS_BUF_SIZE	PLAT_QEMU_SP_IMAGE_NS_BUF_SIZE
329 
330 #define PLAT_QEMU_SP_IMAGE_HEAP_BASE	(PLAT_QEMU_SP_IMAGE_BASE + \
331 					PLAT_QEMU_SP_IMAGE_SIZE)
332 #define PLAT_QEMU_SP_IMAGE_HEAP_SIZE	ULL(0x800000)
333 
334 #define PLAT_SP_IMAGE_STACK_BASE	(PLAT_QEMU_SP_IMAGE_HEAP_BASE + \
335 						PLAT_QEMU_SP_IMAGE_HEAP_SIZE)
336 #define PLAT_SP_IMAGE_STACK_PCPU_SIZE	ULL(0x10000)
337 #define QEMU_SP_IMAGE_STACK_TOTAL_SIZE	(PLATFORM_CORE_COUNT * \
338 						PLAT_SP_IMAGE_STACK_PCPU_SIZE)
339 
340 #define QEMU_SP_IMAGE_RW_MMAP		MAP_REGION2( \
341 					PLAT_QEMU_SP_IMAGE_HEAP_BASE, \
342 					PLAT_QEMU_SP_IMAGE_HEAP_BASE, \
343 					(QEMU_SP_IMAGE_STACK_TOTAL_SIZE + \
344 					PLAT_QEMU_SP_IMAGE_HEAP_SIZE), \
345 					MT_RW_DATA | MT_SECURE | \
346 					MT_USER, \
347 					PAGE_SIZE)
348 
349 /*
350  * Secure variable storage is located at Secure Flash.
351  */
352 #if SPM_MM
353 #define QEMU_SECURE_VARSTORE_BASE 0x01000000
354 #define QEMU_SECURE_VARSTORE_SIZE 0x00100000
355 #define MAP_SECURE_VARSTORE		MAP_REGION_FLAT( \
356 					QEMU_SECURE_VARSTORE_BASE, \
357 					QEMU_SECURE_VARSTORE_SIZE, \
358 					MT_DEVICE | MT_RW | \
359 					MT_SECURE | MT_USER)
360 #endif
361 
362 /* Total number of memory regions with distinct properties */
363 #define PLAT_QEMU_SP_IMAGE_NUM_MEM_REGIONS	6
364 
365 /*
366  * Name of the section to put the translation tables used by the S-EL1/S-EL0
367  * context of a Secure Partition.
368  */
369 #define PLAT_SP_IMAGE_XLAT_SECTION_NAME		".qemu_sp_xlat_table"
370 #define PLAT_SP_IMAGE_BASE_XLAT_SECTION_NAME	".qemu_sp_xlat_table"
371 
372 /* Cookies passed to the Secure Partition at boot. Not used by QEMU platforms.*/
373 #define PLAT_SPM_COOKIE_0		ULL(0)
374 #define PLAT_SPM_COOKIE_1		ULL(0)
375 #endif
376 
377 #define QEMU_PRI_BITS		2
378 #define PLAT_SP_PRI		0x20
379 
380 #endif /* PLATFORM_DEF_H */
381