diff --git a/dts/arm/st/f0/stm32f072.dtsi b/dts/arm/st/f0/stm32f072.dtsi index 1c7ad8b1b6762d..24c829eac5fa0f 100644 --- a/dts/arm/st/f0/stm32f072.dtsi +++ b/dts/arm/st/f0/stm32f072.dtsi @@ -10,6 +10,12 @@ soc { compatible = "st,stm32f072", "st,stm32f0", "simple-bus"; + rom_bootloader: rom_bootloader@0x1FFFC800 { + compatible = "st,stm32-bootloader"; + reg = <0x1FFFC800 DT_SIZE_K(12)>; + status = "reserved"; + }; + can1: can@40006400 { compatible = "st,stm32-bxcan"; reg = <0x40006400 0x400>; diff --git a/dts/arm/st/f4/stm32f401.dtsi b/dts/arm/st/f4/stm32f401.dtsi index be3eb9fc1a9abf..b2b1ad4513217a 100644 --- a/dts/arm/st/f4/stm32f401.dtsi +++ b/dts/arm/st/f4/stm32f401.dtsi @@ -18,6 +18,12 @@ soc { compatible = "st,stm32f401", "st,stm32f4", "simple-bus"; + rom_bootloader: rom_bootloader@0x1FFF0000 { + compatible = "st,stm32-bootloader"; + reg = <0x1FFF0000 DT_SIZE_K(29)>; + status = "reserved"; + }; + spi2: spi@40003800 { compatible = "st,stm32-spi"; #address-cells = <1>; diff --git a/dts/arm/st/f4/stm32f411.dtsi b/dts/arm/st/f4/stm32f411.dtsi index 0826bf2cbaad26..397568cf3d0fc4 100644 --- a/dts/arm/st/f4/stm32f411.dtsi +++ b/dts/arm/st/f4/stm32f411.dtsi @@ -10,6 +10,13 @@ soc { compatible = "st,stm32f411", "st,stm32f4", "simple-bus"; + + rom_bootloader: rom_bootloader@0x1FFF0000 { + compatible = "st,stm32-bootloader"; + reg = <0x1FFF0000 DT_SIZE_K(29)>; + status = "reserved"; + }; + spi5: spi@40015000 { compatible = "st,stm32-spi"; #address-cells = <1>; diff --git a/soc/arm/st_stm32/common/CMakeLists.txt b/soc/arm/st_stm32/common/CMakeLists.txt index 70dd8c865c9789..592d508bd52835 100644 --- a/soc/arm/st_stm32/common/CMakeLists.txt +++ b/soc/arm/st_stm32/common/CMakeLists.txt @@ -5,6 +5,7 @@ zephyr_sources(stm32cube_hal.c) zephyr_linker_sources_ifdef(CONFIG_STM32_CCM SECTIONS ccm.ld) zephyr_sources_ifdef(CONFIG_STM32_BACKUP_SRAM stm32_backup_sram.c) +zephyr_sources_ifdef(CONFIG_STM32_BOOTLOADER stm32_bootloader.c) zephyr_linker_sources_ifdef(CONFIG_STM32_BACKUP_SRAM SECTIONS stm32_backup_sram.ld) zephyr_sources(soc_config.c) diff --git a/soc/arm/st_stm32/common/Kconfig.soc b/soc/arm/st_stm32/common/Kconfig.soc index 07b2122cefd969..97d962e7f48d2e 100644 --- a/soc/arm/st_stm32/common/Kconfig.soc +++ b/soc/arm/st_stm32/common/Kconfig.soc @@ -15,6 +15,17 @@ config STM32_BACKUP_SRAM help Enable support for STM32 backup SRAM. + +config HAS_STM32_BOOTLOADER + def_bool $(dt_compat_enabled,$(DT_COMPAT_ST_STM32_BOOTLOADER)) + +config STM32_BOOTLOADER + bool "STM32 Bootloader Support" + default HAS_STM32_BOOTLOADER + depends on RETENTION_BOOT_MODE + help + Enable support for jumping into the STM32 when the bootmode is set. + config USE_STM32_ASSERT depends on ASSERT bool "STM32Cube HAL and LL drivers asserts" diff --git a/soc/arm/st_stm32/common/stm32_bootloader.c b/soc/arm/st_stm32/common/stm32_bootloader.c new file mode 100644 index 00000000000000..bcc5db558bf2b4 --- /dev/null +++ b/soc/arm/st_stm32/common/stm32_bootloader.c @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2020 Google LLC. + * + * SPDX-License-Identifier: Apache-2.0 + */ + +#include +#include +#include +#include +#include + +static const uint32_t bootloader = DT_REG_ADDR(DT_INST(0, st_stm32_bootloader)); +static FUNC_NORETURN void jump_to_bootloader(void) +{ + uint32_t i = 0; + void (*jmp)(void); + + __disable_irq(); + + SysTick->CTRL = 0; + SysTick->LOAD = 0; + SysTick->VAL = 0; + + for (i = 0; i < sizeof(NVIC->ICER) / sizeof(NVIC->ICER[0]); i++) + { + NVIC->ICER[i] = 0xFFFFFFFF; + NVIC->ICPR[i] = 0xFFFFFFFF; + } + + LL_SYSCFG_SetRemapMemory(LL_SYSCFG_REMAP_SYSTEMFLASH); + + jmp = (void (*)(void)) (void (*)(void)) (*((uint32_t *) ((bootloader + 4)))); + + __set_CONTROL(0); + __set_MSP(*(uint32_t *)bootloader); + + __enable_irq(); + + jmp(); + + while (1) { } +} + +static int bootloader_check_boot_init(void) +{ + if (bootmode_check(BOOT_MODE_TYPE_BOOTLOADER) > 0) { + bootmode_clear(); + jump_to_bootloader(); + } + + return 0; +} + +SYS_INIT(bootloader_check_boot_init, EARLY, 0);