2014-10-13 15:29:49 +02:00
|
|
|
# Define the cpu used by the CC2538DK board:
|
|
|
|
export CPU = cc2538
|
|
|
|
|
|
|
|
export CPU_MODEL ?= cc2538nf53
|
|
|
|
|
|
|
|
# Define tools used for building the project:
|
|
|
|
export PREFIX ?= arm-none-eabi-
|
|
|
|
|
|
|
|
export CC = $(PREFIX)gcc
|
2014-11-18 19:10:29 +01:00
|
|
|
export CXX = $(PREFIX)g++
|
2014-10-13 15:29:49 +02:00
|
|
|
export AR = $(PREFIX)ar
|
|
|
|
export AS = $(PREFIX)as
|
|
|
|
export LINK = $(PREFIX)gcc
|
|
|
|
export SIZE = $(PREFIX)size
|
|
|
|
export OBJCOPY = $(PREFIX)objcopy
|
|
|
|
export OBJDUMP = $(PREFIX)objdump
|
|
|
|
|
|
|
|
export TERMPROG ?= $(RIOTBASE)/dist/tools/pyterm/pyterm
|
2014-10-30 19:44:05 +01:00
|
|
|
export DEBUGGER = $(RIOTBOARD)/$(BOARD)/dist/debug.sh
|
|
|
|
export DEBUGSERVER = JLinkGDBServer -device CC2538SF53
|
|
|
|
export RESET = $(RIOTBOARD)/$(BOARD)/dist/reset.sh
|
2014-10-13 15:29:49 +02:00
|
|
|
|
|
|
|
# Define the flash-tool and default port:
|
2014-10-30 19:44:05 +01:00
|
|
|
export PROGRAMMER ?= cc2538-bsl
|
|
|
|
|
|
|
|
ifeq ($(PROGRAMMER),cc2538-bsl)
|
|
|
|
export FLASHER = python $(RIOTBOARD)/$(BOARD)/dist/cc2538-bsl.py
|
|
|
|
export FFLAGS = -p "$(PORT)" -e -w -v $(HEXFILE)
|
|
|
|
else ifeq ($(PROGRAMMER),jlink)
|
|
|
|
export FLASHER = $(RIOTBOARD)/$(BOARD)/dist/flash.sh
|
|
|
|
export FFLAGS = $(BINDIR) $(HEXFILE)
|
|
|
|
endif
|
|
|
|
|
2014-10-13 15:29:49 +02:00
|
|
|
export PORT ?= /dev/ttyUSB1
|
|
|
|
|
|
|
|
# Define build specific options:
|
|
|
|
export CPU_USAGE = -mcpu=cortex-m3
|
|
|
|
|
|
|
|
export ASFLAGS += -ggdb -g3 $(CPU_USAGE) $(FPU_USAGE) -mlittle-endian
|
2015-01-22 13:36:22 +01:00
|
|
|
export CFLAGS += $(ASFLAGS) -std=gnu99 -mthumb -mno-thumb-interwork -nostartfiles -Os -Wall -Wstrict-prototypes -ffunction-sections -fdata-sections -fno-builtin
|
2014-10-13 15:29:49 +02:00
|
|
|
export LINKFLAGS += $(CFLAGS) -static -lgcc -T$(LINKERSCRIPT) -L$(RIOTCPU)/$(CPU)
|
|
|
|
export OFLAGS += -O binary --gap-fill 0xff
|
2014-10-30 19:44:05 +01:00
|
|
|
export HEXFILE = $(ELFFILE:.elf=.bin)
|
2014-10-13 15:29:49 +02:00
|
|
|
export TERMFLAGS += -p "$(PORT)"
|
2014-10-30 19:44:05 +01:00
|
|
|
export DEBUGGER_FLAGS = $(BINDIR) $(ELFFILE)
|
|
|
|
export RESET_FLAGS = $(BINDIR)
|
2014-10-13 15:29:49 +02:00
|
|
|
|
|
|
|
export OBJDUMPFLAGS += --disassemble --source --disassembler-options=force-thumb
|
|
|
|
|
2014-11-18 19:10:29 +01:00
|
|
|
# unwanted (CXXUWFLAGS) and extra (CXXEXFLAGS) flags for c++
|
|
|
|
export CXXUWFLAGS +=
|
|
|
|
export CXXEXFLAGS +=
|
|
|
|
|
2014-10-13 15:29:49 +02:00
|
|
|
# Use the nano-specs of the NewLib when available:
|
|
|
|
ifeq ($(shell $(LINK) -specs=nano.specs -E - 2>/dev/null >/dev/null </dev/null ; echo $$?),0)
|
|
|
|
export LINKFLAGS += -specs=nano.specs -lc -lnosys
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Export board specific includes to the global includes-listing:
|
|
|
|
export INCLUDES += -I$(RIOTBOARD)/$(BOARD)/include
|