xref: /rk3399_ARM-atf/plat/imx/imx9/imx94/include/platform_def.h (revision 480e8dd9df291cc0e31695983fa6ff235e1671cd)
1*4249a4fbSJacky Bai /*
2*4249a4fbSJacky Bai  * Copyright 2024-2025 NXP
3*4249a4fbSJacky Bai  *
4*4249a4fbSJacky Bai  * SPDX-License-Identifier: BSD-3-Clause
5*4249a4fbSJacky Bai  */
6*4249a4fbSJacky Bai #ifndef PLATFORM_DEF_H
7*4249a4fbSJacky Bai #define PLATFORM_DEF_H
8*4249a4fbSJacky Bai 
9*4249a4fbSJacky Bai #include <lib/utils_def.h>
10*4249a4fbSJacky Bai #include <lib/xlat_tables/xlat_tables_v2.h>
11*4249a4fbSJacky Bai 
12*4249a4fbSJacky Bai #include <imx94_scmi_def.h>
13*4249a4fbSJacky Bai 
14*4249a4fbSJacky Bai #define PLATFORM_LINKER_FORMAT		"elf64-littleaarch64"
15*4249a4fbSJacky Bai #define PLATFORM_LINKER_ARCH		aarch64
16*4249a4fbSJacky Bai 
17*4249a4fbSJacky Bai #define PLATFORM_STACK_SIZE		0xB00
18*4249a4fbSJacky Bai #define CACHE_WRITEBACK_GRANULE		64
19*4249a4fbSJacky Bai 
20*4249a4fbSJacky Bai #define PLAT_PRIMARY_CPU		U(0x0)
21*4249a4fbSJacky Bai #define PLATFORM_MAX_CPU_PER_CLUSTER	U(4)
22*4249a4fbSJacky Bai #define PLATFORM_CLUSTER_COUNT		U(1)
23*4249a4fbSJacky Bai #define PLATFORM_CLUSTER0_CORE_COUNT	U(4)
24*4249a4fbSJacky Bai #define PLATFORM_CORE_COUNT		U(4)
25*4249a4fbSJacky Bai 
26*4249a4fbSJacky Bai #define IMX_PWR_LVL0			MPIDR_AFFLVL0
27*4249a4fbSJacky Bai 
28*4249a4fbSJacky Bai #define PWR_DOMAIN_AT_MAX_LVL		U(1)
29*4249a4fbSJacky Bai #define PLAT_MAX_PWR_LVL		U(2)
30*4249a4fbSJacky Bai #define PLAT_MAX_OFF_STATE		U(4)
31*4249a4fbSJacky Bai #define PLAT_MAX_RET_STATE		U(2)
32*4249a4fbSJacky Bai 
33*4249a4fbSJacky Bai /* DRAM region 256KB */
34*4249a4fbSJacky Bai #define BL31_BASE			U(0x8A200000)
35*4249a4fbSJacky Bai #define BL31_LIMIT			U(0x8A240000)
36*4249a4fbSJacky Bai 
37*4249a4fbSJacky Bai /* non-secure uboot base */
38*4249a4fbSJacky Bai #define PLAT_NS_IMAGE_OFFSET		U(0x90200000)
39*4249a4fbSJacky Bai 
40*4249a4fbSJacky Bai /* GICv4 base address */
41*4249a4fbSJacky Bai #define PLAT_GICD_BASE			U(0x48000000)
42*4249a4fbSJacky Bai #define PLAT_GICR_BASE			U(0x48060000)
43*4249a4fbSJacky Bai #define PLAT_ARM_GICR_BASE		PLAT_GICR_BASE
44*4249a4fbSJacky Bai #define PLAT_ARM_GICD_BASE		PLAT_GICD_BASE
45*4249a4fbSJacky Bai 
46*4249a4fbSJacky Bai #define PLAT_VIRT_ADDR_SPACE_SIZE	(ULL(1) << 32)
47*4249a4fbSJacky Bai #define PLAT_PHY_ADDR_SPACE_SIZE	(ULL(1) << 32)
48*4249a4fbSJacky Bai 
49*4249a4fbSJacky Bai #define MAX_XLAT_TABLES			14U
50*4249a4fbSJacky Bai #define MAX_MMAP_REGIONS		32U
51*4249a4fbSJacky Bai 
52*4249a4fbSJacky Bai #define IMX_LPUART_BASE			0x44380000
53*4249a4fbSJacky Bai 
54*4249a4fbSJacky Bai #define IMX_BOOT_UART_CLK_IN_HZ		24000000 /* Select 24MHz oscillator */
55*4249a4fbSJacky Bai #define IMX_CONSOLE_BAUDRATE		4000000
56*4249a4fbSJacky Bai 
57*4249a4fbSJacky Bai #define AIPSx_SIZE			U(0x800000)
58*4249a4fbSJacky Bai #define AIPS1_BASE			U(0x44000000)
59*4249a4fbSJacky Bai #define AIPS2_BASE			U(0x42000000)
60*4249a4fbSJacky Bai #define AIPS3_BASE			U(0x42800000)
61*4249a4fbSJacky Bai #define AIPS4_BASE			U(0x49000000)
62*4249a4fbSJacky Bai #define MU_SECURE_BASE			U(0x44220000)
63*4249a4fbSJacky Bai #define GPIO1_BASE			U(0x47400000)
64*4249a4fbSJacky Bai #define GPIO2_BASE			U(0x43810000)
65*4249a4fbSJacky Bai #define GPIO3_BASE			U(0x43820000)
66*4249a4fbSJacky Bai #define GPIO4_BASE			U(0x43840000)
67*4249a4fbSJacky Bai #define GPIO5_BASE			U(0x43850000)
68*4249a4fbSJacky Bai #define GPIO6_BASE			U(0x43860000)
69*4249a4fbSJacky Bai #define GPIO7_BASE			U(0x43870000)
70*4249a4fbSJacky Bai #define WDOG3_BASE			U(0x49220000)
71*4249a4fbSJacky Bai #define WDOG4_BASE			U(0x49230000)
72*4249a4fbSJacky Bai 
73*4249a4fbSJacky Bai #define ELE_MU_BASE			U(0x47540000)
74*4249a4fbSJacky Bai 
75*4249a4fbSJacky Bai #define SMT_BUFFER_BASE			U(0x204d6000)
76*4249a4fbSJacky Bai #define SMT_BUFFER_SIZE			0x1000
77*4249a4fbSJacky Bai 
78*4249a4fbSJacky Bai #define IMX9_SCMI_PAYLOAD_BASE		0x44221000
79*4249a4fbSJacky Bai #define IMX9_MU1_BASE			0x44220000
80*4249a4fbSJacky Bai #define MU_GCR_OFF			0x114
81*4249a4fbSJacky Bai 
82*4249a4fbSJacky Bai #define SM_AP_SEMA_ADDR			0x442213F8
83*4249a4fbSJacky Bai 
84*4249a4fbSJacky Bai #define XSPI1_BASE			U(0x42b90000)
85*4249a4fbSJacky Bai #define XSPI2_BASE			U(0x42bE0000)
86*4249a4fbSJacky Bai #define XSPI_MTO			U(0x928)
87*4249a4fbSJacky Bai 
88*4249a4fbSJacky Bai #define GPIO_NUM			6U
89*4249a4fbSJacky Bai #define PER_NUM				30U
90*4249a4fbSJacky Bai #define WDOG_NUM			2U
91*4249a4fbSJacky Bai #define IMR_NUM				15U
92*4249a4fbSJacky Bai 
93*4249a4fbSJacky Bai #define NETC_IREC_PCI_INT_X0		U(359)
94*4249a4fbSJacky Bai 
95*4249a4fbSJacky Bai #define COUNTER_FREQUENCY		24000000
96*4249a4fbSJacky Bai 
97*4249a4fbSJacky Bai /*
98*4249a4fbSJacky Bai  * Define a list of Group 1 Secure and Group 0 interrupt properties
99*4249a4fbSJacky Bai  * as per GICv3 terminology.
100*4249a4fbSJacky Bai  */
101*4249a4fbSJacky Bai #define PLAT_ARM_G1S_IRQ_PROPS(grp) \
102*4249a4fbSJacky Bai 	INTR_PROP_DESC(29U, GIC_HIGHEST_SEC_PRIORITY, grp,   \
103*4249a4fbSJacky Bai 		       GIC_INTR_CFG_LEVEL)
104*4249a4fbSJacky Bai 
105*4249a4fbSJacky Bai #define PLAT_ARM_G0_IRQ_PROPS(grp) \
106*4249a4fbSJacky Bai 	INTR_PROP_DESC(8U, GIC_HIGHEST_SEC_PRIORITY, \
107*4249a4fbSJacky Bai 		       (grp), GIC_INTR_CFG_LEVEL)
108*4249a4fbSJacky Bai 
109*4249a4fbSJacky Bai /* Memory map regions */
110*4249a4fbSJacky Bai #define AIPS2_MAP	MAP_REGION_FLAT(AIPS2_BASE, AIPSx_SIZE, MT_DEVICE | MT_RW)
111*4249a4fbSJacky Bai #define AIPS3_MAP	MAP_REGION_FLAT(AIPS3_BASE, AIPSx_SIZE, MT_DEVICE | MT_RW)
112*4249a4fbSJacky Bai #define GIC_MAP		MAP_REGION_FLAT(PLAT_GICD_BASE, 0x200000, MT_DEVICE | MT_RW)
113*4249a4fbSJacky Bai #define AIPS1_MAP	MAP_REGION_FLAT(AIPS1_BASE, AIPSx_SIZE, MT_DEVICE | MT_RW)
114*4249a4fbSJacky Bai #define GPIO2_MAP	MAP_REGION_FLAT(GPIO2_BASE, 0x20000, MT_DEVICE | MT_RW)
115*4249a4fbSJacky Bai #define GPIO4_MAP	MAP_REGION_FLAT(GPIO4_BASE, 0x20000, MT_DEVICE | MT_RW)
116*4249a4fbSJacky Bai #define GPIO6_MAP	MAP_REGION_FLAT(GPIO6_BASE, 0x20000, MT_DEVICE | MT_RW)
117*4249a4fbSJacky Bai #define ELE_MU_MAP	MAP_REGION_FLAT(ELE_MU_BASE, 0x10000, MT_DEVICE | MT_RW)
118*4249a4fbSJacky Bai #define AIPS4_MAP	MAP_REGION_FLAT(AIPS4_BASE, AIPSx_SIZE, MT_DEVICE | MT_RW)
119*4249a4fbSJacky Bai 
120*4249a4fbSJacky Bai #endif /* PLATFORM_DEF_H */
121