2017-11-29 19:50:50 +01:00
|
|
|
include $(RIOTCPU)/efm32/efm32-info.mk
|
|
|
|
|
2020-02-11 22:31:00 +01:00
|
|
|
# HACK: here we would want to look into USEMODULE to include Makefile.include
|
|
|
|
# but since Makefile.dep is still resolved after Makefile.include we can't do
|
|
|
|
# something like `$(filter cpu_efm32%,$(USEMODULE))`. This is why we use
|
|
|
|
# `cpu_$(CPU_FAM)` for something that is MODULE related.
|
|
|
|
include $(RIOTCPU)/efm32/families/$(CPU_FAM)/Makefile.include
|
|
|
|
|
2022-10-13 22:33:36 +02:00
|
|
|
# Export vars for Gecko SDK librail Makefile
|
|
|
|
export EFM32_LIBRAIL_BLOB_NAME
|
|
|
|
|
2022-10-17 00:46:33 +02:00
|
|
|
INCLUDES += -I$(RIOTCPU)/efm32/include/vendor
|
|
|
|
|
2020-02-11 22:31:00 +01:00
|
|
|
ifeq (,$(EFM32_HEADER))
|
|
|
|
$(error Header file for $(CPU_MODEL) is missing)
|
|
|
|
endif
|
|
|
|
|
2019-07-22 00:06:58 +02:00
|
|
|
# the size of riotboot on the EFM32 exceeds the default value
|
2022-10-19 01:49:21 +02:00
|
|
|
ifneq (,$(filter periph_usbdev,$(USEMODULE)))
|
|
|
|
RIOTBOOT_LEN ?= 0x4000
|
|
|
|
else
|
|
|
|
RIOTBOOT_LEN ?= 0x2000
|
|
|
|
endif
|
2019-07-22 00:06:58 +02:00
|
|
|
|
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
|
|
|
|
2022-10-19 01:47:35 +02:00
|
|
|
# to be able to use the family as define
|
|
|
|
CFLAGS += -DCPU_FAM_$(call uppercase_and_underscore,$(CPU_FAM))
|
|
|
|
|
2020-01-08 00:44:48 +01:00
|
|
|
# include EFM32 specific driver headers
|
|
|
|
INCLUDES += -I$(RIOTCPU)/efm32/include/drivers
|
|
|
|
|
2022-05-06 12:23:09 +02:00
|
|
|
# arm_math.h is required by vendor headers and is located in CMSIS DSP includes
|
|
|
|
INCLUDES += -I$(PKGDIRBASE)/cmsis/CMSIS/DSP/Include
|
|
|
|
|
2017-11-29 19:50:50 +01:00
|
|
|
# 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
|