1 // SPDX-License-Identifier: GPL-2.0
3 * Copyright (C) 2016-2017 Intel Corporation
7 #include <asm/arch/fpga_manager.h>
8 #include <asm/arch/misc.h>
9 #include <asm/arch/reset_manager.h>
10 #include <asm/arch/system_manager.h>
16 DECLARE_GLOBAL_DATA_PTR;
18 static const struct socfpga_reset_manager *reset_manager_base =
19 (void *)SOCFPGA_RSTMGR_ADDRESS;
20 static const struct socfpga_system_manager *sysmgr_regs =
21 (struct socfpga_system_manager *)SOCFPGA_SYSMGR_ADDRESS;
23 #define ECC_MASK (ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK | \
24 ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK | \
25 ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK | \
26 ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK | \
27 ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK | \
28 ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK)
30 void socfpga_reset_uart(int assert)
32 unsigned int com_port;
34 com_port = uart_com_port(gd->fdt_blob);
36 if (com_port == SOCFPGA_UART1_ADDRESS)
37 socfpga_per_reset(SOCFPGA_RESET(UART1), assert);
38 else if (com_port == SOCFPGA_UART0_ADDRESS)
39 socfpga_per_reset(SOCFPGA_RESET(UART0), assert);
42 static const u32 per0fpgamasks[] = {
43 ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
44 ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK,
45 ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
46 ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK,
47 ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
48 ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK,
54 ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
55 ALT_RSTMGR_PER0MODRST_NAND_SET_MSK,
56 ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
57 ALT_RSTMGR_PER0MODRST_QSPI_SET_MSK,
58 ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK |
59 ALT_RSTMGR_PER0MODRST_SDMMC_SET_MSK,
60 ALT_RSTMGR_PER0MODRST_SPIM0_SET_MSK,
61 ALT_RSTMGR_PER0MODRST_SPIM1_SET_MSK,
62 ALT_RSTMGR_PER0MODRST_SPIS0_SET_MSK,
63 ALT_RSTMGR_PER0MODRST_SPIS1_SET_MSK,
64 0, /* uart0 per1mod */
65 0, /* uart1 per1mod */
68 static const u32 per1fpgamasks[] = {
69 0, /* emac0 per0mod */
70 0, /* emac1 per0mod */
71 0, /* emac2 per0mod */
72 ALT_RSTMGR_PER1MODRST_I2C0_SET_MSK,
73 ALT_RSTMGR_PER1MODRST_I2C1_SET_MSK,
74 ALT_RSTMGR_PER1MODRST_I2C2_SET_MSK, /* i2c0_emac */
75 ALT_RSTMGR_PER1MODRST_I2C3_SET_MSK, /* i2c1_emac */
76 ALT_RSTMGR_PER1MODRST_I2C4_SET_MSK, /* i2c2_emac */
79 0, /* sdmmc per0mod */
80 0, /* spim0 per0mod */
81 0, /* spim1 per0mod */
82 0, /* spis0 per0mod */
83 0, /* spis1 per0mod */
84 ALT_RSTMGR_PER1MODRST_UART0_SET_MSK,
85 ALT_RSTMGR_PER1MODRST_UART1_SET_MSK,
94 static const struct bridge_cfg bridge_cfg_tbl[] = {
96 COMPAT_ALTERA_SOCFPGA_H2F_BRG,
97 ALT_SYSMGR_NOC_H2F_SET_MSK,
98 ALT_RSTMGR_BRGMODRST_H2F_SET_MSK,
101 COMPAT_ALTERA_SOCFPGA_LWH2F_BRG,
102 ALT_SYSMGR_NOC_LWH2F_SET_MSK,
103 ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK,
106 COMPAT_ALTERA_SOCFPGA_F2H_BRG,
107 ALT_SYSMGR_NOC_F2H_SET_MSK,
108 ALT_RSTMGR_BRGMODRST_F2H_SET_MSK,
111 COMPAT_ALTERA_SOCFPGA_F2SDR0,
112 ALT_SYSMGR_NOC_F2SDR0_SET_MSK,
113 ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK,
116 COMPAT_ALTERA_SOCFPGA_F2SDR1,
117 ALT_SYSMGR_NOC_F2SDR1_SET_MSK,
118 ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK,
121 COMPAT_ALTERA_SOCFPGA_F2SDR2,
122 ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
123 ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK,
127 /* Disable the watchdog (toggle reset to watchdog) */
128 void socfpga_watchdog_disable(void)
130 /* assert reset for watchdog */
131 setbits_le32(&reset_manager_base->per1modrst,
132 ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
135 /* Release NOC ddr scheduler from reset */
136 void socfpga_reset_deassert_noc_ddr_scheduler(void)
138 clrbits_le32(&reset_manager_base->brgmodrst,
139 ALT_RSTMGR_BRGMODRST_DDRSCH_SET_MSK);
142 /* Check whether Watchdog in reset state? */
143 int socfpga_is_wdt_in_reset(void)
147 val = readl(&reset_manager_base->per1modrst);
148 val &= ALT_RSTMGR_PER1MODRST_WD0_SET_MSK;
150 /* return 0x1 if watchdog in reset */
154 /* emacbase: base address of emac to enable/disable reset
155 * state: 0 - disable reset, !0 - enable reset
157 void socfpga_emac_manage_reset(ulong emacbase, u32 state)
163 case SOCFPGA_EMAC0_ADDRESS:
164 eccmask = ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK;
165 emacmask = ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK;
167 case SOCFPGA_EMAC1_ADDRESS:
168 eccmask = ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK;
169 emacmask = ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK;
171 case SOCFPGA_EMAC2_ADDRESS:
172 eccmask = ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK;
173 emacmask = ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK;
176 pr_err("emac base address unexpected! %lx", emacbase);
182 /* Enable ECC OCP first */
183 setbits_le32(&reset_manager_base->per0modrst, eccmask);
184 setbits_le32(&reset_manager_base->per0modrst, emacmask);
186 /* Disable ECC OCP first */
187 clrbits_le32(&reset_manager_base->per0modrst, emacmask);
188 clrbits_le32(&reset_manager_base->per0modrst, eccmask);
192 static int get_bridge_init_val(const void *blob, int compat_id)
196 node = fdtdec_next_compatible(blob, 0, compat_id);
200 return fdtdec_get_uint(blob, node, "init-val", 0);
203 /* Enable bridges (hps2fpga, lwhps2fpga, fpga2hps, fpga2sdram) per handoff */
204 int socfpga_reset_deassert_bridges_handoff(void)
206 u32 mask_noc = 0, mask_rstmgr = 0;
209 for (i = 0; i < ARRAY_SIZE(bridge_cfg_tbl); i++) {
210 if (get_bridge_init_val(gd->fdt_blob,
211 bridge_cfg_tbl[i].compat_id)) {
212 mask_noc |= bridge_cfg_tbl[i].mask_noc;
213 mask_rstmgr |= bridge_cfg_tbl[i].mask_rstmgr;
217 /* clear idle request to all bridges */
218 setbits_le32(&sysmgr_regs->noc_idlereq_clr, mask_noc);
220 /* Release bridges from reset state per handoff value */
221 clrbits_le32(&reset_manager_base->brgmodrst, mask_rstmgr);
223 /* Poll until all idleack to 0, timeout at 1000ms */
224 return wait_for_bit_le32(&sysmgr_regs->noc_idleack, mask_noc,
228 void socfpga_reset_assert_fpga_connected_peripherals(void)
232 u32 fpga_pinux_addr = SOCFPGA_PINMUX_FPGA_INTERFACE_ADDRESS;
235 for (i = 0; i < ARRAY_SIZE(per1fpgamasks); i++) {
236 if (readl(fpga_pinux_addr)) {
237 mask0 |= per0fpgamasks[i];
238 mask1 |= per1fpgamasks[i];
240 fpga_pinux_addr += sizeof(u32);
243 setbits_le32(&reset_manager_base->per0modrst, mask0 & ECC_MASK);
244 setbits_le32(&reset_manager_base->per1modrst, mask1);
245 setbits_le32(&reset_manager_base->per0modrst, mask0);
248 /* Release L4 OSC1 Watchdog Timer 0 from reset through reset manager */
249 void socfpga_reset_deassert_osc1wd0(void)
251 clrbits_le32(&reset_manager_base->per1modrst,
252 ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
256 * Assert or de-assert SoCFPGA reset manager reset.
258 void socfpga_per_reset(u32 reset, int set)
261 u32 rstmgr_bank = RSTMGR_BANK(reset);
263 switch (rstmgr_bank) {
265 reg = &reset_manager_base->mpumodrst;
268 reg = &reset_manager_base->per0modrst;
271 reg = &reset_manager_base->per1modrst;
274 reg = &reset_manager_base->brgmodrst;
277 reg = &reset_manager_base->sysmodrst;
285 setbits_le32(reg, 1 << RSTMGR_RESET(reset));
287 clrbits_le32(reg, 1 << RSTMGR_RESET(reset));
291 * Assert reset on every peripheral but L4WD0.
292 * Watchdog must be kept intact to prevent glitches
294 * For the Arria10, we disable all the peripherals except L4 watchdog0,
295 * L4 Timer 0, and ECC.
297 void socfpga_per_reset_all(void)
299 const u32 l4wd0 = (1 << RSTMGR_RESET(SOCFPGA_RESET(L4WD0)) |
300 (1 << RSTMGR_RESET(SOCFPGA_RESET(L4SYSTIMER0))));
301 unsigned mask_ecc_ocp =
302 ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
303 ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
304 ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
305 ALT_RSTMGR_PER0MODRST_USBECC0_SET_MSK |
306 ALT_RSTMGR_PER0MODRST_USBECC1_SET_MSK |
307 ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
308 ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
309 ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK;
311 /* disable all components except ECC_OCP, L4 Timer0 and L4 WD0 */
312 writel(~l4wd0, &reset_manager_base->per1modrst);
313 setbits_le32(&reset_manager_base->per0modrst, ~mask_ecc_ocp);
315 /* Finally disable the ECC_OCP */
316 setbits_le32(&reset_manager_base->per0modrst, mask_ecc_ocp);
319 #if defined(CONFIG_SOCFPGA_VIRTUAL_TARGET)
320 int socfpga_bridges_reset(void)
322 /* For SoCFPGA-VT, this is NOP. */
326 int socfpga_bridges_reset(void)
330 /* Disable all the bridges (hps2fpga, lwhps2fpga, fpga2hps,
332 /* set idle request to all bridges */
333 writel(ALT_SYSMGR_NOC_H2F_SET_MSK |
334 ALT_SYSMGR_NOC_LWH2F_SET_MSK |
335 ALT_SYSMGR_NOC_F2H_SET_MSK |
336 ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
337 ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
338 ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
339 &sysmgr_regs->noc_idlereq_set);
341 /* Enable the NOC timeout */
342 writel(ALT_SYSMGR_NOC_TMO_EN_SET_MSK, &sysmgr_regs->noc_timeout);
344 /* Poll until all idleack to 1 */
345 ret = wait_for_bit_le32(&sysmgr_regs->noc_idleack,
346 ALT_SYSMGR_NOC_H2F_SET_MSK |
347 ALT_SYSMGR_NOC_LWH2F_SET_MSK |
348 ALT_SYSMGR_NOC_F2H_SET_MSK |
349 ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
350 ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
351 ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
356 /* Poll until all idlestatus to 1 */
357 ret = wait_for_bit_le32(&sysmgr_regs->noc_idlestatus,
358 ALT_SYSMGR_NOC_H2F_SET_MSK |
359 ALT_SYSMGR_NOC_LWH2F_SET_MSK |
360 ALT_SYSMGR_NOC_F2H_SET_MSK |
361 ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
362 ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
363 ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
368 /* Put all bridges (except NOR DDR scheduler) into reset state */
369 setbits_le32(&reset_manager_base->brgmodrst,
370 (ALT_RSTMGR_BRGMODRST_H2F_SET_MSK |
371 ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK |
372 ALT_RSTMGR_BRGMODRST_F2H_SET_MSK |
373 ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK |
374 ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK |
375 ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK));
377 /* Disable NOC timeout */
378 writel(0, &sysmgr_regs->noc_timeout);