mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-25 01:58:13 +01:00 
			
		
		
		
	This patch triggers warm reset to recover the MPFE NoC from corruption due to high frequency transient clock output from HPS EMIF IOPLL at VCO startup after peripheral RBF is programmed. Signed-off-by: Tien Fong Chee <tien.fong.chee@intel.com> Signed-off-by: Sin Hui Kho <sin.hui.kho@intel.com> Reviewed-by: Tien Fong Chee <tien.fong.chee@intel.com>
		
			
				
	
	
		
			123 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			123 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0 */
 | |
| /*
 | |
|  * Copyright (C) 2016-2021 Intel Corporation
 | |
|  */
 | |
| 
 | |
| #ifndef _RESET_MANAGER_ARRIA10_H_
 | |
| #define _RESET_MANAGER_ARRIA10_H_
 | |
| 
 | |
| #include <dt-bindings/reset/altr,rst-mgr-a10.h>
 | |
| #include <linux/bitops.h>
 | |
| 
 | |
| void socfpga_watchdog_disable(void);
 | |
| void socfpga_reset_deassert_noc_ddr_scheduler(void);
 | |
| int socfpga_reset_deassert_bridges_handoff(void);
 | |
| void socfpga_reset_deassert_osc1wd0(void);
 | |
| int socfpga_bridges_reset(void);
 | |
| 
 | |
| #define RSTMGR_A10_STATUS	0x00
 | |
| #define RSTMGR_A10_CTRL		0x0c
 | |
| #define RSTMGR_A10_MPUMODRST	0x20
 | |
| #define RSTMGR_A10_PER0MODRST	0x24
 | |
| #define RSTMGR_A10_PER1MODRST	0x28
 | |
| #define RSTMGR_A10_BRGMODRST	0x2c
 | |
| #define RSTMGR_A10_SYSMODRST	0x30
 | |
| #define RSTMGR_A10_SYSWARMMASK	0x50
 | |
| 
 | |
| #define RSTMGR_CTRL		RSTMGR_A10_CTRL
 | |
| 
 | |
| /*
 | |
|  * SocFPGA Arria10 reset IDs, bank mapping is as follows:
 | |
|  * 0 ... mpumodrst
 | |
|  * 1 ... per0modrst
 | |
|  * 2 ... per1modrst
 | |
|  * 3 ... brgmodrst
 | |
|  * 4 ... sysmodrst
 | |
|  */
 | |
| #define RSTMGR_EMAC0		RSTMGR_DEFINE(1, 0)
 | |
| #define RSTMGR_EMAC1		RSTMGR_DEFINE(1, 1)
 | |
| #define RSTMGR_EMAC2		RSTMGR_DEFINE(1, 2)
 | |
| #define RSTMGR_NAND		RSTMGR_DEFINE(1, 5)
 | |
| #define RSTMGR_QSPI		RSTMGR_DEFINE(1, 6)
 | |
| #define RSTMGR_SDMMC		RSTMGR_DEFINE(1, 7)
 | |
| #define RSTMGR_DMA		RSTMGR_DEFINE(1, 16)
 | |
| #define RSTMGR_SPIM0		RSTMGR_DEFINE(1, 17)
 | |
| #define RSTMGR_SPIM1		RSTMGR_DEFINE(1, 18)
 | |
| #define RSTMGR_L4WD0		RSTMGR_DEFINE(2, 0)
 | |
| #define RSTMGR_L4WD1		RSTMGR_DEFINE(2, 1)
 | |
| #define RSTMGR_L4SYSTIMER0	RSTMGR_DEFINE(2, 2)
 | |
| #define RSTMGR_L4SYSTIMER1	RSTMGR_DEFINE(2, 3)
 | |
| #define RSTMGR_SPTIMER0		RSTMGR_DEFINE(2, 4)
 | |
| #define RSTMGR_SPTIMER1		RSTMGR_DEFINE(2, 5)
 | |
| #define RSTMGR_UART0		RSTMGR_DEFINE(2, 16)
 | |
| #define RSTMGR_UART1		RSTMGR_DEFINE(2, 17)
 | |
| #define RSTMGR_DDRSCH		RSTMGR_DEFINE(3, 6)
 | |
| 
 | |
| #define ALT_RSTMGR_CTL_SWWARMRSTREQ_SET_MSK	BIT(1)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMAC0_SET_MSK	BIT(0)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMAC1_SET_MSK	BIT(1)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMAC2_SET_MSK	BIT(2)
 | |
| #define ALT_RSTMGR_PER0MODRST_USB0_SET_MSK	BIT(3)
 | |
| #define ALT_RSTMGR_PER0MODRST_USB1_SET_MSK	BIT(4)
 | |
| #define ALT_RSTMGR_PER0MODRST_NAND_SET_MSK	BIT(5)
 | |
| #define ALT_RSTMGR_PER0MODRST_QSPI_SET_MSK	BIT(6)
 | |
| #define ALT_RSTMGR_PER0MODRST_SDMMC_SET_MSK	BIT(7)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMACECC0_SET_MSK	BIT(8)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMACECC1_SET_MSK	BIT(9)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMACECC2_SET_MSK	BIT(10)
 | |
