xref: /rk3399_rockchip-uboot/arch/arm/mach-socfpga/reset_manager_arria10.c (revision b491b49882fc71838b46c47a860daf2978c80be4)
1827e6a7eSLey Foon Tan /*
2827e6a7eSLey Foon Tan  * Copyright (C) 2016-2017 Intel Corporation
3827e6a7eSLey Foon Tan  *
4827e6a7eSLey Foon Tan  * SPDX-License-Identifier:    GPL-2.0
5827e6a7eSLey Foon Tan  */
6827e6a7eSLey Foon Tan 
7827e6a7eSLey Foon Tan #include <asm/io.h>
8827e6a7eSLey Foon Tan #include <asm/arch/fpga_manager.h>
9827e6a7eSLey Foon Tan #include <asm/arch/misc.h>
10827e6a7eSLey Foon Tan #include <asm/arch/reset_manager.h>
11827e6a7eSLey Foon Tan #include <asm/arch/system_manager.h>
12827e6a7eSLey Foon Tan #include <common.h>
13827e6a7eSLey Foon Tan #include <errno.h>
14827e6a7eSLey Foon Tan #include <fdtdec.h>
15827e6a7eSLey Foon Tan #include <wait_bit.h>
16827e6a7eSLey Foon Tan 
17827e6a7eSLey Foon Tan DECLARE_GLOBAL_DATA_PTR;
18827e6a7eSLey Foon Tan 
19827e6a7eSLey Foon Tan static const struct socfpga_reset_manager *reset_manager_base =
20827e6a7eSLey Foon Tan 		(void *)SOCFPGA_RSTMGR_ADDRESS;
21827e6a7eSLey Foon Tan static const struct socfpga_system_manager *sysmgr_regs =
22827e6a7eSLey Foon Tan 		(struct socfpga_system_manager *)SOCFPGA_SYSMGR_ADDRESS;
23827e6a7eSLey Foon Tan 
24827e6a7eSLey Foon Tan #define ECC_MASK (ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK | \
25827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK | \
26827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK | \
27827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK | \
28827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK | \
29827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK)
30827e6a7eSLey Foon Tan 
socfpga_reset_uart(int assert)31827e6a7eSLey Foon Tan void socfpga_reset_uart(int assert)
32827e6a7eSLey Foon Tan {
33827e6a7eSLey Foon Tan 	unsigned int com_port;
34827e6a7eSLey Foon Tan 
35827e6a7eSLey Foon Tan 	com_port = uart_com_port(gd->fdt_blob);
36827e6a7eSLey Foon Tan 
37827e6a7eSLey Foon Tan 	if (com_port == SOCFPGA_UART1_ADDRESS)
38827e6a7eSLey Foon Tan 		socfpga_per_reset(SOCFPGA_RESET(UART1), assert);
39827e6a7eSLey Foon Tan 	else if (com_port == SOCFPGA_UART0_ADDRESS)
40827e6a7eSLey Foon Tan 		socfpga_per_reset(SOCFPGA_RESET(UART0), assert);
41827e6a7eSLey Foon Tan }
42827e6a7eSLey Foon Tan 
43827e6a7eSLey Foon Tan static const u32 per0fpgamasks[] = {
44827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
45827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK,
46827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
47827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK,
48827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
49827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK,
50827e6a7eSLey Foon Tan 	0, /* i2c0 per1mod */
51827e6a7eSLey Foon Tan 	0, /* i2c1 per1mod */
52827e6a7eSLey Foon Tan 	0, /* i2c0_emac */
53827e6a7eSLey Foon Tan 	0, /* i2c1_emac */
54827e6a7eSLey Foon Tan 	0, /* i2c2_emac */
55827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
56827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_NAND_SET_MSK,
57827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
58827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_QSPI_SET_MSK,
59827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK |
60827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SDMMC_SET_MSK,
61827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SPIM0_SET_MSK,
62827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SPIM1_SET_MSK,
63827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SPIS0_SET_MSK,
64827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER0MODRST_SPIS1_SET_MSK,
65827e6a7eSLey Foon Tan 	0, /* uart0 per1mod */
66827e6a7eSLey Foon Tan 	0, /* uart1 per1mod */
67827e6a7eSLey Foon Tan };
68827e6a7eSLey Foon Tan 
69827e6a7eSLey Foon Tan static const u32 per1fpgamasks[] = {
70827e6a7eSLey Foon Tan 	0, /* emac0 per0mod */
71827e6a7eSLey Foon Tan 	0, /* emac1 per0mod */
72827e6a7eSLey Foon Tan 	0, /* emac2 per0mod */
73827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_I2C0_SET_MSK,
74827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_I2C1_SET_MSK,
75827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_I2C2_SET_MSK, /* i2c0_emac */
76827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_I2C3_SET_MSK, /* i2c1_emac */
77827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_I2C4_SET_MSK, /* i2c2_emac */
78827e6a7eSLey Foon Tan 	0, /* nand per0mod */
79827e6a7eSLey Foon Tan 	0, /* qspi per0mod */
80827e6a7eSLey Foon Tan 	0, /* sdmmc per0mod */
81827e6a7eSLey Foon Tan 	0, /* spim0 per0mod */
82827e6a7eSLey Foon Tan 	0, /* spim1 per0mod */
83827e6a7eSLey Foon Tan 	0, /* spis0 per0mod */
84827e6a7eSLey Foon Tan 	0, /* spis1 per0mod */
85827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_UART0_SET_MSK,
86827e6a7eSLey Foon Tan 	ALT_RSTMGR_PER1MODRST_UART1_SET_MSK,
87827e6a7eSLey Foon Tan };
88827e6a7eSLey Foon Tan 
89827e6a7eSLey Foon Tan struct bridge_cfg {
90827e6a7eSLey Foon Tan 	int compat_id;
91827e6a7eSLey Foon Tan 	u32  mask_noc;
92827e6a7eSLey Foon Tan 	u32  mask_rstmgr;
93827e6a7eSLey Foon Tan };
94827e6a7eSLey Foon Tan 
95827e6a7eSLey Foon Tan static const struct bridge_cfg bridge_cfg_tbl[] = {
96827e6a7eSLey Foon Tan 	{
97827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_H2F_BRG,
98827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_H2F_SET_MSK,
99827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_H2F_SET_MSK,
100827e6a7eSLey Foon Tan 	},
101827e6a7eSLey Foon Tan 	{
102827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_LWH2F_BRG,
103827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_LWH2F_SET_MSK,
104827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK,
105827e6a7eSLey Foon Tan 	},
106827e6a7eSLey Foon Tan 	{
107827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_F2H_BRG,
108827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2H_SET_MSK,
109827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_F2H_SET_MSK,
110827e6a7eSLey Foon Tan 	},
111827e6a7eSLey Foon Tan 	{
112827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_F2SDR0,
113827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR0_SET_MSK,
114827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK,
115827e6a7eSLey Foon Tan 	},
116827e6a7eSLey Foon Tan 	{
117827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_F2SDR1,
118827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR1_SET_MSK,
119827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK,
120827e6a7eSLey Foon Tan 	},
121827e6a7eSLey Foon Tan 	{
122827e6a7eSLey Foon Tan 		COMPAT_ALTERA_SOCFPGA_F2SDR2,
123827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
124827e6a7eSLey Foon Tan 		ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK,
125827e6a7eSLey Foon Tan 	},
126827e6a7eSLey Foon Tan };
127827e6a7eSLey Foon Tan 
128827e6a7eSLey Foon Tan /* Disable the watchdog (toggle reset to watchdog) */
socfpga_watchdog_disable(void)129827e6a7eSLey Foon Tan void socfpga_watchdog_disable(void)
130827e6a7eSLey Foon Tan {
131827e6a7eSLey Foon Tan 	/* assert reset for watchdog */
132827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per1modrst,
133827e6a7eSLey Foon Tan 		     ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
134827e6a7eSLey Foon Tan }
135827e6a7eSLey Foon Tan 
136827e6a7eSLey Foon Tan /* Release NOC ddr scheduler from reset */
socfpga_reset_deassert_noc_ddr_scheduler(void)137827e6a7eSLey Foon Tan void socfpga_reset_deassert_noc_ddr_scheduler(void)
138827e6a7eSLey Foon Tan {
139827e6a7eSLey Foon Tan 	clrbits_le32(&reset_manager_base->brgmodrst,
140827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_DDRSCH_SET_MSK);
141827e6a7eSLey Foon Tan }
142827e6a7eSLey Foon Tan 
143827e6a7eSLey Foon Tan /* Check whether Watchdog in reset state? */
socfpga_is_wdt_in_reset(void)144827e6a7eSLey Foon Tan int socfpga_is_wdt_in_reset(void)
145827e6a7eSLey Foon Tan {
146827e6a7eSLey Foon Tan 	u32 val;
147827e6a7eSLey Foon Tan 
148827e6a7eSLey Foon Tan 	val = readl(&reset_manager_base->per1modrst);
149827e6a7eSLey Foon Tan 	val &= ALT_RSTMGR_PER1MODRST_WD0_SET_MSK;
150827e6a7eSLey Foon Tan 
151827e6a7eSLey Foon Tan 	/* return 0x1 if watchdog in reset */
152827e6a7eSLey Foon Tan 	return val;
153827e6a7eSLey Foon Tan }
154827e6a7eSLey Foon Tan 
155827e6a7eSLey Foon Tan /* emacbase: base address of emac to enable/disable reset
156827e6a7eSLey Foon Tan  * state: 0 - disable reset, !0 - enable reset
157827e6a7eSLey Foon Tan  */
socfpga_emac_manage_reset(ulong emacbase,u32 state)158827e6a7eSLey Foon Tan void socfpga_emac_manage_reset(ulong emacbase, u32 state)
159827e6a7eSLey Foon Tan {
160827e6a7eSLey Foon Tan 	ulong eccmask;
161827e6a7eSLey Foon Tan 	ulong emacmask;
162827e6a7eSLey Foon Tan 
163827e6a7eSLey Foon Tan 	switch (emacbase) {
164827e6a7eSLey Foon Tan 	case SOCFPGA_EMAC0_ADDRESS:
165827e6a7eSLey Foon Tan 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK;
166827e6a7eSLey Foon Tan 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK;
167827e6a7eSLey Foon Tan 		break;
168827e6a7eSLey Foon Tan 	case SOCFPGA_EMAC1_ADDRESS:
169827e6a7eSLey Foon Tan 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK;
170827e6a7eSLey Foon Tan 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK;
171827e6a7eSLey Foon Tan 		break;
172827e6a7eSLey Foon Tan 	case SOCFPGA_EMAC2_ADDRESS:
173827e6a7eSLey Foon Tan 		eccmask = ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK;
174827e6a7eSLey Foon Tan 		emacmask = ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK;
175827e6a7eSLey Foon Tan 		break;
176827e6a7eSLey Foon Tan 	default:
17790aa625cSMasahiro Yamada 		pr_err("emac base address unexpected! %lx", emacbase);
178827e6a7eSLey Foon Tan 		hang();
179827e6a7eSLey Foon Tan 		break;
180827e6a7eSLey Foon Tan 	}
181827e6a7eSLey Foon Tan 
182827e6a7eSLey Foon Tan 	if (state) {
183827e6a7eSLey Foon Tan 		/* Enable ECC OCP first */
184827e6a7eSLey Foon Tan 		setbits_le32(&reset_manager_base->per0modrst, eccmask);
185827e6a7eSLey Foon Tan 		setbits_le32(&reset_manager_base->per0modrst, emacmask);
186827e6a7eSLey Foon Tan 	} else {
187827e6a7eSLey Foon Tan 		/* Disable ECC OCP first */
188827e6a7eSLey Foon Tan 		clrbits_le32(&reset_manager_base->per0modrst, emacmask);
189827e6a7eSLey Foon Tan 		clrbits_le32(&reset_manager_base->per0modrst, eccmask);
190827e6a7eSLey Foon Tan 	}
191827e6a7eSLey Foon Tan }
192827e6a7eSLey Foon Tan 
get_bridge_init_val(const void * blob,int compat_id)193827e6a7eSLey Foon Tan static int get_bridge_init_val(const void *blob, int compat_id)
194827e6a7eSLey Foon Tan {
195827e6a7eSLey Foon Tan 	int node;
196827e6a7eSLey Foon Tan 
197827e6a7eSLey Foon Tan 	node = fdtdec_next_compatible(blob, 0, compat_id);
198827e6a7eSLey Foon Tan 	if (node < 0)
199827e6a7eSLey Foon Tan 		return 0;
200827e6a7eSLey Foon Tan 
201827e6a7eSLey Foon Tan 	return fdtdec_get_uint(blob, node, "init-val", 0);
202827e6a7eSLey Foon Tan }
203827e6a7eSLey Foon Tan 
204827e6a7eSLey Foon Tan /* Enable bridges (hps2fpga, lwhps2fpga, fpga2hps, fpga2sdram) per handoff */
socfpga_reset_deassert_bridges_handoff(void)205827e6a7eSLey Foon Tan int socfpga_reset_deassert_bridges_handoff(void)
206827e6a7eSLey Foon Tan {
207827e6a7eSLey Foon Tan 	u32 mask_noc = 0, mask_rstmgr = 0;
208827e6a7eSLey Foon Tan 	int i;
209827e6a7eSLey Foon Tan 
210827e6a7eSLey Foon Tan 	for (i = 0; i < ARRAY_SIZE(bridge_cfg_tbl); i++) {
211827e6a7eSLey Foon Tan 		if (get_bridge_init_val(gd->fdt_blob,
212827e6a7eSLey Foon Tan 					bridge_cfg_tbl[i].compat_id)) {
213827e6a7eSLey Foon Tan 			mask_noc |= bridge_cfg_tbl[i].mask_noc;
214827e6a7eSLey Foon Tan 			mask_rstmgr |= bridge_cfg_tbl[i].mask_rstmgr;
215827e6a7eSLey Foon Tan 		}
216827e6a7eSLey Foon Tan 	}
217827e6a7eSLey Foon Tan 
218827e6a7eSLey Foon Tan 	/* clear idle request to all bridges */
219827e6a7eSLey Foon Tan 	setbits_le32(&sysmgr_regs->noc_idlereq_clr, mask_noc);
220827e6a7eSLey Foon Tan 
221827e6a7eSLey Foon Tan 	/* Release bridges from reset state per handoff value */
222827e6a7eSLey Foon Tan 	clrbits_le32(&reset_manager_base->brgmodrst, mask_rstmgr);
223827e6a7eSLey Foon Tan 
224827e6a7eSLey Foon Tan 	/* Poll until all idleack to 0, timeout at 1000ms */
225*b491b498SJon Lin 	return wait_for_bit_le32(&sysmgr_regs->noc_idleack, mask_noc,
226827e6a7eSLey Foon Tan 				 false, 1000, false);
227827e6a7eSLey Foon Tan }
228827e6a7eSLey Foon Tan 
socfpga_reset_assert_fpga_connected_peripherals(void)229827e6a7eSLey Foon Tan void socfpga_reset_assert_fpga_connected_peripherals(void)
230827e6a7eSLey Foon Tan {
231827e6a7eSLey Foon Tan 	u32 mask0 = 0;
232827e6a7eSLey Foon Tan 	u32 mask1 = 0;
233827e6a7eSLey Foon Tan 	u32 fpga_pinux_addr = SOCFPGA_PINMUX_FPGA_INTERFACE_ADDRESS;
234827e6a7eSLey Foon Tan 	int i;
235827e6a7eSLey Foon Tan 
236827e6a7eSLey Foon Tan 	for (i = 0; i < ARRAY_SIZE(per1fpgamasks); i++) {
237827e6a7eSLey Foon Tan 		if (readl(fpga_pinux_addr)) {
238827e6a7eSLey Foon Tan 			mask0 |= per0fpgamasks[i];
239827e6a7eSLey Foon Tan 			mask1 |= per1fpgamasks[i];
240827e6a7eSLey Foon Tan 		}
241827e6a7eSLey Foon Tan 		fpga_pinux_addr += sizeof(u32);
242827e6a7eSLey Foon Tan 	}
243827e6a7eSLey Foon Tan 
244827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per0modrst, mask0 & ECC_MASK);
245827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per1modrst, mask1);
246827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per0modrst, mask0);
247827e6a7eSLey Foon Tan }
248827e6a7eSLey Foon Tan 
249827e6a7eSLey Foon Tan /* Release L4 OSC1 Watchdog Timer 0 from reset through reset manager */
socfpga_reset_deassert_osc1wd0(void)250827e6a7eSLey Foon Tan void socfpga_reset_deassert_osc1wd0(void)
251827e6a7eSLey Foon Tan {
252827e6a7eSLey Foon Tan 	clrbits_le32(&reset_manager_base->per1modrst,
253827e6a7eSLey Foon Tan 		     ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
254827e6a7eSLey Foon Tan }
255827e6a7eSLey Foon Tan 
256827e6a7eSLey Foon Tan /*
257827e6a7eSLey Foon Tan  * Assert or de-assert SoCFPGA reset manager reset.
258827e6a7eSLey Foon Tan  */
socfpga_per_reset(u32 reset,int set)259827e6a7eSLey Foon Tan void socfpga_per_reset(u32 reset, int set)
260827e6a7eSLey Foon Tan {
261827e6a7eSLey Foon Tan 	const u32 *reg;
262827e6a7eSLey Foon Tan 	u32 rstmgr_bank = RSTMGR_BANK(reset);
263827e6a7eSLey Foon Tan 
264827e6a7eSLey Foon Tan 	switch (rstmgr_bank) {
265827e6a7eSLey Foon Tan 	case 0:
266827e6a7eSLey Foon Tan 		reg = &reset_manager_base->mpumodrst;
267827e6a7eSLey Foon Tan 		break;
268827e6a7eSLey Foon Tan 	case 1:
269827e6a7eSLey Foon Tan 		reg = &reset_manager_base->per0modrst;
270827e6a7eSLey Foon Tan 		break;
271827e6a7eSLey Foon Tan 	case 2:
272827e6a7eSLey Foon Tan 		reg = &reset_manager_base->per1modrst;
273827e6a7eSLey Foon Tan 		break;
274827e6a7eSLey Foon Tan 	case 3:
275827e6a7eSLey Foon Tan 		reg = &reset_manager_base->brgmodrst;
276827e6a7eSLey Foon Tan 		break;
277827e6a7eSLey Foon Tan 	case 4:
278827e6a7eSLey Foon Tan 		reg = &reset_manager_base->sysmodrst;
279827e6a7eSLey Foon Tan 		break;
280827e6a7eSLey Foon Tan 
281827e6a7eSLey Foon Tan 	default:
282827e6a7eSLey Foon Tan 		return;
283827e6a7eSLey Foon Tan 	}
284827e6a7eSLey Foon Tan 
285827e6a7eSLey Foon Tan 	if (set)
286827e6a7eSLey Foon Tan 		setbits_le32(reg, 1 << RSTMGR_RESET(reset));
287827e6a7eSLey Foon Tan 	else
288827e6a7eSLey Foon Tan 		clrbits_le32(reg, 1 << RSTMGR_RESET(reset));
289827e6a7eSLey Foon Tan }
290827e6a7eSLey Foon Tan 
291827e6a7eSLey Foon Tan /*
292827e6a7eSLey Foon Tan  * Assert reset on every peripheral but L4WD0.
293827e6a7eSLey Foon Tan  * Watchdog must be kept intact to prevent glitches
294827e6a7eSLey Foon Tan  * and/or hangs.
295827e6a7eSLey Foon Tan  * For the Arria10, we disable all the peripherals except L4 watchdog0,
296827e6a7eSLey Foon Tan  * L4 Timer 0, and ECC.
297827e6a7eSLey Foon Tan  */
socfpga_per_reset_all(void)298827e6a7eSLey Foon Tan void socfpga_per_reset_all(void)
299827e6a7eSLey Foon Tan {
300827e6a7eSLey Foon Tan 	const u32 l4wd0 = (1 << RSTMGR_RESET(SOCFPGA_RESET(L4WD0)) |
301827e6a7eSLey Foon Tan 			  (1 << RSTMGR_RESET(SOCFPGA_RESET(L4SYSTIMER0))));
302827e6a7eSLey Foon Tan 	unsigned mask_ecc_ocp =
303827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
304827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
305827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
306827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_USBECC0_SET_MSK |
307827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_USBECC1_SET_MSK |
308827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
309827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
310827e6a7eSLey Foon Tan 		ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK;
311827e6a7eSLey Foon Tan 
312827e6a7eSLey Foon Tan 	/* disable all components except ECC_OCP, L4 Timer0 and L4 WD0 */
313827e6a7eSLey Foon Tan 	writel(~l4wd0, &reset_manager_base->per1modrst);
314827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per0modrst, ~mask_ecc_ocp);
315827e6a7eSLey Foon Tan 
316827e6a7eSLey Foon Tan 	/* Finally disable the ECC_OCP */
317827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->per0modrst, mask_ecc_ocp);
318827e6a7eSLey Foon Tan }
319827e6a7eSLey Foon Tan 
320827e6a7eSLey Foon Tan #if defined(CONFIG_SOCFPGA_VIRTUAL_TARGET)
socfpga_bridges_reset(void)3216a34af5bSTien Fong Chee int socfpga_bridges_reset(void)
322827e6a7eSLey Foon Tan {
323827e6a7eSLey Foon Tan 	/* For SoCFPGA-VT, this is NOP. */
324827e6a7eSLey Foon Tan 	return 0;
325827e6a7eSLey Foon Tan }
326827e6a7eSLey Foon Tan #else
socfpga_bridges_reset(void)3276a34af5bSTien Fong Chee int socfpga_bridges_reset(void)
328827e6a7eSLey Foon Tan {
329827e6a7eSLey Foon Tan 	int ret;
330827e6a7eSLey Foon Tan 
331827e6a7eSLey Foon Tan 	/* Disable all the bridges (hps2fpga, lwhps2fpga, fpga2hps,
332827e6a7eSLey Foon Tan 	   fpga2sdram) */
333827e6a7eSLey Foon Tan 	/* set idle request to all bridges */
334827e6a7eSLey Foon Tan 	writel(ALT_SYSMGR_NOC_H2F_SET_MSK |
335827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_LWH2F_SET_MSK |
336827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2H_SET_MSK |
337827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
338827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
339827e6a7eSLey Foon Tan 		ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
340827e6a7eSLey Foon Tan 		&sysmgr_regs->noc_idlereq_set);
341827e6a7eSLey Foon Tan 
342827e6a7eSLey Foon Tan 	/* Enable the NOC timeout */
343827e6a7eSLey Foon Tan 	writel(ALT_SYSMGR_NOC_TMO_EN_SET_MSK, &sysmgr_regs->noc_timeout);
344827e6a7eSLey Foon Tan 
345827e6a7eSLey Foon Tan 	/* Poll until all idleack to 1 */
346*b491b498SJon Lin 	ret = wait_for_bit_le32(&sysmgr_regs->noc_idleack,
347827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_H2F_SET_MSK |
348827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_LWH2F_SET_MSK |
349827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2H_SET_MSK |
350827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
351827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
352827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
353827e6a7eSLey Foon Tan 				true, 10000, false);
354827e6a7eSLey Foon Tan 	if (ret)
355827e6a7eSLey Foon Tan 		return ret;
356827e6a7eSLey Foon Tan 
357827e6a7eSLey Foon Tan 	/* Poll until all idlestatus to 1 */
358*b491b498SJon Lin 	ret = wait_for_bit_le32(&sysmgr_regs->noc_idlestatus,
359827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_H2F_SET_MSK |
360827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_LWH2F_SET_MSK |
361827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2H_SET_MSK |
362827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
363827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
364827e6a7eSLey Foon Tan 				ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
365827e6a7eSLey Foon Tan 				true, 10000, false);
366827e6a7eSLey Foon Tan 	if (ret)
367827e6a7eSLey Foon Tan 		return ret;
368827e6a7eSLey Foon Tan 
369827e6a7eSLey Foon Tan 	/* Put all bridges (except NOR DDR scheduler) into reset state */
370827e6a7eSLey Foon Tan 	setbits_le32(&reset_manager_base->brgmodrst,
371827e6a7eSLey Foon Tan 		     (ALT_RSTMGR_BRGMODRST_H2F_SET_MSK |
372827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK |
373827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_F2H_SET_MSK |
374827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK |
375827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK |
376827e6a7eSLey Foon Tan 		     ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK));
377827e6a7eSLey Foon Tan 
378827e6a7eSLey Foon Tan 	/* Disable NOC timeout */
379827e6a7eSLey Foon Tan 	writel(0, &sysmgr_regs->noc_timeout);
380827e6a7eSLey Foon Tan 
381827e6a7eSLey Foon Tan 	return 0;
382827e6a7eSLey Foon Tan }
383827e6a7eSLey Foon Tan #endif
384