xref: /rk3399_ARM-atf/plat/arm/board/juno/juno_def.h (revision 6b76d1e94e5957269756dcc936a692af81f38b67)
185135283SDan Handley /*
2*3f34663fSManish V Badarkhe  * Copyright (c) 2014-2020, ARM Limited and Contributors. All rights reserved.
385135283SDan Handley  *
482cb2c1aSdp-arm  * SPDX-License-Identifier: BSD-3-Clause
585135283SDan Handley  */
685135283SDan Handley 
71083b2b3SAntonio Nino Diaz #ifndef JUNO_DEF_H
81083b2b3SAntonio Nino Diaz #define JUNO_DEF_H
985135283SDan Handley 
1009d40e0eSAntonio Nino Diaz #include <lib/utils_def.h>
1185135283SDan Handley 
12*3f34663fSManish V Badarkhe /******************************************************************************
13*3f34663fSManish V Badarkhe  * Definition of platform soc id
14*3f34663fSManish V Badarkhe  *****************************************************************************/
15*3f34663fSManish V Badarkhe #define JUNO_SOC_ID     1
16*3f34663fSManish V Badarkhe 
1785135283SDan Handley /*******************************************************************************
1885135283SDan Handley  * Juno memory map related constants
1985135283SDan Handley  ******************************************************************************/
2085135283SDan Handley 
2185135283SDan Handley /* Board revisions */
22f21c6321SAntonio Nino Diaz #define REV_JUNO_R0			U(0x1)	/* Rev B */
23f21c6321SAntonio Nino Diaz #define REV_JUNO_R1			U(0x2)	/* Rev C */
24f21c6321SAntonio Nino Diaz #define REV_JUNO_R2			U(0x3)	/* Rev D */
2585135283SDan Handley 
2685135283SDan Handley /* Bypass offset from start of NOR flash */
27f21c6321SAntonio Nino Diaz #define BL1_ROM_BYPASS_OFFSET		UL(0x03EC0000)
2885135283SDan Handley 
29f21c6321SAntonio Nino Diaz #define EMMC_BASE			UL(0x0c000000)
30f21c6321SAntonio Nino Diaz #define EMMC_SIZE			UL(0x04000000)
3185135283SDan Handley 
32f21c6321SAntonio Nino Diaz #define PSRAM_BASE			UL(0x14000000)
33f21c6321SAntonio Nino Diaz #define PSRAM_SIZE			UL(0x02000000)
3485135283SDan Handley 
35f21c6321SAntonio Nino Diaz #define JUNO_SSC_VER_PART_NUM		U(0x030)
3685135283SDan Handley 
3785135283SDan Handley /*******************************************************************************
380108047aSSoby Mathew  * Juno topology related constants
390108047aSSoby Mathew  ******************************************************************************/
405b33ad17SDeepika Bhavnani #define JUNO_CLUSTER_COUNT		U(2)
415b33ad17SDeepika Bhavnani #define JUNO_CLUSTER0_CORE_COUNT	U(2)
425b33ad17SDeepika Bhavnani #define JUNO_CLUSTER1_CORE_COUNT	U(4)
430108047aSSoby Mathew 
440108047aSSoby Mathew /*******************************************************************************
4585135283SDan Handley  * TZC-400 related constants
4685135283SDan Handley  ******************************************************************************/
4785135283SDan Handley #define TZC400_NSAID_CCI400		0  /* Note: Same as default NSAID!! */
4885135283SDan Handley #define TZC400_NSAID_PCIE		1
4985135283SDan Handley #define TZC400_NSAID_HDLCD0		2
5085135283SDan Handley #define TZC400_NSAID_HDLCD1		3
5185135283SDan Handley #define TZC400_NSAID_USB		4
5285135283SDan Handley #define TZC400_NSAID_DMA330		5
5385135283SDan Handley #define TZC400_NSAID_THINLINKS		6
5485135283SDan Handley #define TZC400_NSAID_AP			9
5585135283SDan Handley #define TZC400_NSAID_GPU		10
5685135283SDan Handley #define TZC400_NSAID_SCP		11
5785135283SDan Handley #define TZC400_NSAID_CORESIGHT		12
5885135283SDan Handley 
5985135283SDan Handley /*******************************************************************************
60df9a39eaSdp-arm  * TRNG related constants
61df9a39eaSdp-arm  ******************************************************************************/
62f21c6321SAntonio Nino Diaz #define TRNG_BASE	UL(0x7FE60000)
63df9a39eaSdp-arm #define TRNG_NOUTPUTS	4
64f21c6321SAntonio Nino Diaz #define TRNG_STATUS	UL(0x10)
65f21c6321SAntonio Nino Diaz #define TRNG_INTMASK	UL(0x14)
66f21c6321SAntonio Nino Diaz #define TRNG_CONFIG	UL(0x18)
67f21c6321SAntonio Nino Diaz #define TRNG_CONTROL	UL(0x1C)
68e6d2aea1Sdp-arm #define TRNG_NBYTES	16	/* Number of bytes generated per round. */
69df9a39eaSdp-arm 
70df9a39eaSdp-arm /*******************************************************************************
7185135283SDan Handley  * MMU-401 related constants
7285135283SDan Handley  ******************************************************************************/
73f21c6321SAntonio Nino Diaz #define MMU401_SSD_OFFSET		UL(0x4000)
74f21c6321SAntonio Nino Diaz #define MMU401_DMA330_BASE		UL(0x7fb00000)
7585135283SDan Handley 
76a7270d35SVikram Kanigiri /*******************************************************************************
77a7270d35SVikram Kanigiri  * Interrupt handling constants
78a7270d35SVikram Kanigiri  ******************************************************************************/
79a7270d35SVikram Kanigiri #define JUNO_IRQ_DMA_SMMU		126
80a7270d35SVikram Kanigiri #define JUNO_IRQ_HDLCD0_SMMU		128
81a7270d35SVikram Kanigiri #define JUNO_IRQ_HDLCD1_SMMU		130
82a7270d35SVikram Kanigiri #define JUNO_IRQ_USB_SMMU		132
83a7270d35SVikram Kanigiri #define JUNO_IRQ_THIN_LINKS_SMMU	134
84a7270d35SVikram Kanigiri #define JUNO_IRQ_SEC_I2C		137
85a7270d35SVikram Kanigiri #define JUNO_IRQ_GPU_SMMU_1		73
86a7270d35SVikram Kanigiri #define JUNO_IRQ_ETR_SMMU		75
8785135283SDan Handley 
88e237c1baSRoberto Vargas /*******************************************************************************
89e237c1baSRoberto Vargas  * Memprotect definitions
90e237c1baSRoberto Vargas  ******************************************************************************/
91e237c1baSRoberto Vargas /* PSCI memory protect definitions:
92e237c1baSRoberto Vargas  * This variable is stored in a non-secure flash because some ARM reference
93e237c1baSRoberto Vargas  * platforms do not have secure NVRAM. Real systems that provided MEM_PROTECT
94e237c1baSRoberto Vargas  * support must use a secure NVRAM to store the PSCI MEM_PROTECT definitions.
95e237c1baSRoberto Vargas  */
96e237c1baSRoberto Vargas #define PLAT_ARM_MEM_PROT_ADDR		(V2M_FLASH0_BASE + \
97e237c1baSRoberto Vargas 					 V2M_FLASH0_SIZE - V2M_FLASH_BLOCK_SIZE)
98e237c1baSRoberto Vargas 
991083b2b3SAntonio Nino Diaz #endif /* JUNO_DEF_H */
100