xref: /rk3399_ARM-atf/plat/xilinx/common/include/pm_node.h (revision 5c62d599274b5d9facd4996b50c1a1e153b247a4)
1a92681d9SJay Buddhabhatti /*
2a92681d9SJay Buddhabhatti  * Copyright (c) 2019, Xilinx, Inc. All rights reserved.
3a92681d9SJay Buddhabhatti  * Copyright (c) 2022-2023, Advanced Micro Devices, Inc. All rights reserved.
4a92681d9SJay Buddhabhatti  *
5a92681d9SJay Buddhabhatti  * SPDX-License-Identifier: BSD-3-Clause
6a92681d9SJay Buddhabhatti  */
7a92681d9SJay Buddhabhatti 
8a92681d9SJay Buddhabhatti /* Versal PM nodes enums and defines */
9a92681d9SJay Buddhabhatti 
10a92681d9SJay Buddhabhatti #ifndef PM_NODE_H
11a92681d9SJay Buddhabhatti #define PM_NODE_H
12a92681d9SJay Buddhabhatti 
13a92681d9SJay Buddhabhatti /*********************************************************************
14a92681d9SJay Buddhabhatti  * Macro definitions
15a92681d9SJay Buddhabhatti  ********************************************************************/
16a92681d9SJay Buddhabhatti 
17a92681d9SJay Buddhabhatti #define NODE_CLASS_SHIFT	26U
18a92681d9SJay Buddhabhatti #define NODE_SUBCLASS_SHIFT	20U
19a92681d9SJay Buddhabhatti #define NODE_TYPE_SHIFT		14U
20a92681d9SJay Buddhabhatti #define NODE_INDEX_SHIFT	0U
21a92681d9SJay Buddhabhatti #define NODE_CLASS_MASK_BITS    0x3F
22a92681d9SJay Buddhabhatti #define NODE_SUBCLASS_MASK_BITS 0x3F
23a92681d9SJay Buddhabhatti #define NODE_TYPE_MASK_BITS     0x3F
24a92681d9SJay Buddhabhatti #define NODE_INDEX_MASK_BITS    0x3FFF
25a92681d9SJay Buddhabhatti #define NODE_CLASS_MASK         (NODE_CLASS_MASK_BITS << NODE_CLASS_SHIFT)
26a92681d9SJay Buddhabhatti #define NODE_SUBCLASS_MASK      (NODE_SUBCLASS_MASK_BITS << NODE_SUBCLASS_SHIFT)
27a92681d9SJay Buddhabhatti #define NODE_TYPE_MASK          (NODE_TYPE_MASK_BITS << NODE_TYPE_SHIFT)
28a92681d9SJay Buddhabhatti #define NODE_INDEX_MASK         (NODE_INDEX_MASK_BITS << NODE_INDEX_SHIFT)
29a92681d9SJay Buddhabhatti 
30a92681d9SJay Buddhabhatti #define NODEID(CLASS, SUBCLASS, TYPE, INDEX)	\
31a92681d9SJay Buddhabhatti 	     ((((CLASS) & NODE_CLASS_MASK_BITS) << NODE_CLASS_SHIFT) | \
32a92681d9SJay Buddhabhatti 	     (((SUBCLASS) & NODE_SUBCLASS_MASK_BITS) << NODE_SUBCLASS_SHIFT) | \
33a92681d9SJay Buddhabhatti 	     (((TYPE) & NODE_TYPE_MASK_BITS) << NODE_TYPE_SHIFT) | \
34a92681d9SJay Buddhabhatti 	     (((INDEX) & NODE_INDEX_MASK_BITS) << NODE_INDEX_SHIFT))
35a92681d9SJay Buddhabhatti 
36a92681d9SJay Buddhabhatti #define NODECLASS(ID)		(((ID) & NODE_CLASS_MASK) >> NODE_CLASS_SHIFT)
37a92681d9SJay Buddhabhatti #define NODESUBCLASS(ID)	(((ID) & NODE_SUBCLASS_MASK) >> \
38a92681d9SJay Buddhabhatti 				NODE_SUBCLASS_SHIFT)
39a92681d9SJay Buddhabhatti #define NODETYPE(ID)		(((ID) & NODE_TYPE_MASK) >> NODE_TYPE_SHIFT)
40a92681d9SJay Buddhabhatti #define NODEINDEX(ID)		(((ID) & NODE_INDEX_MASK) >> NODE_INDEX_SHIFT)
41a92681d9SJay Buddhabhatti 
42a92681d9SJay Buddhabhatti /*********************************************************************
43a92681d9SJay Buddhabhatti  * Enum definitions
44a92681d9SJay Buddhabhatti  ********************************************************************/
45a92681d9SJay Buddhabhatti 
46a92681d9SJay Buddhabhatti /* Node class types */
47a92681d9SJay Buddhabhatti enum pm_node_class {
48a92681d9SJay Buddhabhatti 	XPM_NODECLASS_MIN,
49a92681d9SJay Buddhabhatti 
50a92681d9SJay Buddhabhatti 	XPM_NODECLASS_POWER,
51a92681d9SJay Buddhabhatti 	XPM_NODECLASS_CLOCK,
52a92681d9SJay Buddhabhatti 	XPM_NODECLASS_RESET,
53a92681d9SJay Buddhabhatti 	XPM_NODECLASS_MEMIC,
54a92681d9SJay Buddhabhatti 	XPM_NODECLASS_STMIC,
55a92681d9SJay Buddhabhatti 	XPM_NODECLASS_DEVICE,
56a92681d9SJay Buddhabhatti 
57a92681d9SJay Buddhabhatti 	XPM_NODECLASS_MAX
58a92681d9SJay Buddhabhatti };
59a92681d9SJay Buddhabhatti 
60a92681d9SJay Buddhabhatti enum pm_device_node_subclass {
61a92681d9SJay Buddhabhatti 	/* Device types */
62a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_CORE = 1,
63a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_PERIPH,
64a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_MEM,
65a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_SOC,
66a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_MEM_CTRLR,
67a92681d9SJay Buddhabhatti 	XPM_NODESUBCL_DEV_PHY,
68a92681d9SJay Buddhabhatti };
69a92681d9SJay Buddhabhatti 
70a92681d9SJay Buddhabhatti enum pm_device_node_type {
71a92681d9SJay Buddhabhatti 	/* Device types */
72a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_CORE_PMC = 1,
73a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_CORE_PSM,
74a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_CORE_APU,
75a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_CORE_RPU,
76a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_OCM,
77a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_TCM,
78a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_L2CACHE,
79a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_DDR,
80a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_PERIPH,
81a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_SOC,
82a92681d9SJay Buddhabhatti 	XPM_NODETYPE_DEV_GT,
83a92681d9SJay Buddhabhatti };
84a92681d9SJay Buddhabhatti 
85a92681d9SJay Buddhabhatti /* Device node Indexes */
86a92681d9SJay Buddhabhatti enum pm_device_node_idx {
87a92681d9SJay Buddhabhatti 	/* Device nodes */
88*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_MIN = 0x0,
89a92681d9SJay Buddhabhatti 
90a92681d9SJay Buddhabhatti 	/* Processor devices */
91*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PMC_PROC = 0x1,
92*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PSM_PROC = 0x2,
93*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ACPU_0 = 0x3,
94*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ACPU_1 = 0x4,
95*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_RPU0_0 = 0x5,
96*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_RPU0_1 = 0x6,
97a92681d9SJay Buddhabhatti 
98a92681d9SJay Buddhabhatti 	/* Memory devices */
99*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_OCM_0 = 0x7,
100*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_OCM_1 = 0x8,
101*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_OCM_2 = 0x9,
102*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_OCM_3 = 0xA,
103*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TCM_0_A = 0xB,
104*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TCM_0_B = 0xC,
105*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TCM_1_A = 0xD,
106*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TCM_1_B = 0xE,
107*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_L2_BANK_0 = 0xF,
108*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_0 = 0x10,
109*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_1 = 0x11,
110*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_2 = 0x12,
111*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_3 = 0x13,
112*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_4 = 0x14,
113*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_5 = 0x15,
114*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_6 = 0x16,
115*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDR_7 = 0x17,
116a92681d9SJay Buddhabhatti 
117a92681d9SJay Buddhabhatti 	/* LPD Peripheral devices */
118*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_USB_0 = 0x18,
119*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GEM_0 = 0x19,
120*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GEM_1 = 0x1A,
121*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SPI_0 = 0x1B,
122*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SPI_1 = 0x1C,
123*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_I2C_0 = 0x1D,
124*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_I2C_1 = 0x1E,
125*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_CAN_FD_0 = 0x1F,
126*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_CAN_FD_1 = 0x20,
127*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_UART_0 = 0x21,
128*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_UART_1 = 0x22,
129*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GPIO = 0x23,
130*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TTC_0 = 0x24,
131*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TTC_1 = 0x25,
132*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TTC_2 = 0x26,
133*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_TTC_3 = 0x27,
134*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SWDT_LPD = 0x28,
135a92681d9SJay Buddhabhatti 
136a92681d9SJay Buddhabhatti 	/* FPD Peripheral devices */
137*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SWDT_FPD = 0x29,
138a92681d9SJay Buddhabhatti 
139a92681d9SJay Buddhabhatti 	/* PMC Peripheral devices */
140*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_OSPI = 0x2A,
141*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_QSPI = 0x2B,
142*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GPIO_PMC = 0x2C,
143*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_I2C_PMC = 0x2D,
144*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SDIO_0 = 0x2E,
145*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SDIO_1 = 0x2F,
146a92681d9SJay Buddhabhatti 
147*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PL_0 = 0x30,
148*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PL_1 = 0x31,
149*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PL_2 = 0x32,
150*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_PL_3 = 0x33,
151*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_RTC = 0x34,
152*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_0 = 0x35,
153*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_1 = 0x36,
154*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_2 = 0x37,
155*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_3 = 0x38,
156*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_4 = 0x39,
157*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_5 = 0x3A,
158*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_6 = 0x3B,
159*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_ADMA_7 = 0x3C,
160*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_0 = 0x3D,
161*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_1 = 0x3E,
162*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_2 = 0x3F,
163*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_3 = 0x40,
164*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_4 = 0x41,
165*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_5 = 0x42,
166*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_IPI_6 = 0x43,
167a92681d9SJay Buddhabhatti 
168a92681d9SJay Buddhabhatti 	/* Entire SoC */
169*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_SOC = 0x44,
170a92681d9SJay Buddhabhatti 
171a92681d9SJay Buddhabhatti 	/* DDR memory controllers */
172*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDRMC_0 = 0x45,
173*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDRMC_1 = 0x46,
174*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDRMC_2 = 0x47,
175*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_DDRMC_3 = 0x48,
176a92681d9SJay Buddhabhatti 
177a92681d9SJay Buddhabhatti 	/* GT devices */
178*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_0 = 0x49,
179*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_1 = 0x4A,
180*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_2 = 0x4B,
181*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_3 = 0x4C,
182*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_4 = 0x4D,
183*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_5 = 0x4E,
184*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_6 = 0x4F,
185*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_7 = 0x50,
186*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_8 = 0x51,
187*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_9 = 0x52,
188*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_GT_10 = 0x53,
189a92681d9SJay Buddhabhatti 
190*5c62d599SJay Buddhabhatti 	XPM_NODEIDX_DEV_MAX = 0x54,
191a92681d9SJay Buddhabhatti };
192a92681d9SJay Buddhabhatti 
193a92681d9SJay Buddhabhatti #endif /* PM_NODE_H */
194