2015-04-22 12:56:28 +02:00
|
|
|
# This CPU implementation is using the new core/CPU interface:
|
|
|
|
export CFLAGS += -DCOREIF_NG=1
|
|
|
|
|
|
|
|
# Tell the build system that the CPU depends on the Cortex-M common files:
|
2015-05-18 18:47:17 +02:00
|
|
|
export USEMODULE += cortexm_common
|
|
|
|
# Export the peripheral drivers to be linked into the final binary:
|
|
|
|
export USEMODULE += periph
|
2015-04-22 12:56:28 +02:00
|
|
|
# all cortex MCU's use newlib as libc
|
|
|
|
export USEMODULE += newlib
|
|
|
|
|
2015-06-11 20:41:21 +02:00
|
|
|
# set default for CPU_MODEL
|
|
|
|
export CPU_MODEL ?= $(CPU)
|
|
|
|
|
2015-05-18 18:47:17 +02:00
|
|
|
# export the CPU model and architecture
|
2015-04-22 12:56:28 +02:00
|
|
|
MODEL = $(shell echo $(CPU_MODEL) | tr 'a-z' 'A-Z')
|
|
|
|
export CFLAGS += -DCPU_MODEL_$(MODEL)
|
2015-05-18 18:47:17 +02:00
|
|
|
ARCH = $(shell echo $(CPU_ARCH) | tr 'a-z-' 'A-Z_')
|
|
|
|
export CFLAGS += -DCPU_ARCH_$(ARCH)
|
|
|
|
|
|
|
|
# set the compiler specific CPU and FPU options
|
|
|
|
ifeq ($(CPU_ARCH),cortex-m4f)
|
2015-05-29 13:56:41 +02:00
|
|
|
# TODO: enable hard floating points for the M4F once the context save/restore
|
|
|
|
# code is adjusted to take care of FPU registers
|
|
|
|
#export CFLAGS_FPU += -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
2015-05-18 18:47:17 +02:00
|
|
|
export MCPU := cortex-m4
|
|
|
|
endif
|
2015-05-29 13:56:41 +02:00
|
|
|
CFLAGS_FPU ?= -mfloat-abi=soft
|
|
|
|
export MCPU ?= $(CPU_ARCH)
|
2015-04-22 12:56:28 +02:00
|
|
|
|
2015-05-30 10:02:46 +02:00
|
|
|
# CMSIS DSP needs to know about the CPU core
|
|
|
|
ifneq (,$(filter cmsis-dsp,$(USEPKG)))
|
|
|
|
# definition needed to use cmsis-dsp headers
|
|
|
|
ifeq ($(CPU_ARCH),cortex-m0)
|
|
|
|
export CFLAGS += -DARM_MATH_CM0
|
|
|
|
else ifeq ($(CPU_ARCH),cortex-m0plus)
|
|
|
|
export CFLAGS += -DARM_MATH_CM0PLUS
|
|
|
|
else ifeq ($(CPU_ARCH),cortex-m3)
|
|
|
|
export CFLAGS += -DARM_MATH_CM3
|
|
|
|
else ifeq ($(CPU_ARCH),cortex-m4)
|
|
|
|
export CFLAGS += -DARM_MATH_CM4
|
|
|
|
else ifeq ($(CPU_ARCH),cortex-m4f)
|
|
|
|
export CFLAGS += -DARM_MATH_CM4
|
|
|
|
else ifeq ($(CPU_ARCH),cortex-m7)
|
|
|
|
export CFLAGS += -DARM_MATH_CM7
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2015-04-22 12:56:28 +02:00
|
|
|
# Include CPU specific includes:
|
|
|
|
export INCLUDES += -I$(RIOTCPU)/$(CPU)/include
|
|
|
|
|
|
|
|
# Explicitly tell the linker to link the startup code.
|
|
|
|
# Without this the interrupt vectors will not be linked correctly!
|
2015-05-27 18:13:02 +02:00
|
|
|
ifeq ($(COMMON_STARTUP),)
|
2015-06-03 12:44:44 +02:00
|
|
|
export UNDEF += $(BINDIR)cpu/vectors.o
|
2015-05-27 18:13:02 +02:00
|
|
|
endif
|
2015-04-22 12:56:28 +02:00
|
|
|
|
|
|
|
# CPU depends on the cortex-m common module, so include it:
|
2015-05-18 18:47:17 +02:00
|
|
|
include $(RIOTCPU)/cortexm_common/Makefile.include
|
2015-04-22 12:56:28 +02:00
|
|
|
|
|
|
|
# Avoid overriding the default rule:
|
|
|
|
all:
|
|
|
|
|
|
|
|
# Rule to generate assembly listings from ELF files:
|
|
|
|
%.lst: %.elf
|
|
|
|
$(OBJDUMP) $(OBJDUMPFLAGS) $< > $@
|