include $(RIOTCPU)/stm32/stm32_info.mk FEATURES_PROVIDED += bootloader_stm32 FEATURES_PROVIDED += cpu_stm32$(CPU_FAM) FEATURES_PROVIDED += periph_cpuid FEATURES_PROVIDED += periph_gpio periph_gpio_irq FEATURES_PROVIDED += puf_sram FEATURES_PROVIDED += periph_timer_periodic FEATURES_PROVIDED += periph_uart_modecfg FEATURES_PROVIDED += periph_uart_nonblocking FEATURES_PROVIDED += periph_wdt ifneq (,$(filter $(CPU_FAM),f0 f1 f3 g0 g4 l0 l1 l4 wb)) FEATURES_PROVIDED += periph_flashpage FEATURES_PROVIDED += periph_flashpage_raw endif ifneq (,$(filter $(CPU_FAM),l0 l1)) FEATURES_PROVIDED += periph_eeprom endif ifeq (f1,$(CPU_FAM)) FEATURES_CONFLICT += periph_rtc:periph_rtt FEATURES_CONFLICT_MSG += "On the STM32F1, the RTC and RTT map to the same hardware peripheral." endif # Not all F4 and L0 parts implement a RNG. CPU_MODELS_WITHOUT_HWRNG = stm32f401% stm32f411% stm32f446% stm32l031% ifneq (,$(filter $(CPU_FAM),f2 f4 f7 g4 l0 l4 wb)) ifeq (,$(filter $(CPU_MODELS_WITHOUT_HWRNG),$(CPU_MODEL))) FEATURES_PROVIDED += periph_hwrng endif endif ifneq (,$(filter $(CPU_FAM),f2 f4 f7 g0 g4 l1 l4)) FEATURES_PROVIDED += cortexm_mpu endif # only some stm32f3 and stm32l0 have an MPU STM32_WITH_MPU += stm32f303re stm32f303vc stm32f303ze stm32l052t8 ifneq (,$(filter $(CPU_MODEL),$(STM32_WITH_MPU))) FEATURES_PROVIDED += cortexm_mpu endif include $(RIOTCPU)/cortexm_common/Makefile.features