2016-01-15 18:21:29 +01:00
|
|
|
# Target triple for the build. Use arm-none-eabi if you are unsure.
|
2016-03-17 21:55:17 +01:00
|
|
|
export TARGET_ARCH ?= arm-none-eabi
|
2016-01-15 18:21:29 +01:00
|
|
|
|
|
|
|
# define build specific options
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS_CPU = -mcpu=$(MCPU) -mlittle-endian -mthumb $(CFLAGS_FPU)
|
2018-05-11 23:07:25 +02:00
|
|
|
|
2016-01-15 18:21:29 +01:00
|
|
|
ifneq (llvm,$(TOOLCHAIN))
|
|
|
|
# Clang (observed with v3.7) does not understand -mno-thumb-interwork, only add if
|
|
|
|
# not building with LLVM
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -mno-thumb-interwork
|
2018-05-11 23:07:25 +02:00
|
|
|
|
|
|
|
# work around https://gcc.gnu.org/bugzilla/show_bug.cgi?id=85606
|
|
|
|
ifneq (,$(filter cortex-m0%,$(CPU_ARCH)))
|
|
|
|
CFLAGS_CPU += -march=armv6s-m
|
2016-01-15 18:21:29 +01:00
|
|
|
endif
|
2018-05-11 23:07:25 +02:00
|
|
|
endif
|
|
|
|
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS_LINK = -ffunction-sections -fdata-sections -fno-builtin -fshort-enums
|
|
|
|
CFLAGS_DBG ?= -ggdb -g3
|
|
|
|
CFLAGS_OPT ?= -Os
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += $(CFLAGS_CPU) $(CFLAGS_LINK) $(CFLAGS_DBG) $(CFLAGS_OPT)
|
2016-01-15 18:21:29 +01:00
|
|
|
|
2019-08-27 16:06:41 +02:00
|
|
|
ASFLAGS += $(CFLAGS_CPU) $(CFLAGS_DBG)
|
2016-01-15 18:21:29 +01:00
|
|
|
export LINKFLAGS += -L$(RIOTCPU)/$(CPU)/ldscripts -L$(RIOTCPU)/cortexm_common/ldscripts
|
2016-10-03 23:19:00 +02:00
|
|
|
export LINKER_SCRIPT ?= $(CPU_MODEL).ld
|
2016-09-29 22:49:32 +02:00
|
|
|
export LINKFLAGS += -T$(LINKER_SCRIPT) -Wl,--fatal-warnings
|
|
|
|
|
2016-02-08 13:31:50 +01:00
|
|
|
export LINKFLAGS += $(CFLAGS_CPU) $(CFLAGS_DBG) $(CFLAGS_OPT) -static -lgcc -nostartfiles
|
2016-01-15 18:21:29 +01:00
|
|
|
export LINKFLAGS += -Wl,--gc-sections
|
|
|
|
|
2015-04-22 12:56:28 +02:00
|
|
|
# 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
|
2017-01-09 19:19:23 +01:00
|
|
|
# include common periph code
|
2017-11-06 10:35:30 +01:00
|
|
|
export USEMODULE += cortexm_common_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)
|
|
|
|
|
2018-11-15 17:04:17 +01:00
|
|
|
|
|
|
|
# extract version inside the first parentheses
|
|
|
|
ARM_GCC_VERSION = $(shell $(TARGET_ARCH)-gcc --version | sed -n '1 s/[^(]*(\([^\)]*\)).*/\1/p')
|
|
|
|
|
|
|
|
# Ubuntu bionic gcc-arm-none-eabi compiler is not supported
|
|
|
|
# Both when using gnu and llvm toolchains
|
|
|
|
#
|
|
|
|
# /usr/bin/arm-none-eabi-gcc --version | head -n 1
|
|
|
|
# arm-none-eabi-gcc (15:6.3.1+svn253039-1build1) 6.3.1 20170620
|
|
|
|
#
|
|
|
|
ARM_GCC_UNSUPPORTED += 15:6.3.1% # ubuntu bionic, ignore 'svn' build part
|
|
|
|
|
|
|
|
# Should not raise an error on the host system version when building in docker
|
|
|
|
ifneq (1,$(BUILD_IN_DOCKER))
|
|
|
|
ifneq (,$(filter $(ARM_GCC_UNSUPPORTED),$(ARM_GCC_VERSION)))
|
|
|
|
$(warning $(TARGET_ARCH)-gcc version not supported)
|
|
|
|
$(warning $(shell $(TARGET_ARCH)-gcc --version | head -n 1))
|
|
|
|
$(warning The currently recommanded version is the one installed in the riotdocker image)
|
|
|
|
$(warning https://github.com/RIOT-OS/riotdocker/blob/master/Dockerfile)
|
|
|
|
ifeq (1,$(WERROR))
|
|
|
|
$(error This check can be ignored by building with 'WERROR=0')
|
|
|
|
endif # WERROR
|
|
|
|
endif # ARM_GCC_UNSUPPORTED
|
|
|
|
endif # BUILD_IN_DOCKER
|
|
|
|
|
|
|
|
|
2015-09-16 21:41:58 +02:00
|
|
|
# Temporary LLVM/Clang Workaround:
|
|
|
|
# report cortex-m0 instead of cortex-m0plus if llvm/clang (<= 3.6.2) is used
|
|
|
|
# llvm/clang version 3.6.2 still does not support the cortex-m0plus mcpu type
|
|
|
|
ifeq (llvm,$(TOOLCHAIN))
|
|
|
|
ifeq (cortex-m0plus,$(CPU_ARCH))
|
|
|
|
LLVM_UNSUP = $(shell clang -target arm-none-eabi -mcpu=$(CPU_ARCH) -c -x c /dev/null -o /dev/null \
|
|
|
|
> /dev/null 2>&1 || echo 1 )
|
|
|
|
ifeq (1,$(LLVM_UNSUP))
|
|
|
|
CPU_ARCH = cortex-m0
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2015-04-22 12:56:28 +02:00
|
|
|
MODEL = $(shell echo $(CPU_MODEL) | tr 'a-z' 'A-Z')
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DCPU_MODEL_$(MODEL)
|
2015-05-18 18:47:17 +02:00
|
|
|
ARCH = $(shell echo $(CPU_ARCH) | tr 'a-z-' 'A-Z_')
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DCPU_ARCH_$(ARCH)
|
2015-05-18 18:47:17 +02:00
|
|
|
|
|
|
|
# set the compiler specific CPU and FPU options
|
2017-02-20 18:21:13 +01:00
|
|
|
ifneq (,$(filter $(CPU_ARCH),cortex-m4f cortex-m7))
|
|
|
|
ifneq (,$(filter cortexm_fpu,$(DISABLE_MODULE)))
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS_FPU ?= -mfloat-abi=soft
|
2017-02-20 18:21:13 +01:00
|
|
|
else
|
|
|
|
USEMODULE += cortexm_fpu
|
|
|
|
# clang assumes there is an FPU
|
|
|
|
ifneq (llvm,$(TOOLCHAIN))
|
|
|
|
ifeq ($(CPU_ARCH),cortex-m7)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS_FPU ?= -mfloat-abi=hard -mfpu=fpv5-d16
|
2017-02-20 18:21:13 +01:00
|
|
|
else
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS_FPU ?= -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
2017-02-20 18:21:13 +01:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
ifeq ($(CPU_ARCH),cortex-m4f)
|
|
|
|
export MCPU := cortex-m4
|
|
|
|
else
|
|
|
|
export MCPU ?= $(CPU_ARCH)
|
|
|
|
endif
|
|
|
|
else
|
2015-05-29 13:56:41 +02:00
|
|
|
CFLAGS_FPU ?= -mfloat-abi=soft
|
|
|
|
export MCPU ?= $(CPU_ARCH)
|
2017-02-20 18:21:13 +01:00
|
|
|
endif
|
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)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM0
|
2015-05-30 10:02:46 +02:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m0plus)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM0PLUS
|
2015-05-30 10:02:46 +02:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m3)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM3
|
2015-05-30 10:02:46 +02:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m4)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM4
|
2015-05-30 10:02:46 +02:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m4f)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM4
|
2015-05-30 10:02:46 +02:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m7)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM7
|
2019-01-21 17:04:20 +01:00
|
|
|
else ifeq ($(CPU_ARCH),cortex-m23)
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DARM_MATH_CM23
|
2015-05-30 10:02:46 +02:00
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
2015-04-22 12:56:28 +02:00
|
|
|
# Explicitly tell the linker to link the startup code.
|
|
|
|
# Without this the interrupt vectors will not be linked correctly!
|
2018-01-29 15:15:18 +01:00
|
|
|
VECTORS_O ?= $(BINDIR)/cpu/vectors.o
|
2015-05-27 18:13:02 +02:00
|
|
|
ifeq ($(COMMON_STARTUP),)
|
2018-01-29 15:15:18 +01:00
|
|
|
export UNDEF += $(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
|
|
|
|
2016-01-15 18:21:29 +01:00
|
|
|
# use the nano-specs of Newlib when available
|
2016-03-21 07:36:02 +01:00
|
|
|
USEMODULE += newlib_nano
|
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) $< > $@
|