• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2019-2023, Intel Corporation. All rights reserved.
3  * Copyright (c) 2024, Altera Corporation. All rights reserved.
4  *
5  * SPDX-License-Identifier: BSD-3-Clause
6  */
7 #ifndef AGX_SOCFPGA_SYSTEMMANAGER_H
8 #define AGX_SOCFPGA_SYSTEMMANAGER_H
9 
10 #include "socfpga_plat_def.h"
11 
12 /* System Manager Register Map */
13 #define SOCFPGA_SYSMGR_SILICONID_1			0x00
14 #define SOCFPGA_SYSMGR_SILICONID_2			0x04
15 #define SOCFPGA_SYSMGR_WDDBG				0x08
16 #define SOCFPGA_SYSMGR_MPU_STATUS			0x10
17 #define SOCFPGA_SYSMGR_SDMMC_L3_MASTER			0x2C
18 #define SOCFPGA_SYSMGR_NAND_L3_MASTER			0x34
19 #define SOCFPGA_SYSMGR_USB0_L3_MASTER			0x38
20 #define SOCFPGA_SYSMGR_USB1_L3_MASTER			0x3C
21 #define SOCFPGA_SYSMGR_TSN_GLOBAL			0x40
22 #define SOCFPGA_SYSMGR_EMAC_0				0x44 /* TSN_0 */
23 #define SOCFPGA_SYSMGR_EMAC_1				0x48 /* TSN_1 */
24 #define SOCFPGA_SYSMGR_EMAC_2				0x4C /* TSN_2 */
25 #define SOCFPGA_SYSMGR_TSN_0_ACE			0x50
26 #define SOCFPGA_SYSMGR_TSN_1_ACE			0x54
27 #define SOCFPGA_SYSMGR_TSN_2_ACE			0x58
28 #define SOCFPGA_SYSMGR_FPGAINTF_EN_1			0x68
29 #define SOCFPGA_SYSMGR_FPGAINTF_EN_2			0x6C
30 #define SOCFPGA_SYSMGR_FPGAINTF_EN_3			0x70
31 #define SOCFPGA_SYSMGR_DMAC0_L3_MASTER			0x74
32 #define SOCFPGA_SYSMGR_ETR_L3_MASTER			0x78
33 #define SOCFPGA_SYSMGR_DMAC1_L3_MASTER			0x7C
34 #define SOCFPGA_SYSMGR_SEC_CTRL_SLT			0x80
35 #define SOCFPGA_SYSMGR_OSC_TRIM				0x84
36 #define SOCFPGA_SYSMGR_DMAC0_CTRL_STATUS_REG		0x88
37 #define SOCFPGA_SYSMGR_DMAC1_CTRL_STATUS_REG		0x8C
38 #define SOCFPGA_SYSMGR_ECC_INTMASK_VALUE		0x90
39 #define SOCFPGA_SYSMGR_ECC_INTMASK_SET			0x94
40 #define SOCFPGA_SYSMGR_ECC_INTMASK_CLR			0x98
41 #define SOCFPGA_SYSMGR_ECC_INTMASK_SERR			0x9C
42 #define SOCFPGA_SYSMGR_ECC_INTMASK_DERR			0xA0
43 /* NOC configuration value for Agilex5 */
44 #define SOCFPGA_SYSMGR_NOC_TIMEOUT			0xC0
45 #define SOCFPGA_SYSMGR_NOC_IDLEREQ_SET			0xC4
46 #define SOCFPGA_SYSMGR_NOC_IDLEREQ_CLR			0xC8
47 #define SOCFPGA_SYSMGR_NOC_IDLEREQ_VAL			0xCC
48 #define SOCFPGA_SYSMGR_NOC_IDLEACK			0xD0
49 #define SOCFPGA_SYSMGR_NOC_IDLESTATUS			0xD4
50 #define SOCFPGA_SYSMGR_FPGA2SOC_CTRL			0xD8
51 #define SOCFPGA_SYSMGR_FPGA_CFG				0xDC
52 #define SOCFPGA_SYSMGR_GPO				0xE4
53 #define SOCFPGA_SYSMGR_GPI				0xE8
54 #define SOCFPGA_SYSMGR_MPU				0xF0
55 #define SOCFPGA_SYSMGR_SDM_HPS_SPARE			0xF4
56 #define SOCFPGA_SYSMGR_HPS_SDM_SPARE			0xF8
57 #define SOCFPGA_SYSMGR_DFI_INTF				0xFC
58 #define SOCFPGA_SYSMGR_NAND_DD_CTRL			0x100
59 #define SOCFPGA_SYSMGR_NAND_PHY_CTRL_REG		0x104
60 #define SOCFPGA_SYSMGR_NAND_PHY_TSEL_REG		0x108
61 #define SOCFPGA_SYSMGR_NAND_DQ_TIMING_REG		0x10C
62 #define SOCFPGA_SYSMGR_PHY_DQS_TIMING_REG		0x110
63 #define SOCFPGA_SYSMGR_NAND_PHY_GATE_LPBK_CTRL_REG	0x114
64 #define SOCFPGA_SYSMGR_NAND_PHY_DLL_MASTER_CTRL_REG	0x118
65 #define SOCFPGA_SYSMGR_NAND_PHY_DLL_SLAVE_CTRL_REG	0x11C
66 #define SOCFPGA_SYSMGR_NAND_DD_DEFAULT_SETTING_REG0	0x120
67 #define SOCFPGA_SYSMGR_NAND_DD_DEFAULT_SETTING_REG1	0x124
68 #define SOCFPGA_SYSMGR_NAND_DD_STATUS_REG		0x128
69 #define SOCFPGA_SYSMGR_NAND_DD_ID_LOW_REG		0x12C
70 #define SOCFPGA_SYSMGR_NAND_DD_ID_HIGH_REG		0x130
71 #define SOCFPGA_SYSMGR_NAND_WRITE_PROT_EN_REG		0x134
72 #define SOCFPGA_SYSMGR_SDMMC_CMD_QUEUE_SETTING_REG	0x138
73 #define SOCFPGA_SYSMGR_I3C_SLV_PID_LOW			0x13C
74 #define SOCFPGA_SYSMGR_I3C_SLV_PID_HIGH			0x140
75 #define SOCFPGA_SYSMGR_I3C_SLV_CTRL_0			0x144
76 #define SOCFPGA_SYSMGR_I3C_SLV_CTRL_1			0x148
77 #define SOCFPGA_SYSMGR_F2S_BRIDGE_CTRL			0x14C
78 #define SOCFPGA_SYSMGR_DMA_TBU_STASH_CTRL_REG_0_DMA0	0x150
79 #define SOCFPGA_SYSMGR_DMA_TBU_STASH_CTRL_REG_0_DMA1	0x154
80 #define SOCFPGA_SYSMGR_SDM_TBU_STASH_CTRL_REG_1_SDM	0x158
81 #define SOCFPGA_SYSMGR_IO_TBU_STASH_CTRL_REG_2_USB2	0x15C
82 #define SOCFPGA_SYSMGR_IO_TBU_STASH_CTRL_REG_2_USB3	0x160
83 #define SOCFPGA_SYSMGR_IO_TBU_STASH_CTRL_REG_2_SDMMC	0x164
84 #define SOCFPGA_SYSMGR_IO_TBU_STASH_CTRL_REG_2_NAND	0x168
85 #define SOCFPGA_SYSMGR_IO_TBU_STASH_CTRL_REG_2_ETR	0x16C
86 #define SOCFPGA_SYSMGR_TSN_TBU_STASH_CTRL_REG_3_TSN0	0x170
87 #define SOCFPGA_SYSMGR_TSN_TBU_STASH_CTRL_REG_3_TSN1	0x174
88 #define SOCFPGA_SYSMGR_TSN_TBU_STASH_CTRL_REG_3_TSN2	0x178
89 #define SOCFPGA_SYSMGR_DMA_TBU_STREAM_CTRL_REG_0_DMA0	0x17C
90 #define SOCFPGA_SYSMGR_DMA_TBU_STREAM_CTRL_REG_0_DMA1	0x180
91 #define SOCFPGA_SYSMGR_SDM_TBU_STREAM_CTRL_REG_1_SDM	0x184
92 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_CTRL_REG_2_USB2	0x188
93 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_CTRL_REG_2_USB3	0x18C
94 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_CTRL_REG_2_SDMMC	0x190
95 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_CTRL_REG_2_NAND	0x194
96 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_CTRL_REG_2_ETR	0x198
97 #define SOCFPGA_SYSMGR_TSN_TBU_STREAM_CTRL_REG_3_TSN0	0x19C
98 #define SOCFPGA_SYSMGR_TSN_TBU_STREAM_CTRL_REG_3_TSN1	0x1A0
99 #define SOCFPGA_SYSMGR_TSN_TBU_STREAM_CTRL_REG_3_TSN2	0x1A4
100 #define SOCFPGA_SYSMGR_DMA_TBU_STREAM_ID_AX_REG_0_DMA0	0x1A8
101 #define SOCFPGA_SYSMGR_DMA_TBU_STREAM_ID_AX_REG_0_DMA1	0x1AC
102 #define SOCFPGA_SYSMGR_SDM_TBU_STREAM_ID_AX_REG_1_SDM	0x1B0
103 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_USB2	0x1B4
104 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_USB3	0x1B8
105 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_SDMMC	0x1BC
106 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_NAND	0x1C0
107 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_ETR	0x1C4
108 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_TSN0	0x1C8
109 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_TSN1	0x1CC
110 #define SOCFPGA_SYSMGR_IO_TBU_STREAM_ID_AX_REG_2_TSN2	0x1D0
111 #define SOCFPGA_SYSMGR_USB3_MISC_CTRL_REG0		0x1F0
112 #define SOCFPGA_SYSMGR_USB3_MISC_CTRL_REG1		0x1F4
113 
114 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_0		0x200
115 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_1		0x204
116 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_2		0x208
117 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_3		0x20C
118 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_4		0x210
119 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_5		0x214
120 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_6		0x218
121 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_7		0x21C
122 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_8		0x220
123 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_COLD_9		0x224
124 #define SOCFPGA_SYSMGR_MPFE_CONFIG			0x228
125 #define SOCFPGA_SYSMGR_MPFE_STATUS			0x22C
126 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_0		0x230
127 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_1		0x234
128 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_2		0x238
129 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_3		0x23C
130 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_4		0x240
131 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_5		0x244
132 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_6		0x248
133 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_7		0x24C
134 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_8		0x250
135 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_WARM_9		0x254
136 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_0		0x258
137 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_1		0x25C
138 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_2		0x260
139 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_3		0x264
140 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_4		0x268
141 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_5		0x26C
142 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_6		0x270
143 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_7		0x274
144 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_8		0x278
145 #define SOCFPGA_SYSMGR_BOOT_SCRATCH_POR_9		0x27C
146 
147 /* QSPI ECC from SDM register */
148 #define SOCFPGA_ECC_QSPI_CTRL				0x08
149 #define SOCFPGA_ECC_QSPI_ERRINTEN			0x10
150 #define SOCFPGA_ECC_QSPI_ERRINTENS			0x14
151 #define SOCFPGA_ECC_QSPI_ERRINTENR			0x18
152 #define SOCFPGA_ECC_QSPI_INTMODE			0x1C
153 #define SOCFPGA_ECC_QSPI_INTSTAT			0x20
154 #define SOCFPGA_ECC_QSPI_INTTEST			0x24
155 #define SOCFPGA_ECC_QSPI_ECC_ACCCTRL			0x78
156 #define SOCFPGA_ECC_QSPI_ECC_STARTACC			0x7C
157 #define SOCFPGA_ECC_QSPI_ECC_WDCTRL			0x80
158 
159 #define DMA0_STREAM_CTRL_REG				0x10D1217C
160 #define DMA1_STREAM_CTRL_REG				0x10D12180
161 #define SDM_STREAM_CTRL_REG				0x10D12184
162 #define USB2_STREAM_CTRL_REG				0x10D12188
163 #define USB3_STREAM_CTRL_REG				0x10D1218C
164 #define SDMMC_STREAM_CTRL_REG				0x10D12190
165 #define NAND_STREAM_CTRL_REG				0x10D12194
166 #define ETR_STREAM_CTRL_REG				0x10D12198
167 #define TSN0_STREAM_CTRL_REG				0x10D1219C
168 #define TSN1_STREAM_CTRL_REG				0x10D121A0
169 #define TSN2_STREAM_CTRL_REG				0x10D121A4
170 
171 /* Stream ID configuration value for Agilex5 */
172 #define TSN0						0x00010001
173 #define TSN1						0x00020002
174 #define TSN2						0x00030003
175 #define NAND						0x00040004
176 #define SDMMC						0x00050005
177 #define USB0						0x00060006
178 #define USB1						0x00070007
179 #define DMA0						0x00080008
180 #define DMA1						0x00090009
181 #define SDM						0x000A000A
182 #define CORE_SIGHT_DEBUG				0x000B000B
183 
184 /* Field Masking */
185 #define SYSMGR_SDMMC_DRVSEL(x)				(((x) & 0x7) << 0)
186 #define SYSMGR_SDMMC_SMPLSEL(x)				(((x) & 0x7) << 4)
187 #define IDLE_DATA_LWSOC2FPGA				BIT(4)
188 #define IDLE_DATA_SOC2FPGA				BIT(0)
189 #define IDLE_DATA_MASK					(IDLE_DATA_LWSOC2FPGA | IDLE_DATA_SOC2FPGA)
190 #define SYSMGR_ECC_OCRAM_MASK				BIT(1)
191 #define SYSMGR_ECC_DDR0_MASK				BIT(16)
192 #define SYSMGR_ECC_DDR1_MASK				BIT(17)
193 #define WSTREAMIDEN_REG_CTRL				BIT(0)
194 #define RSTREAMIDEN_REG_CTRL				BIT(1)
195 #define WMMUSECSID_REG_VAL				BIT(4)
196 #define RMMUSECSID_REG_VAL				BIT(5)
197 
198 /* Macros */
199 #define SOCFPGA_ECC_QSPI(_reg)				(SOCFPGA_ECC_QSPI_REG_BASE \
200 								+ (SOCFPGA_ECC_QSPI_##_reg))
201 
202 #define SOCFPGA_SYSMGR(_reg)				(SOCFPGA_SYSMGR_REG_BASE \
203 								+ (SOCFPGA_SYSMGR_##_reg))
204 
205 #define ENABLE_STREAMID					WSTREAMIDEN_REG_CTRL | \
206 							RSTREAMIDEN_REG_CTRL
207 #define ENABLE_STREAMID_SECURE_TX			WSTREAMIDEN_REG_CTRL | \
208 							RSTREAMIDEN_REG_CTRL | \
209 							WMMUSECSID_REG_VAL | RMMUSECSID_REG_VAL
210 
211 #endif /* AGX5_SOCFPGA_SYSTEMMANAGER_H */
212