| #define ALT_RSTMGR_PER0MODRST_USBECC0_SET_MSK	BIT(11)
 | |
| #define ALT_RSTMGR_PER0MODRST_USBECC1_SET_MSK	BIT(12)
 | |
| #define ALT_RSTMGR_PER0MODRST_NANDECC_SET_MSK	BIT(13)
 | |
| #define ALT_RSTMGR_PER0MODRST_QSPIECC_SET_MSK	BIT(14)
 | |
| #define ALT_RSTMGR_PER0MODRST_SDMMCECC_SET_MSK	BIT(15)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMA_SET_MSK	BIT(16)
 | |
| #define ALT_RSTMGR_PER0MODRST_SPIM0_SET_MSK	BIT(17)
 | |
| #define ALT_RSTMGR_PER0MODRST_SPIM1_SET_MSK	BIT(18)
 | |
| #define ALT_RSTMGR_PER0MODRST_SPIS0_SET_MSK	BIT(19)
 | |
| #define ALT_RSTMGR_PER0MODRST_SPIS1_SET_MSK	BIT(20)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAECC_SET_MSK	BIT(21)
 | |
| #define ALT_RSTMGR_PER0MODRST_EMACPTP_SET_MSK	BIT(22)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF0_SET_MSK	BIT(24)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF1_SET_MSK	BIT(25)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF2_SET_MSK	BIT(26)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF3_SET_MSK	BIT(27)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF4_SET_MSK	BIT(28)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF5_SET_MSK	BIT(29)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF6_SET_MSK	BIT(30)
 | |
| #define ALT_RSTMGR_PER0MODRST_DMAIF7_SET_MSK	BIT(31)
 | |
| 
 | |
| #define ALT_RSTMGR_PER1MODRST_WD0_SET_MSK	BIT(0)
 | |
| #define ALT_RSTMGR_PER1MODRST_WD1_SET_MSK	BIT(1)
 | |
| #define ALT_RSTMGR_PER1MODRST_L4SYSTMR0_SET_MSK	BIT(2)
 | |
| #define ALT_RSTMGR_PER1MODRST_L4SYSTMR1_SET_MSK	BIT(3)
 | |
| #define ALT_RSTMGR_PER1MODRST_SPTMR0_SET_MSK	BIT(4)
 | |
| #define ALT_RSTMGR_PER1MODRST_SPTMR1_SET_MSK	BIT(5)
 | |
| #define ALT_RSTMGR_PER1MODRST_I2C0_SET_MSK	BIT(8)
 | |
| #define ALT_RSTMGR_PER1MODRST_I2C1_SET_MSK	BIT(9)
 | |
| #define ALT_RSTMGR_PER1MODRST_I2C2_SET_MSK	BIT(10)
 | |
| #define ALT_RSTMGR_PER1MODRST_I2C3_SET_MSK	BIT(11)
 | |
| #define ALT_RSTMGR_PER1MODRST_I2C4_SET_MSK	BIT(12)
 | |
| #define ALT_RSTMGR_PER1MODRST_UART0_SET_MSK	BIT(16)
 | |
| #define ALT_RSTMGR_PER1MODRST_UART1_SET_MSK	BIT(17)
 | |
| #define ALT_RSTMGR_PER1MODRST_GPIO0_SET_MSK	BIT(24)
 | |
| #define ALT_RSTMGR_PER1MODRST_GPIO1_SET_MSK	BIT(25)
 | |
| #define ALT_RSTMGR_PER1MODRST_GPIO2_SET_MSK	BIT(26)
 | |
| 
 | |
| #define ALT_RSTMGR_BRGMODRST_H2F_SET_MSK	BIT(0)
 | |
| #define ALT_RSTMGR_BRGMODRST_LWH2F_SET_MSK	BIT(1)
 | |
| #define ALT_RSTMGR_BRGMODRST_F2H_SET_MSK	BIT(2)
 | |
| #define ALT_RSTMGR_BRGMODRST_F2SSDRAM0_SET_MSK	BIT(3)
 | |
| #define ALT_RSTMGR_BRGMODRST_F2SSDRAM1_SET_MSK	BIT(4)
 | |
| #define ALT_RSTMGR_BRGMODRST_F2SSDRAM2_SET_MSK	BIT(5)
 | |
| #define ALT_RSTMGR_BRGMODRST_DDRSCH_SET_MSK	BIT(6)
 | |
| 
 | |
| #define ALT_RSTMGR_HDSKEN_SDRSELFREFEN_SET_MSK	BIT(0)
 | |
| #define ALT_RSTMGR_HDSKEN_FPGAMGRHSEN_SET_MSK	BIT(1)
 | |
| #define ALT_RSTMGR_HDSKEN_FPGAHSEN_SET_MSK	BIT(2)
 | |
| #define ALT_RSTMGR_HDSKEN_ETRSTALLEN_SET_MSK	BIT(3)
 | |
| 
 | |
| #define ALT_RSTMGR_FPGAMGRWARMMASK_S2F_SET_MSK	BIT(3)
 | |
| #define ALT_RSTMGR_SYSWARMMASK_S2F_SET_MSK	BIT(4)
 | |
| 
 | |
| #endif /* _RESET_MANAGER_ARRIA10_H_ */
 |