xref: /arm-trusted-firmware/plat/arm/board/fvp_r/fvp_r_def.h (revision 91f16700b400a8c0651d24a598fc48ee2997a0d7)
1*91f16700Schasinglulu /*
2*91f16700Schasinglulu  * Copyright (c) 2021, ARM Limited and Contributors. All rights reserved.
3*91f16700Schasinglulu  *
4*91f16700Schasinglulu  * SPDX-License-Identifier: BSD-3-Clause
5*91f16700Schasinglulu  */
6*91f16700Schasinglulu 
7*91f16700Schasinglulu #ifndef FVP_R_DEF_H
8*91f16700Schasinglulu #define FVP_R_DEF_H
9*91f16700Schasinglulu 
10*91f16700Schasinglulu #include <lib/utils_def.h>
11*91f16700Schasinglulu 
12*91f16700Schasinglulu /******************************************************************************
13*91f16700Schasinglulu  * FVP-R topology constants
14*91f16700Schasinglulu  *****************************************************************************/
15*91f16700Schasinglulu #define FVP_R_CLUSTER_COUNT		2
16*91f16700Schasinglulu #define FVP_R_MAX_CPUS_PER_CLUSTER	4
17*91f16700Schasinglulu #define FVP_R_MAX_PE_PER_CPU		1
18*91f16700Schasinglulu #define FVP_R_PRIMARY_CPU		0x0
19*91f16700Schasinglulu 
20*91f16700Schasinglulu /******************************************************************************
21*91f16700Schasinglulu  * Definition of platform soc id
22*91f16700Schasinglulu  *****************************************************************************/
23*91f16700Schasinglulu #define FVP_R_SOC_ID			0
24*91f16700Schasinglulu 
25*91f16700Schasinglulu /*******************************************************************************
26*91f16700Schasinglulu  * FVP_R memory map related constants
27*91f16700Schasinglulu  ******************************************************************************/
28*91f16700Schasinglulu 
29*91f16700Schasinglulu #define FLASH1_BASE			UL(0x8c000000)
30*91f16700Schasinglulu #define FLASH1_SIZE			UL(0x04000000)
31*91f16700Schasinglulu 
32*91f16700Schasinglulu #define PSRAM_BASE			UL(0x94000000)
33*91f16700Schasinglulu #define PSRAM_SIZE			UL(0x04000000)
34*91f16700Schasinglulu 
35*91f16700Schasinglulu #define VRAM_BASE			UL(0x98000000)
36*91f16700Schasinglulu #define VRAM_SIZE			UL(0x02000000)
37*91f16700Schasinglulu 
38*91f16700Schasinglulu /* Aggregate of all devices in the first GB */
39*91f16700Schasinglulu #define DEVICE0_BASE			UL(0xa0000000)
40*91f16700Schasinglulu #define DEVICE0_SIZE			UL(0x0c200000)
41*91f16700Schasinglulu 
42*91f16700Schasinglulu /*
43*91f16700Schasinglulu  *  In case of FVP_R models with CCN, the CCN register space overlaps into
44*91f16700Schasinglulu  *  the NSRAM area.
45*91f16700Schasinglulu  */
46*91f16700Schasinglulu #define DEVICE1_BASE			UL(0xae000000)
47*91f16700Schasinglulu #define DEVICE1_SIZE			UL(0x1A00000)
48*91f16700Schasinglulu 
49*91f16700Schasinglulu #define NSRAM_BASE			UL(0xae000000)
50*91f16700Schasinglulu #define NSRAM_SIZE			UL(0x10000)
51*91f16700Schasinglulu /* Devices in the second GB */
52*91f16700Schasinglulu #define DEVICE2_BASE			UL(0xffe00000)
53*91f16700Schasinglulu #define DEVICE2_SIZE			UL(0x00200000)
54*91f16700Schasinglulu 
55*91f16700Schasinglulu #define PCIE_EXP_BASE			UL(0xc0000000)
56*91f16700Schasinglulu #define TZRNG_BASE			UL(0x7fe60000)
57*91f16700Schasinglulu 
58*91f16700Schasinglulu /* Non-volatile counters */
59*91f16700Schasinglulu #define TRUSTED_NVCTR_BASE		UL(0xffe70000)
60*91f16700Schasinglulu #define TFW_NVCTR_BASE			(TRUSTED_NVCTR_BASE + UL(0x0000))
61*91f16700Schasinglulu #define TFW_NVCTR_SIZE			UL(4)
62*91f16700Schasinglulu #define NTFW_CTR_BASE			(TRUSTED_NVCTR_BASE + UL(0x0004))
63*91f16700Schasinglulu #define NTFW_CTR_SIZE			UL(4)
64*91f16700Schasinglulu 
65*91f16700Schasinglulu /* Keys */
66*91f16700Schasinglulu #define SOC_KEYS_BASE			UL(0xffe80000)
67*91f16700Schasinglulu #define TZ_PUB_KEY_HASH_BASE		(SOC_KEYS_BASE + UL(0x0000))
68*91f16700Schasinglulu #define TZ_PUB_KEY_HASH_SIZE		UL(32)
69*91f16700Schasinglulu #define HU_KEY_BASE			(SOC_KEYS_BASE + UL(0x0020))
70*91f16700Schasinglulu #define HU_KEY_SIZE			UL(16)
71*91f16700Schasinglulu #define END_KEY_BASE			(SOC_KEYS_BASE + UL(0x0044))
72*91f16700Schasinglulu #define END_KEY_SIZE			UL(32)
73*91f16700Schasinglulu 
74*91f16700Schasinglulu /* Constants to distinguish FVP_R type */
75*91f16700Schasinglulu #define HBI_BASE_FVP_R			U(0x020)
76*91f16700Schasinglulu #define REV_BASE_FVP_R_V0		U(0x0)
77*91f16700Schasinglulu #define REV_BASE_FVP_R_REVC		U(0x2)
78*91f16700Schasinglulu 
79*91f16700Schasinglulu #define HBI_FOUNDATION_FVP_R		U(0x010)
80*91f16700Schasinglulu #define REV_FOUNDATION_FVP_R_V2_0	U(0x0)
81*91f16700Schasinglulu #define REV_FOUNDATION_FVP_R_V2_1	U(0x1)
82*91f16700Schasinglulu #define REV_FOUNDATION_FVP_R_v9_1	U(0x2)
83*91f16700Schasinglulu #define REV_FOUNDATION_FVP_R_v9_6	U(0x3)
84*91f16700Schasinglulu 
85*91f16700Schasinglulu #define BLD_GIC_VE_MMAP			U(0x0)
86*91f16700Schasinglulu #define BLD_GIC_A53A57_MMAP		U(0x1)
87*91f16700Schasinglulu 
88*91f16700Schasinglulu #define ARCH_MODEL			U(0x1)
89*91f16700Schasinglulu 
90*91f16700Schasinglulu /* FVP_R Power controller base address*/
91*91f16700Schasinglulu #define PWRC_BASE			UL(0x1c100000)
92*91f16700Schasinglulu 
93*91f16700Schasinglulu /* FVP_R SP804 timer frequency is 35 MHz*/
94*91f16700Schasinglulu #define SP804_TIMER_CLKMULT		1
95*91f16700Schasinglulu #define SP804_TIMER_CLKDIV		35
96*91f16700Schasinglulu 
97*91f16700Schasinglulu /* SP810 controller. FVP_R specific flags */
98*91f16700Schasinglulu #define FVP_R_SP810_CTRL_TIM0_OV		BIT_32(16)
99*91f16700Schasinglulu #define FVP_R_SP810_CTRL_TIM1_OV		BIT_32(18)
100*91f16700Schasinglulu #define FVP_R_SP810_CTRL_TIM2_OV		BIT_32(20)
101*91f16700Schasinglulu #define FVP_R_SP810_CTRL_TIM3_OV		BIT_32(22)
102*91f16700Schasinglulu 
103*91f16700Schasinglulu #endif /* FVP_R_DEF_H */
104