Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2012 Altera Corporation <www.altera.com> |
| 3 | * |
Wolfgang Denk | d79de1d | 2013-07-08 09:37:19 +0200 | [diff] [blame] | 4 | * SPDX-License-Identifier: GPL-2.0+ |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 5 | */ |
| 6 | |
| 7 | #ifndef _RESET_MANAGER_H_ |
| 8 | #define _RESET_MANAGER_H_ |
| 9 | |
| 10 | void reset_cpu(ulong addr); |
| 11 | void reset_deassert_peripherals_handoff(void); |
| 12 | |
Marek Vasut | 8d8c648 | 2014-09-08 14:08:45 +0200 | [diff] [blame] | 13 | void socfpga_bridges_reset(int enable); |
| 14 | |
Marek Vasut | c38c869 | 2014-09-08 14:08:45 +0200 | [diff] [blame] | 15 | void socfpga_emac_reset(int enable); |
Pavel Machek | 56a00ab | 2014-09-09 14:03:28 +0200 | [diff] [blame] | 16 | void socfpga_watchdog_reset(void); |
Stefan Roese | ca6b8fb | 2014-11-07 13:50:30 +0100 | [diff] [blame] | 17 | void socfpga_spim_enable(void); |
Dinh Nguyen | 804a50b | 2015-03-30 17:01:04 -0500 | [diff] [blame] | 18 | void socfpga_uart0_enable(void); |
| 19 | void socfpga_sdram_enable(void); |
| 20 | void socfpga_osc1timer_enable(void); |
Pavel Machek | 56a00ab | 2014-09-09 14:03:28 +0200 | [diff] [blame] | 21 | |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 22 | struct socfpga_reset_manager { |
Chin Liang See | 1922dad | 2013-08-07 10:08:03 -0500 | [diff] [blame] | 23 | u32 status; |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 24 | u32 ctrl; |
Chin Liang See | 1922dad | 2013-08-07 10:08:03 -0500 | [diff] [blame] | 25 | u32 counts; |
| 26 | u32 padding1; |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 27 | u32 mpu_mod_reset; |
| 28 | u32 per_mod_reset; |
| 29 | u32 per2_mod_reset; |
| 30 | u32 brg_mod_reset; |
| 31 | }; |
| 32 | |
Chin Liang See | 1922dad | 2013-08-07 10:08:03 -0500 | [diff] [blame] | 33 | #if defined(CONFIG_SOCFPGA_VIRTUAL_TARGET) |
| 34 | #define RSTMGR_CTRL_SWWARMRSTREQ_LSB 2 |
| 35 | #else |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 36 | #define RSTMGR_CTRL_SWWARMRSTREQ_LSB 1 |
Chin Liang See | 1922dad | 2013-08-07 10:08:03 -0500 | [diff] [blame] | 37 | #endif |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 38 | |
Marek Vasut | c38c869 | 2014-09-08 14:08:45 +0200 | [diff] [blame] | 39 | #define RSTMGR_PERMODRST_EMAC0_LSB 0 |
| 40 | #define RSTMGR_PERMODRST_EMAC1_LSB 1 |
Pavel Machek | 56a00ab | 2014-09-09 14:03:28 +0200 | [diff] [blame] | 41 | #define RSTMGR_PERMODRST_L4WD0_LSB 6 |
Dinh Nguyen | 804a50b | 2015-03-30 17:01:04 -0500 | [diff] [blame] | 42 | #define RSTMGR_PERMODRST_OSC1TIMER0_LSB 8 |
| 43 | #define RSTMGR_PERMODRST_UART0_LSB 16 |
Stefan Roese | ca6b8fb | 2014-11-07 13:50:30 +0100 | [diff] [blame] | 44 | #define RSTMGR_PERMODRST_SPIM0_LSB 18 |
| 45 | #define RSTMGR_PERMODRST_SPIM1_LSB 19 |
Dinh Nguyen | 804a50b | 2015-03-30 17:01:04 -0500 | [diff] [blame] | 46 | #define RSTMGR_PERMODRST_SDR_LSB 29 |
Pavel Machek | 56a00ab | 2014-09-09 14:03:28 +0200 | [diff] [blame] | 47 | |
Dinh Nguyen | ad51f7c | 2012-10-04 06:46:02 +0000 | [diff] [blame] | 48 | #endif /* _RESET_MANAGER_H_ */ |