[U-Boot] [PATCH v1] ARM: socfpga: stratix10: Disable FPGA2SOC reset

Marek Vasut marex at denx.de
Fri May 3 15:10:09 UTC 2019


On 5/3/19 10:19 AM, chee.hong.ang at intel.com wrote:
> From: "Ang, Chee Hong" <chee.hong.ang at intel.com>
> 
> Software must never reset FPGA2SOC bridge. This bridge must only be
> reset by POR/COLD/WARM reset. Asserting the FPGA2SOC reset by software
> can cause the SoC to lock-up if there are traffics being drived into
> FPGA2SOC bridge.
> 
> Signed-off-by: Ang, Chee Hong <chee.hong.ang at intel.com>
> ---
>  arch/arm/mach-socfpga/include/mach/reset_manager_s10.h | 2 ++
>  arch/arm/mach-socfpga/reset_manager_s10.c              | 7 ++++---
>  2 files changed, 6 insertions(+), 3 deletions(-)
> 
> diff --git a/arch/arm/mach-socfpga/include/mach/reset_manager_s10.h b/arch/arm/mach-socfpga/include/mach/reset_manager_s10.h
> index 3ac46c3..aef965e 100644
> --- a/arch/arm/mach-socfpga/include/mach/reset_manager_s10.h
> +++ b/arch/arm/mach-socfpga/include/mach/reset_manager_s10.h
> @@ -48,6 +48,8 @@ struct socfpga_reset_manager {
>  #define RSTMGR_MPUMODRST_CORE0		0
>  #define RSTMGR_PER0MODRST_OCP_MASK	0x0020bf00
>  #define RSTMGR_BRGMODRST_DDRSCH_MASK	0X00000040
> +#define RSTMGR_BRGMODRST_FPGA2SOC_MASK	0x00000004
> +
>  /* Watchdogs and MPU warm reset mask */
>  #define RSTMGR_L4WD_MPU_WARMRESET_MASK	0x000F0F00
>  
> diff --git a/arch/arm/mach-socfpga/reset_manager_s10.c b/arch/arm/mach-socfpga/reset_manager_s10.c
> index f8dd787..39753a1 100644
> --- a/arch/arm/mach-socfpga/reset_manager_s10.c
> +++ b/arch/arm/mach-socfpga/reset_manager_s10.c
> @@ -61,7 +61,7 @@ void socfpga_bridges_reset(int enable)
>  		/* clear idle request to all bridges */
>  		setbits_le32(&system_manager_base->noc_idlereq_clr, ~0);
>  
> -		/* Release bridges from reset state per handoff value */
> +		/* Release all bridges from reset state */
>  		clrbits_le32(&reset_manager_base->brgmodrst, ~0);
>  
>  		/* Poll until all idleack to 0 */
> @@ -84,9 +84,10 @@ void socfpga_bridges_reset(int enable)
>  			(SYSMGR_NOC_H2F_MSK | SYSMGR_NOC_LWH2F_MSK)))
>  			;
>  
> -		/* Put all bridges (except NOR DDR scheduler) into reset */
> +		/* Reset all bridges (except NOR DDR scheduler & F2S) */
>  		setbits_le32(&reset_manager_base->brgmodrst,
> -			     ~RSTMGR_BRGMODRST_DDRSCH_MASK);
> +			     ~(RSTMGR_BRGMODRST_DDRSCH_MASK |
> +			     RSTMGR_BRGMODRST_FPGA2SOC_MASK));
>  
>  		/* Disable NOC timeout */
>  		writel(0, &system_manager_base->noc_timeout);
> 
Applied, thanks

-- 
Best regards,
Marek Vasut


More information about the U-Boot mailing list