mirror of
https://github.com/u-boot/u-boot.git
synced 2025-05-03 18:23:34 +00:00

There are 5 L4 watchdogs and one SDM triggered warm reset bit in Agilex5 reset manager "stat" register where bit 16:20 for L4 watchdogs. Assigning value 1 to these bits in the register address will initiate SDM to trigger warm reset. Introducing new warm reset mask for Agilex5 to trigger warm reset to all five L4 watchdogs. Signed-off-by: Tien Fong Chee <tien.fong.chee@altera.com> Signed-off-by: Alif Zakuan Yuslaimi <alif.zakuan.yuslaimi@altera.com> Reviewed-by: Tien Fong Chee <tien.fong.chee@altera.com>
53 lines
1.6 KiB
C
53 lines
1.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (C) 2016-2019 Intel Corporation <www.intel.com>
|
|
* Copyright (C) 2025 Altera Corporation <www.altera.com>
|
|
*/
|
|
|
|
#ifndef _RESET_MANAGER_SOC64_H_
|
|
#define _RESET_MANAGER_SOC64_H_
|
|
|
|
void reset_deassert_peripherals_handoff(void);
|
|
int cpu_has_been_warmreset(void);
|
|
void print_reset_info(void);
|
|
void socfpga_bridges_reset(int enable);
|
|
|
|
#define RSTMGR_SOC64_STATUS 0x00
|
|
#define RSTMGR_SOC64_MPUMODRST 0x20
|
|
#define RSTMGR_SOC64_PER0MODRST 0x24
|
|
#define RSTMGR_SOC64_PER1MODRST 0x28
|
|
#define RSTMGR_SOC64_BRGMODRST 0x2c
|
|
|
|
#define RSTMGR_MPUMODRST_CORE0 0
|
|
#define RSTMGR_PER0MODRST_OCP_MASK 0x0020bf00
|
|
#define RSTMGR_BRGMODRST_DDRSCH_MASK 0X00000040
|
|
#define RSTMGR_BRGMODRST_FPGA2SOC_MASK 0x00000004
|
|
|
|
/* SDM, Watchdogs and MPU warm reset mask */
|
|
#define RSTMGR_STAT_SDMWARMRST 0x2
|
|
#define RSTMGR_STAT_MPU0RST_BITPOS 8
|
|
#define RSTMGR_STAT_L4WD0RST_BITPOS 16
|
|
#if IS_ENABLED(CONFIG_TARGET_SOCFPGA_AGILEX5)
|
|
#define RSTMGR_STAT_L4WD0RST_BIT 0x1F0000
|
|
#define RSTMGR_L4WD_MPU_WARMRESET_MASK (RSTMGR_STAT_SDMWARMRST | \
|
|
RSTMGR_STAT_L4WD0RST_BIT)
|
|
#else
|
|
#define RSTMGR_L4WD_MPU_WARMRESET_MASK (RSTMGR_STAT_SDMWARMRST | \
|
|
GENMASK(RSTMGR_STAT_MPU0RST_BITPOS + 3, \
|
|
RSTMGR_STAT_MPU0RST_BITPOS) | \
|
|
GENMASK(RSTMGR_STAT_L4WD0RST_BITPOS + 3, \
|
|
RSTMGR_STAT_L4WD0RST_BITPOS))
|
|
#endif
|
|
|
|
/*
|
|
* SocFPGA Stratix10 reset IDs, bank mapping is as follows:
|
|
* 0 ... mpumodrst
|
|
* 1 ... per0modrst
|
|
* 2 ... per1modrst
|
|
* 3 ... brgmodrst
|
|
*/
|
|
#define RSTMGR_L4WD0 RSTMGR_DEFINE(2, 0)
|
|
#define RSTMGR_OSC1TIMER0 RSTMGR_DEFINE(2, 4)
|
|
#define RSTMGR_UART0 RSTMGR_DEFINE(2, 16)
|
|
|
|
#endif /* _RESET_MANAGER_SOC64_H_ */
|