reset_manager_arria10.c 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (C) 2016-2017 Intel Corporation
  4. */
  5. #include <asm/io.h>
  6. #include <asm/arch/fpga_manager.h>
  7. #include <asm/arch/misc.h>
  8. #include <asm/arch/reset_manager.h>
  9. #include <asm/arch/system_manager.h>
  10. #include <common.h>
  11. #include <errno.h>
  12. #include <fdtdec.h>
  13. #include <wait_bit.h>
  14. DECLARE_GLOBAL_DATA_PTR;
  15. static const struct socfpga_reset_manager *reset_manager_base =
  16. (void *)SOCFPGA_RSTMGR_ADDRESS;
  17. static const struct socfpga_system_manager *sysmgr_regs =
  18. (struct socfpga_system_manager *)SOCFPGA_SYSMGR_ADDRESS;
  19. struct bridge_cfg {
  20. int compat_id;
  21. u32 mask_noc;
  22. u32 mask_rstmgr;
  23. };
  24. static const struct bridge_cfg bridge_cfg_tbl[] = {
  25. {
  26. COMPAT_ALTERA_SOCFPGA_H2F_BRG,
  27. ALT_SYSMGR_NOC_H2F_SET_MSK,
  28. ALT_RSTMGR_BRGMODRST_H2F_SET_MSK,
  29. },
  30. {
  31. COMPAT_ALTERA_SOCFPGA_LWH2F_BRG,
  32. ALT_SYSMGR_NOC_LWH2F_SET_MSK,
  33. ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK,
  34. },
  35. {
  36. COMPAT_ALTERA_SOCFPGA_F2H_BRG,
  37. ALT_SYSMGR_NOC_F2H_SET_MSK,
  38. ALT_RSTMGR_BRGMODRST_F2H_SET_MSK,
  39. },
  40. {
  41. COMPAT_ALTERA_SOCFPGA_F2SDR0,
  42. ALT_SYSMGR_NOC_F2SDR0_SET_MSK,
  43. ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK,
  44. },
  45. {
  46. COMPAT_ALTERA_SOCFPGA_F2SDR1,
  47. ALT_SYSMGR_NOC_F2SDR1_SET_MSK,
  48. ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK,
  49. },
  50. {
  51. COMPAT_ALTERA_SOCFPGA_F2SDR2,
  52. ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
  53. ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK,
  54. },
  55. };
  56. /* Disable the watchdog (toggle reset to watchdog) */
  57. void socfpga_watchdog_disable(void)
  58. {
  59. /* assert reset for watchdog */
  60. setbits_le32(&reset_manager_base->per1modrst,
  61. ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
  62. }
  63. /* Release NOC ddr scheduler from reset */
  64. void socfpga_reset_deassert_noc_ddr_scheduler(void)
  65. {
  66. clrbits_le32(&reset_manager_base->brgmodrst,
  67. ALT_RSTMGR_BRGMODRST_DDRSCH_SET_MSK);
  68. }
  69. static int get_bridge_init_val(const void *blob, int compat_id)
  70. {
  71. int node;
  72. node = fdtdec_next_compatible(blob, 0, compat_id);
  73. if (node < 0)
  74. return 0;
  75. return fdtdec_get_uint(blob, node, "init-val", 0);
  76. }
  77. /* Enable bridges (hps2fpga, lwhps2fpga, fpga2hps, fpga2sdram) per handoff */
  78. int socfpga_reset_deassert_bridges_handoff(void)
  79. {
  80. u32 mask_noc = 0, mask_rstmgr = 0;
  81. int i;
  82. for (i = 0; i < ARRAY_SIZE(bridge_cfg_tbl); i++) {
  83. if (get_bridge_init_val(gd->fdt_blob,
  84. bridge_cfg_tbl[i].compat_id)) {
  85. mask_noc |= bridge_cfg_tbl[i].mask_noc;
  86. mask_rstmgr |= bridge_cfg_tbl[i].mask_rstmgr;
  87. }
  88. }
  89. /* clear idle request to all bridges */
  90. setbits_le32(&sysmgr_regs->noc_idlereq_clr, mask_noc);
  91. /* Release bridges from reset state per handoff value */
  92. clrbits_le32(&reset_manager_base->brgmodrst, mask_rstmgr);
  93. /* Poll until all idleack to 0, timeout at 1000ms */
  94. return wait_for_bit_le32(&sysmgr_regs->noc_idleack, mask_noc,
  95. false, 1000, false);
  96. }
  97. /* Release L4 OSC1 Watchdog Timer 0 from reset through reset manager */
  98. void socfpga_reset_deassert_osc1wd0(void)
  99. {
  100. clrbits_le32(&reset_manager_base->per1modrst,
  101. ALT_RSTMGR_PER1MODRST_WD0_SET_MSK);
  102. }
  103. /*
  104. * Assert or de-assert SoCFPGA reset manager reset.
  105. */
  106. void socfpga_per_reset(u32 reset, int set)
  107. {
  108. const u32 *reg;
  109. u32 rstmgr_bank = RSTMGR_BANK(reset);
  110. switch (rstmgr_bank) {
  111. case 0:
  112. reg = &reset_manager_base->mpumodrst;
  113. break;
  114. case 1:
  115. reg = &reset_manager_base->per0modrst;
  116. break;
  117. case 2:
  118. reg = &reset_manager_base->per1modrst;
  119. break;
  120. case 3:
  121. reg = &reset_manager_base->brgmodrst;
  122. break;
  123. case 4:
  124. reg = &reset_manager_base->sysmodrst;
  125. break;
  126. default:
  127. return;
  128. }
  129. if (set)
  130. setbits_le32(reg, 1 << RSTMGR_RESET(reset));
  131. else
  132. clrbits_le32(reg, 1 << RSTMGR_RESET(reset));
  133. }
  134. /*
  135. * Assert reset on every peripheral but L4WD0.
  136. * Watchdog must be kept intact to prevent glitches
  137. * and/or hangs.
  138. * For the Arria10, we disable all the peripherals except L4 watchdog0,
  139. * L4 Timer 0, and ECC.
  140. */
  141. void socfpga_per_reset_all(void)
  142. {
  143. const u32 l4wd0 = (1 << RSTMGR_RESET(SOCFPGA_RESET(L4WD0)) |
  144. (1 << RSTMGR_RESET(SOCFPGA_RESET(L4SYSTIMER0))));
  145. unsigned mask_ecc_ocp =
  146. ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK |
  147. ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK |
  148. ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK |
  149. ALT_RSTMGR_PER0MODRST_USBECC0_SET_MSK |
  150. ALT_RSTMGR_PER0MODRST_USBECC1_SET_MSK |
  151. ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK |
  152. ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK |
  153. ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK;
  154. /* disable all components except ECC_OCP, L4 Timer0 and L4 WD0 */
  155. writel(~l4wd0, &reset_manager_base->per1modrst);
  156. setbits_le32(&reset_manager_base->per0modrst, ~mask_ecc_ocp);
  157. /* Finally disable the ECC_OCP */
  158. setbits_le32(&reset_manager_base->per0modrst, mask_ecc_ocp);
  159. }
  160. int socfpga_bridges_reset(void)
  161. {
  162. int ret;
  163. /* Disable all the bridges (hps2fpga, lwhps2fpga, fpga2hps,
  164. fpga2sdram) */
  165. /* set idle request to all bridges */
  166. writel(ALT_SYSMGR_NOC_H2F_SET_MSK |
  167. ALT_SYSMGR_NOC_LWH2F_SET_MSK |
  168. ALT_SYSMGR_NOC_F2H_SET_MSK |
  169. ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
  170. ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
  171. ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
  172. &sysmgr_regs->noc_idlereq_set);
  173. /* Enable the NOC timeout */
  174. writel(ALT_SYSMGR_NOC_TMO_EN_SET_MSK, &sysmgr_regs->noc_timeout);
  175. /* Poll until all idleack to 1 */
  176. ret = wait_for_bit_le32(&sysmgr_regs->noc_idleack,
  177. ALT_SYSMGR_NOC_H2F_SET_MSK |
  178. ALT_SYSMGR_NOC_LWH2F_SET_MSK |
  179. ALT_SYSMGR_NOC_F2H_SET_MSK |
  180. ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
  181. ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
  182. ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
  183. true, 10000, false);
  184. if (ret)
  185. return ret;
  186. /* Poll until all idlestatus to 1 */
  187. ret = wait_for_bit_le32(&sysmgr_regs->noc_idlestatus,
  188. ALT_SYSMGR_NOC_H2F_SET_MSK |
  189. ALT_SYSMGR_NOC_LWH2F_SET_MSK |
  190. ALT_SYSMGR_NOC_F2H_SET_MSK |
  191. ALT_SYSMGR_NOC_F2SDR0_SET_MSK |
  192. ALT_SYSMGR_NOC_F2SDR1_SET_MSK |
  193. ALT_SYSMGR_NOC_F2SDR2_SET_MSK,
  194. true, 10000, false);
  195. if (ret)
  196. return ret;
  197. /* Put all bridges (except NOR DDR scheduler) into reset state */
  198. setbits_le32(&reset_manager_base->brgmodrst,
  199. (ALT_RSTMGR_BRGMODRST_H2F_SET_MSK |
  200. ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK |
  201. ALT_RSTMGR_BRGMODRST_F2H_SET_MSK |
  202. ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK |
  203. ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK |
  204. ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK));
  205. /* Disable NOC timeout */
  206. writel(0, &sysmgr_regs->noc_timeout);
  207. return 0;
  208. }