reset_manager_gen5.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Copyright (C) 2013 Altera Corporation <www.altera.com>
  4. */
  5. #include <common.h>
  6. #include <asm/io.h>
  7. #include <asm/arch/fpga_manager.h>
  8. #include <asm/arch/reset_manager.h>
  9. #include <asm/arch/system_manager.h>
  10. static const struct socfpga_reset_manager *reset_manager_base =
  11. (void *)SOCFPGA_RSTMGR_ADDRESS;
  12. static const struct socfpga_system_manager *sysmgr_regs =
  13. (struct socfpga_system_manager *)SOCFPGA_SYSMGR_ADDRESS;
  14. /* Assert or de-assert SoCFPGA reset manager reset. */
  15. void socfpga_per_reset(u32 reset, int set)
  16. {
  17. const u32 *reg;
  18. u32 rstmgr_bank = RSTMGR_BANK(reset);
  19. switch (rstmgr_bank) {
  20. case 0:
  21. reg = &reset_manager_base->mpu_mod_reset;
  22. break;
  23. case 1:
  24. reg = &reset_manager_base->per_mod_reset;
  25. break;
  26. case 2:
  27. reg = &reset_manager_base->per2_mod_reset;
  28. break;
  29. case 3:
  30. reg = &reset_manager_base->brg_mod_reset;
  31. break;
  32. case 4:
  33. reg = &reset_manager_base->misc_mod_reset;
  34. break;
  35. default:
  36. return;
  37. }
  38. if (set)
  39. setbits_le32(reg, 1 << RSTMGR_RESET(reset));
  40. else
  41. clrbits_le32(reg, 1 << RSTMGR_RESET(reset));
  42. }
  43. /*
  44. * Assert reset on every peripheral but L4WD0.
  45. * Watchdog must be kept intact to prevent glitches
  46. * and/or hangs.
  47. */
  48. void socfpga_per_reset_all(void)
  49. {
  50. const u32 l4wd0 = 1 << RSTMGR_RESET(SOCFPGA_RESET(L4WD0));
  51. writel(~l4wd0, &reset_manager_base->per_mod_reset);
  52. writel(0xffffffff, &reset_manager_base->per2_mod_reset);
  53. }
  54. /*
  55. * Release peripherals from reset based on handoff
  56. */
  57. void reset_deassert_peripherals_handoff(void)
  58. {
  59. writel(0, &reset_manager_base->per_mod_reset);
  60. }
  61. #define L3REGS_REMAP_LWHPS2FPGA_MASK 0x10
  62. #define L3REGS_REMAP_HPS2FPGA_MASK 0x08
  63. #define L3REGS_REMAP_OCRAM_MASK 0x01
  64. void socfpga_bridges_reset(int enable)
  65. {
  66. const u32 l3mask = L3REGS_REMAP_LWHPS2FPGA_MASK |
  67. L3REGS_REMAP_HPS2FPGA_MASK |
  68. L3REGS_REMAP_OCRAM_MASK;
  69. if (enable) {
  70. /* brdmodrst */
  71. writel(0xffffffff, &reset_manager_base->brg_mod_reset);
  72. } else {
  73. writel(0, &sysmgr_regs->iswgrp_handoff[0]);
  74. writel(l3mask, &sysmgr_regs->iswgrp_handoff[1]);
  75. /* Check signal from FPGA. */
  76. if (!fpgamgr_test_fpga_ready()) {
  77. /* FPGA not ready, do nothing. We allow system to boot
  78. * without FPGA ready. So, return 0 instead of error. */
  79. printf("%s: FPGA not ready, aborting.\n", __func__);
  80. return;
  81. }
  82. /* brdmodrst */
  83. writel(0, &reset_manager_base->brg_mod_reset);
  84. /* Remap the bridges into memory map */
  85. writel(l3mask, SOCFPGA_L3REGS_ADDRESS);
  86. }
  87. return;
  88. }