2017-11-29 19:50:50 +01:00
|
|
|
include $(RIOTCPU)/efm32/efm32-info.mk
|
|
|
|
|
2019-10-08 09:05:11 +02:00
|
|
|
CPU_ARCH = $(EFM32_ARCHITECTURE)
|
2017-11-29 19:50:50 +01:00
|
|
|
export CPU_FAM = $(EFM32_FAMILY)
|
|
|
|
|
2019-07-22 00:06:58 +02:00
|
|
|
# the size of riotboot on the EFM32 exceeds the default value
|
|
|
|
RIOTBOOT_LEN ?= 0x2000
|
|
|
|
|
2017-11-29 19:50:50 +01:00
|
|
|
# the em_device.h header requires a global define with the cpu model
|
2019-08-29 17:41:49 +02:00
|
|
|
CFLAGS += -D$(call uppercase_and_underscore,$(CPU_MODEL))
|
2017-11-29 19:50:50 +01:00
|
|
|
|
|
|
|
# include Gecko SDK package
|
|
|
|
USEPKG += gecko_sdk
|
|
|
|
|
|
|
|
# CMSIS-DSP is needed for arm_math.h on Cortex-M0+ architectures
|
|
|
|
ifeq ($(CPU_ARCH),cortex-m0plus)
|
|
|
|
USEPKG += cmsis-dsp
|
|
|
|
endif
|
|
|
|
|
2018-01-29 15:21:31 +01:00
|
|
|
# include CPU family module
|
|
|
|
USEMODULE += cpu_$(EFM32_FAMILY)
|
|
|
|
|
|
|
|
# vectors.o is provided by 'cpu_$(EFM32_FAMILY)' and not by 'cpu'
|
|
|
|
VECTORS_O := $(BINDIR)/cpu_$(EFM32_FAMILY)/vectors.o
|
|
|
|
|
2017-11-29 19:50:50 +01:00
|
|
|
# include layered power management
|
|
|
|
USEMODULE += pm_layered
|
|
|
|
|
|
|
|
# include vendor device headers
|
|
|
|
INCLUDES += -I$(RIOTCPU)/efm32/families/$(EFM32_FAMILY)/include/vendor
|
|
|
|
|
|
|
|
# include cortexm_common
|
|
|
|
LINKER_SCRIPT = cortexm.ld
|
|
|
|
|
|
|
|
ROM_START_ADDR = $(EFM32_FLASH_START)
|
|
|
|
ROM_LEN = $(EFM32_FLASH_SIZE)
|
|
|
|
RAM_START_ADDR = $(EFM32_SRAM_START)
|
|
|
|
RAM_LEN = $(EFM32_SRAM_SIZE)
|
|
|
|
|
|
|
|
include $(RIOTMAKE)/arch/cortexm.inc.mk
|