reset_manager_arria10.c 10.0 KB

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