mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-12-16 08:13:17 +00:00
715e709038
In case the IWDG is enabled by either U-Boot or Linux, the IWDG can never be disabled again. That includes low power states, which means that if the IWDG is enabled, the SoC would reset itself after a while in suspend via the IWDG. This is not desired behavior. It is possible to enable IWDG pre-timeout IRQ which is routed into the EXTI, and use that IRQ to wake the CPU up before the IWDG timeout is reached and reset is triggered. This pre-timeout IRQ can be used to reload the WDT and then suspend the CPU again every once in a while. Implement this functionality for both IWDG1 and IWDG2 by reading out all the unmasked IRQs, comparing the list with currently pending IRQs in GICv3: - If any IRQ is pending and it is NOT IWDG1 or IWDG2 pre-timeout IRQ, wake up and let OS handle the IRQs - If IWDG1 or IWDG2 IRQ is pending and no other IRQ is pending, ping the respective IWDG and suspend again This does not seem to have any adverse impact on power consumption in suspend. Signed-off-by: Marek Vasut <marex@denx.de> Reviewed-by: Patrick Delaunay <patrick.delaunay@foss.st.com>
180 lines
4.6 KiB
C
180 lines
4.6 KiB
C
/* SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause */
|
|
/*
|
|
* Copyright (C) 2018, STMicroelectronics - All Rights Reserved
|
|
*/
|
|
|
|
#ifndef _MACH_STM32_H_
|
|
#define _MACH_STM32_H_
|
|
|
|
#ifndef __ASSEMBLY__
|
|
#include <linux/bitops.h>
|
|
#endif
|
|
|
|
/*
|
|
* Peripheral memory map
|
|
* only address used before device tree parsing
|
|
*/
|
|
#define STM32_RCC_BASE 0x50000000
|
|
#define STM32_PWR_BASE 0x50001000
|
|
#define STM32_SYSCFG_BASE 0x50020000
|
|
#ifdef CONFIG_STM32MP15x
|
|
#define STM32_DBGMCU_BASE 0x50081000
|
|
#endif
|
|
#define STM32_FMC2_BASE 0x58002000
|
|
#define STM32_IWDG2_BASE 0x5A002000
|
|
#define STM32_DDRCTRL_BASE 0x5A003000
|
|
#define STM32_DDRPHYC_BASE 0x5A004000
|
|
#define STM32_IWDG1_BASE 0x5C003000
|
|
#define STM32_TZC_BASE 0x5C006000
|
|
#define STM32_ETZPC_BASE 0x5C007000
|
|
#define STM32_STGEN_BASE 0x5C008000
|
|
#define STM32_TAMP_BASE 0x5C00A000
|
|
|
|
#ifdef CONFIG_STM32MP15x
|
|
#define STM32_USART1_BASE 0x5C000000
|
|
#define STM32_USART2_BASE 0x4000E000
|
|
#endif
|
|
#ifdef CONFIG_STM32MP13x
|
|
#define STM32_USART1_BASE 0x4c000000
|
|
#define STM32_USART2_BASE 0x4c001000
|
|
#endif
|
|
#define STM32_USART3_BASE 0x4000F000
|
|
#define STM32_UART4_BASE 0x40010000
|
|
#define STM32_UART5_BASE 0x40011000
|
|
#define STM32_USART6_BASE 0x44003000
|
|
#define STM32_UART7_BASE 0x40018000
|
|
#define STM32_UART8_BASE 0x40019000
|
|
|
|
#define STM32_SDMMC1_BASE 0x58005000
|
|
#define STM32_SDMMC2_BASE 0x58007000
|
|
#define STM32_SDMMC3_BASE 0x48004000
|
|
|
|
#ifdef CONFIG_STM32MP15x
|
|
#define STM32_SYSRAM_BASE 0x2FFC0000
|
|
#define STM32_SYSRAM_SIZE SZ_256K
|
|
#endif
|
|
|
|
#define STM32_DDR_BASE 0xC0000000
|
|
#define STM32_DDR_SIZE SZ_1G
|
|
|
|
#ifndef __ASSEMBLY__
|
|
/* enumerated used to identify the SYSCON driver instance */
|
|
enum {
|
|
STM32MP_SYSCON_UNKNOWN,
|
|
STM32MP_SYSCON_SYSCFG,
|
|
};
|
|
|
|
/*
|
|
* enumerated for boot interface from Bootrom, used in TAMP_BOOT_CONTEXT
|
|
* - boot device = bit 8:4
|
|
* - boot instance = bit 3:0
|
|
*/
|
|
#define BOOT_TYPE_MASK 0xF0
|
|
#define BOOT_TYPE_SHIFT 4
|
|
#define BOOT_INSTANCE_MASK 0x0F
|
|
#define BOOT_INSTANCE_SHIFT 0
|
|
|
|
enum boot_device {
|
|
BOOT_FLASH_SD = 0x10,
|
|
BOOT_FLASH_SD_1 = 0x11,
|
|
BOOT_FLASH_SD_2 = 0x12,
|
|
BOOT_FLASH_SD_3 = 0x13,
|
|
|
|
BOOT_FLASH_EMMC = 0x20,
|
|
BOOT_FLASH_EMMC_1 = 0x21,
|
|
BOOT_FLASH_EMMC_2 = 0x22,
|
|
BOOT_FLASH_EMMC_3 = 0x23,
|
|
|
|
BOOT_FLASH_NAND = 0x30,
|
|
BOOT_FLASH_NAND_FMC = 0x31,
|
|
|
|
BOOT_FLASH_NOR = 0x40,
|
|
BOOT_FLASH_NOR_QSPI = 0x41,
|
|
|
|
BOOT_SERIAL_UART = 0x50,
|
|
BOOT_SERIAL_UART_1 = 0x51,
|
|
BOOT_SERIAL_UART_2 = 0x52,
|
|
BOOT_SERIAL_UART_3 = 0x53,
|
|
BOOT_SERIAL_UART_4 = 0x54,
|
|
BOOT_SERIAL_UART_5 = 0x55,
|
|
BOOT_SERIAL_UART_6 = 0x56,
|
|
BOOT_SERIAL_UART_7 = 0x57,
|
|
BOOT_SERIAL_UART_8 = 0x58,
|
|
|
|
BOOT_SERIAL_USB = 0x60,
|
|
BOOT_SERIAL_USB_OTG = 0x62,
|
|
|
|
BOOT_FLASH_SPINAND = 0x70,
|
|
BOOT_FLASH_SPINAND_1 = 0x71,
|
|
};
|
|
|
|
/* TAMP registers */
|
|
#define TAMP_BACKUP_REGISTER(x) (STM32_TAMP_BASE + 0x100 + 4 * x)
|
|
|
|
#ifdef CONFIG_STM32MP15x
|
|
#define TAMP_BACKUP_MAGIC_NUMBER TAMP_BACKUP_REGISTER(4)
|
|
#define TAMP_BACKUP_BRANCH_ADDRESS TAMP_BACKUP_REGISTER(5)
|
|
#define TAMP_FWU_BOOT_INFO_REG TAMP_BACKUP_REGISTER(10)
|
|
#define TAMP_COPRO_RSC_TBL_ADDRESS TAMP_BACKUP_REGISTER(17)
|
|
#define TAMP_COPRO_STATE TAMP_BACKUP_REGISTER(18)
|
|
#define TAMP_BOOT_CONTEXT TAMP_BACKUP_REGISTER(20)
|
|
#define TAMP_BOOTCOUNT TAMP_BACKUP_REGISTER(21)
|
|
|
|
#define TAMP_FWU_BOOT_IDX_MASK GENMASK(3, 0)
|
|
|
|
#define TAMP_FWU_BOOT_IDX_OFFSET 0
|
|
|
|
#define TAMP_COPRO_STATE_OFF 0
|
|
#define TAMP_COPRO_STATE_INIT 1
|
|
#define TAMP_COPRO_STATE_CRUN 2
|
|
#define TAMP_COPRO_STATE_CSTOP 3
|
|
#define TAMP_COPRO_STATE_STANDBY 4
|
|
#define TAMP_COPRO_STATE_CRASH 5
|
|
#endif
|
|
|
|
#ifdef CONFIG_STM32MP13x
|
|
#define TAMP_BOOTCOUNT TAMP_BACKUP_REGISTER(31)
|
|
#define TAMP_BOOT_CONTEXT TAMP_BACKUP_REGISTER(30)
|
|
#endif
|
|
|
|
#define TAMP_BOOT_MODE_MASK GENMASK(15, 8)
|
|
#define TAMP_BOOT_MODE_SHIFT 8
|
|
#define TAMP_BOOT_DEVICE_MASK GENMASK(7, 4)
|
|
#define TAMP_BOOT_INSTANCE_MASK GENMASK(3, 0)
|
|
#define TAMP_BOOT_FORCED_MASK GENMASK(7, 0)
|
|
|
|
enum forced_boot_mode {
|
|
BOOT_NORMAL = 0x00,
|
|
BOOT_FASTBOOT = 0x01,
|
|
BOOT_RECOVERY = 0x02,
|
|
BOOT_STM32PROG = 0x03,
|
|
BOOT_UMS_MMC0 = 0x10,
|
|
BOOT_UMS_MMC1 = 0x11,
|
|
BOOT_UMS_MMC2 = 0x12,
|
|
};
|
|
|
|
/* offset used for BSEC driver: misc_read and misc_write */
|
|
#define STM32_BSEC_SHADOW_OFFSET 0x0
|
|
#define STM32_BSEC_SHADOW(id) (STM32_BSEC_SHADOW_OFFSET + (id) * 4)
|
|
#define STM32_BSEC_OTP_OFFSET 0x80000000
|
|
#define STM32_BSEC_OTP(id) (STM32_BSEC_OTP_OFFSET + (id) * 4)
|
|
#define STM32_BSEC_LOCK_OFFSET 0xC0000000
|
|
#define STM32_BSEC_LOCK(id) (STM32_BSEC_LOCK_OFFSET + (id) * 4)
|
|
|
|
/* BSEC OTP index */
|
|
#ifdef CONFIG_STM32MP15x
|
|
#define BSEC_OTP_RPN 1
|
|
#define BSEC_OTP_SERIAL 13
|
|
#define BSEC_OTP_PKG 16
|
|
#define BSEC_OTP_MAC 57
|
|
#define BSEC_OTP_BOARD 59
|
|
#endif
|
|
#ifdef CONFIG_STM32MP13x
|
|
#define BSEC_OTP_RPN 1
|
|
#define BSEC_OTP_SERIAL 13
|
|
#define BSEC_OTP_MAC 57
|
|
#define BSEC_OTP_BOARD 60
|
|
#endif
|
|
|
|
#endif /* __ASSEMBLY__ */
|
|
#endif /* _MACH_STM32_H_ */
|