mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
ee832148b3
Initialize STM32 RDP in a glitch-resistant fashion to prevent debugger use when restrictions are set by the designer.
71 lines
1.8 KiB
Plaintext
71 lines
1.8 KiB
Plaintext
# Copyright (c) 2020 Inria
|
|
#
|
|
# This file is subject to the terms and conditions of the GNU Lesser
|
|
# General Public License v2.1. See the file LICENSE in the top level
|
|
# directory for more details.
|
|
#
|
|
|
|
config CPU_STM32
|
|
bool
|
|
select HAS_CPU_STM32
|
|
select HAS_PERIPH_CPUID
|
|
select HAS_PERIPH_GPIO
|
|
select HAS_PERIPH_GPIO_IRQ
|
|
select HAS_PERIPH_TIMER_PERIODIC
|
|
select HAS_PERIPH_RTT_OVERFLOW
|
|
select HAS_PERIPH_UART_MODECFG
|
|
select HAS_PERIPH_UART_NONBLOCKING
|
|
|
|
# This CPU requires periph_rtc when periph_rtc_mem
|
|
select MODULE_PERIPH_RTC if MODULE_PERIPH_RTC_MEM && HAS_PERIPH_RTC
|
|
|
|
# Common CPU symbol
|
|
config CPU
|
|
default "stm32" if CPU_STM32
|
|
|
|
# Definition of specific features
|
|
config HAS_CPU_STM32
|
|
bool
|
|
help
|
|
Indicates that a 'stm32' cpu is being used.
|
|
|
|
config HAS_BOOTLOADER_STM32
|
|
bool
|
|
help
|
|
Indicates that the stm32 bootloader is being used.
|
|
|
|
orsource "kconfigs/Kconfig.clk"
|
|
orsource "kconfigs/*/Kconfig"
|
|
orsource "kconfigs/*/Kconfig.lines"
|
|
orsource "kconfigs/*/Kconfig.models"
|
|
|
|
choice
|
|
prompt "ReaDout Protection level"
|
|
default RDP0
|
|
help
|
|
Set minimum running RDP level.
|
|
RDP0 is full debug permissions, RDP1 disables read from Flash but
|
|
otherwise leaves debug enabled, RDP2 disables JTAG completely. If
|
|
there is a mismatch between desired RDP level here and RDP level
|
|
set on the chip, early cpu init will hang. This ensures production
|
|
devices with the wrong RDP level, by fault or malace intent, will
|
|
not run. See cpu manual for further details on RDP.
|
|
depends on (CPU_FAM_F1 || CPU_FAM_F2 || CPU_FAM_F3 || CPU_FAM_F4 || CPU_FAM_F5 || CPU_FAM_F6 || CPU_FAM_F7)
|
|
config RDP0
|
|
bool "RDP0"
|
|
config RDP1
|
|
bool "RDP1"
|
|
config RDP2
|
|
bool "RDP2"
|
|
endchoice
|
|
|
|
if TEST_KCONFIG
|
|
|
|
rsource "periph/Kconfig"
|
|
rsource "stmclk/Kconfig"
|
|
rsource "vectors/Kconfig"
|
|
|
|
endif # TEST_KCONFIG
|
|
|
|
source "$(RIOTCPU)/cortexm_common/Kconfig"
|