xref: /openbmc/u-boot/arch/arm/mach-socfpga/reset_manager_arria10.c (revision 53193a4f07c9e7a7d42493863712352cf16f1258)
1 /*
2  * Copyright (C) 2016-2017 Intel Corporation
3  *
4  * SPDX-License-Identifier:    GPL-2.0
5  */
6 
7 #include <asm/io.h>
8 #include <asm/arch/fpga_manager.h>
9 #include <asm/arch/misc.h>
10 #include <asm/arch/reset_manager.h>
11 #include <asm/arch/system_manager.h>
12 #include <common.h>
13 #include <errno.h>
14 #include <fdtdec.h>
15 #include <wait_bit.h>
16 
17 DECLARE_GLOBAL_DATA_PTR;
18 
19 static const struct socfpga_reset_manager *reset_manager_base =
20 		(void *)SOCFPGA_RSTMGR_ADDRESS;
21 static const struct socfpga_system_manager *sysmgr_regs =
22 		(struct socfpga_system_manager *)SOCFPGA_SYSMGR_ADDRESS;
23 
24 #define ECC_MASK (ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK | \
25 	ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK | \
26 	ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK | \
27 	ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK | \
28 	ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK | \
29 	ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK)
30 
31 void socfpga_reset_uart(int assert)
32 {
33 	unsigned int com_port;
34 
35 	com_port = uart_com_port(gd->fdt_blob);
36 
37 	if (com_port == SOCFPGA_UART1_ADDRESS)
38 		socfpga_per_reset(SOCFPGA_RESET(UART1), assert);
39 	else if (com_port == SOCFPGA_UART0_ADDRESS)
40 		socfpga_per_reset(SOCFPGA_RESET(UART0), assert);
41 }
42 
43 static const u32 per0fpgamasks[] = {
44 	ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
45 	ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK,
46 	ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
47 	ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK,
48 	ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
49 	ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK,
50 	0, /* i2c0 per1mod */
51 	0, /* i2c1 per1mod */
52 	0, /* i2c0_emac */
53 	0, /* i2c1_emac */
54 	0, /* i2c2_emac */
55 	ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
56 	ALT_RSTMGR_PER0MODRST_NAND_SET_MSK,
57 	ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
58 	ALT_RSTMGR_PER0MODRST_QSPI_SET_MSK,
59 	ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK |
60 	ALT_RSTMGR_PER0MODRST_SDMMC_SET_MSK,
61 	ALT_RSTMGR_PER0MODRST_SPIM0_SET_MSK,
62 	ALT_RSTMGR_PER0MODRST_SPIM1_SET_MSK,
63 	ALT_RSTMGR_PER0MODRST_SPIS0_SET_MSK,
64 	ALT_RSTMGR_PER0MODRST_SPIS1_SET_MSK,
65 	0, /* uart0 per1mod */
66 	0, /* uart1 per1mod */
67 };
68 
69 static const u32 per1fpgamasks[] = {
70 	0, /* emac0 per0mod */
71 	0, /* emac1 per0mod */
72 	0, /* emac2 per0mod */
73 	ALT_RSTMGR_PER1MODRST_I2C0_SET_MSK,
74 	ALT_RSTMGR_PER1MODRST_I2C1_SET_MSK,
75 	ALT_RSTMGR_PER1MODRST_I2C2_SET_MSK, /* i2c0_emac */
76 	ALT_RSTMGR_PER1MODRST_I2C3_SET_MSK, /* i2c1_emac */
77 	ALT_RSTMGR_PER1MODRST_I2C4_SET_MSK, /* i2c2_emac */
78 	0, /* nand per0mod */
79 	0, /* qspi per0mod */
80 	0, /* sdmmc per0mod */
81 	0, /* spim0 per0mod */
82 	0, /* spim1 per0mod */
83 	0, /* spis0 per0mod */
84 	0, /* spis1 per0mod */
85 	ALT_RSTMGR_PER1MODRST_UART0_SET_MSK,
86 	ALT_RSTMGR_PER1MODRST_UART1_SET_MSK,
87 };
88 
89 struct bridge_cfg {
90 	int compat_id;
91 	u32  mask_noc;
92 	u32  mask_rstmgr;
93 };
94 
95 static const struct bridge_cfg bridge_cfg_tbl[] = {
96 	{
97 		COMPAT_ALTERA_SOCFPGA_H2F_BRG,
98 		ALT_SYSMGR_NOC_H2F_SET_MSK,
99 		ALT_RSTMGR_BRGMODRST_H2F_SET_MSK,
100 	},
101 	{
102 		COMPAT_ALTERA_SOCFPGA_LWH2F_BRG,
103 		ALT_SYSMGR_NOC_LWH2F_SET_MSK,
104 		ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK,
105 	},
106 	{
107 		COMPAT_ALTERA_SOCFPGA_F2H_BRG,
108 		ALT_SYSMGR_NOC_F2H_SET_MSK,
109 		ALT_RSTMGR_BRGMODRST_F2H_SET_MSK,
110 	},
111 	{
112 		COMPAT_ALTERA_SOCFPGA_F2SDR0,
113 		ALT_SYSMGR_NOC_F2SDR0_SET_MSK,
114 		ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK,
115 	},
116 	{
117 		COMPAT_ALTERA_SOCFPGA_F2SDR1,
118 		ALT_SYSMGR_NOC_F2SDR1_SET_MSK,
119 		ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK,
120 	},
121 	{
122 		COMPAT_ALTERA_SOCFPGA_F2SDR2,
123 		ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
124 		ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK,
125 	},
126 };
127 
128 /* Disable the watchdog (toggle reset to watchdog) */
129 void socfpga_watchdog_disable(void)
130 {
131 	/* assert reset for watchdog */
132 	setbits_le32(&reset_manager_base->per1modrst,
133 		     ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
134 }
135 
136 /* Release NOC ddr scheduler from reset */
137 void socfpga_reset_deassert_noc_ddr_scheduler(void)
138 {
139 	clrbits_le32(&reset_manager_base->brgmodrst,
140 		     ALT_RSTMGR_BRGMODRST_DDRSCH_SET_MSK);
141 }
142 
143 /* Check whether Watchdog in reset state? */
144 int socfpga_is_wdt_in_reset(void)
145 {
146 	u32 val;
147 
148 	val = readl(&reset_manager_base->per1modrst);
149 	val &= ALT_RSTMGR_PER1MODRST_WD0_SET_MSK;
150 
151 	/* return 0x1 if watchdog in reset */
152 	return val;
153 }
154 
155 /* emacbase: base address of emac to enable/disable reset
156  * state: 0 - disable reset, !0 - enable reset
157  */
158 void socfpga_emac_manage_reset(ulong emacbase, u32 state)
159 {
160 	ulong eccmask;
161 	ulong emacmask;
162 
163 	switch (emacbase) {
164 	case SOCFPGA_EMAC0_ADDRESS:
165 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK;
166 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK;
167 		break;
168 	case SOCFPGA_EMAC1_ADDRESS:
169 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK;
170 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK;
171 		break;
172 	case SOCFPGA_EMAC2_ADDRESS:
173 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK;
174 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK;
175 		break;
176 	default:
177 		error("emac base address unexpected! %lx", emacbase);
178 		hang();
179 		break;
180 	}
181 
182 	if (state) {
183 		/* Enable ECC OCP first */
184 		setbits_le32(&reset_manager_base->per0modrst, eccmask);
185 		setbits_le32(&reset_manager_base->per0modrst, emacmask);
186 	} else {
187 		/* Disable ECC OCP first */
188 		clrbits_le32(&reset_manager_base->per0modrst, emacmask);
189 		clrbits_le32(&reset_manager_base->per0modrst, eccmask);
190 	}
191 }
192 
193 static int get_bridge_init_val(const void *blob, int compat_id)
194 {
195 	int node;
196 
197 	node = fdtdec_next_compatible(blob, 0, compat_id);
198 	if (node < 0)
199 		return 0;
200 
201 	return fdtdec_get_uint(blob, node, "init-val", 0);
202 }
203 
204 /* Enable bridges (hps2fpga, lwhps2fpga, fpga2hps, fpga2sdram) per handoff */
205 int socfpga_reset_deassert_bridges_handoff(void)
206 {
207 	u32 mask_noc = 0, mask_rstmgr = 0;
208 	int i;
209 
210 	for (i = 0; i < ARRAY_SIZE(bridge_cfg_tbl); i++) {
211 		if (get_bridge_init_val(gd->fdt_blob,
212 					bridge_cfg_tbl[i].compat_id)) {
213 			mask_noc |= bridge_cfg_tbl[i].mask_noc;
214 			mask_rstmgr |= bridge_cfg_tbl[i].mask_rstmgr;
215 		}
216 	}
217 
218 	/* clear idle request to all bridges */
219 	setbits_le32(&sysmgr_regs->noc_idlereq_clr, mask_noc);
220 
221 	/* Release bridges from reset state per handoff value */
222 	clrbits_le32(&reset_manager_base->brgmodrst, mask_rstmgr);
223 
224 	/* Poll until all idleack to 0, timeout at 1000ms */
225 	return wait_for_bit(__func__, &sysmgr_regs->noc_idleack, mask_noc,
226 			    false, 1000, false);
227 }
228 
229 void socfpga_reset_assert_fpga_connected_peripherals(void)
230 {
231 	u32 mask0 = 0;
232 	u32 mask1 = 0;
233 	u32 fpga_pinux_addr = SOCFPGA_PINMUX_FPGA_INTERFACE_ADDRESS;
234 	int i;
235 
236 	for (i = 0; i < ARRAY_SIZE(per1fpgamasks); i++) {
237 		if (readl(fpga_pinux_addr)) {
238 			mask0 |= per0fpgamasks[i];
239 			mask1 |= per1fpgamasks[i];
240 		}
241 		fpga_pinux_addr += sizeof(u32);
242 	}
243 
244 	setbits_le32(&reset_manager_base->per0modrst, mask0 & ECC_MASK);
245 	setbits_le32(&reset_manager_base->per1modrst, mask1);
246 	setbits_le32(&reset_manager_base->per0modrst, mask0);
247 }
248 
249 /* Release L4 OSC1 Watchdog Timer 0 from reset through reset manager */
250 void socfpga_reset_deassert_osc1wd0(void)
251 {
252 	clrbits_le32(&reset_manager_base->per1modrst,
253 		     ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
254 }
255 
256 /*
257  * Assert or de-assert SoCFPGA reset manager reset.
258  */
259 void socfpga_per_reset(u32 reset, int set)
260 {
261 	const u32 *reg;
262 	u32 rstmgr_bank = RSTMGR_BANK(reset);
263 
264 	switch (rstmgr_bank) {
265 	case 0:
266 		reg = &reset_manager_base->mpumodrst;
267 		break;
268 	case 1:
269 		reg = &reset_manager_base->per0modrst;
270 		break;
271 	case 2:
272 		reg = &reset_manager_base->per1modrst;
273 		break;
274 	case 3:
275 		reg = &reset_manager_base->brgmodrst;
276 		break;
277 	case 4:
278 		reg = &reset_manager_base->sysmodrst;
279 		break;
280 
281 	default:
282 		return;
283 	}
284 
285 	if (set)
286 		setbits_le32(reg, 1 << RSTMGR_RESET(reset));
287 	else
288 		clrbits_le32(reg, 1 << RSTMGR_RESET(reset));
289 }
290 
291 /*
292  * Assert reset on every peripheral but L4WD0.
293  * Watchdog must be kept intact to prevent glitches
294  * and/or hangs.
295  * For the Arria10, we disable all the peripherals except L4 watchdog0,
296  * L4 Timer 0, and ECC.
297  */
298 void socfpga_per_reset_all(void)
299 {
300 	const u32 l4wd0 = (1 << RSTMGR_RESET(SOCFPGA_RESET(L4WD0)) |
301 			  (1 << RSTMGR_RESET(SOCFPGA_RESET(L4SYSTIMER0))));
302 	unsigned mask_ecc_ocp =
303 		ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
304 		ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
305 		ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
306 		ALT_RSTMGR_PER0MODRST_USBECC0_SET_MSK |
307 		ALT_RSTMGR_PER0MODRST_USBECC1_SET_MSK |
308 		ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
309 		ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
310 		ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK;
311 
312 	/* disable all components except ECC_OCP, L4 Timer0 and L4 WD0 */
313 	writel(~l4wd0, &reset_manager_base->per1modrst);
314 	setbits_le32(&reset_manager_base->per0modrst, ~mask_ecc_ocp);
315 
316 	/* Finally disable the ECC_OCP */
317 	setbits_le32(&reset_manager_base->per0modrst, mask_ecc_ocp);
318 }
319 
320 #if defined(CONFIG_SOCFPGA_VIRTUAL_TARGET)
321 int socfpga_bridges_reset(int enable)
322 {
323 	/* For SoCFPGA-VT, this is NOP. */
324 	return 0;
325 }
326 #else
327 int socfpga_bridges_reset(int enable)
328 {
329 	int ret;
330 
331 	/* Disable all the bridges (hps2fpga, lwhps2fpga, fpga2hps,
332 	   fpga2sdram) */
333 	/* set idle request to all bridges */
334 	writel(ALT_SYSMGR_NOC_H2F_SET_MSK |
335 		ALT_SYSMGR_NOC_LWH2F_SET_MSK |
336 		ALT_SYSMGR_NOC_F2H_SET_MSK |
337 		ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
338 		ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
339 		ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
340 		&sysmgr_regs->noc_idlereq_set);
341 
342 	/* Enable the NOC timeout */
343 	writel(ALT_SYSMGR_NOC_TMO_EN_SET_MSK, &sysmgr_regs->noc_timeout);
344 
345 	/* Poll until all idleack to 1 */
346 	ret = wait_for_bit(__func__, &sysmgr_regs->noc_idleack,
347 		     ALT_SYSMGR_NOC_H2F_SET_MSK |
348 		     ALT_SYSMGR_NOC_LWH2F_SET_MSK |
349 		     ALT_SYSMGR_NOC_F2H_SET_MSK |
350 		     ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
351 		     ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
352 		     ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
353 		     true, 10000, false);
354 	if (ret)
355 		return ret;
356 
357 	/* Poll until all idlestatus to 1 */
358 	ret = wait_for_bit(__func__, &sysmgr_regs->noc_idlestatus,
359 		     ALT_SYSMGR_NOC_H2F_SET_MSK |
360 		     ALT_SYSMGR_NOC_LWH2F_SET_MSK |
361 		     ALT_SYSMGR_NOC_F2H_SET_MSK |
362 		     ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
363 		     ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
364 		     ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
365 		     true, 10000, false);
366 	if (ret)
367 		return ret;
368 
369 	/* Put all bridges (except NOR DDR scheduler) into reset state */
370 	setbits_le32(&reset_manager_base->brgmodrst,
371 		     (ALT_RSTMGR_BRGMODRST_H2F_SET_MSK |
372 		     ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK |
373 		     ALT_RSTMGR_BRGMODRST_F2H_SET_MSK |
374 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK |
375 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK |
376 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK));
377 
378 	/* Disable NOC timeout */
379 	writel(0, &sysmgr_regs->noc_timeout);
380 
381 	return 0;
382 }
383 #endif
384