nrf52dk: cpu/nrf52832 support
This commit is contained in:
parent
0671640ea2
commit
20f9515ed1
20 changed files with 1918 additions and 0 deletions
262
cpu/nrf52832/Makefile.nrf52832
Normal file
262
cpu/nrf52832/Makefile.nrf52832
Normal file
|
@ -0,0 +1,262 @@
|
|||
ifndef NRF52_SDK_ROOT
|
||||
$(error NRF52_SDK_ROOT not defined! You must specify where nRF52 SDK resides!)
|
||||
endif
|
||||
|
||||
ifneq ($(filter %.flash erase,$(MAKECMDGOALS)),)
|
||||
ifeq ($(NRF52_JLINK_PATH),)
|
||||
NRF52_JLINK_PATH=$(shell location=$$(which JLinkExe) && dirname $$location)
|
||||
endif
|
||||
ifeq ($(NRF52_JLINK_PATH),)
|
||||
$(error JLink not found in PATH and NRF52_JLINK_PATH path is not defined)
|
||||
endif
|
||||
endif
|
||||
|
||||
ifeq ($(CONTIKI_WITH_RIME),1)
|
||||
$(error Rime stack is not supported!)
|
||||
endif
|
||||
|
||||
ifneq ($(CONTIKI_WITH_IPV6),1)
|
||||
$(error Only IPv6 stack is supported!)
|
||||
endif
|
||||
|
||||
$(info SDK: $(NRF52_SDK_ROOT))
|
||||
|
||||
ifeq ($(NRF52_DK_REVISION),)
|
||||
NRF52_DK_REVISION=pca10040
|
||||
endif
|
||||
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
ifeq ($(NRF52_SOFTDEVICE),)
|
||||
NRF52_SOFTDEVICE := $(shell find $(NRF52_SDK_ROOT) -name *iot*_softdevice.hex | head -n 1)
|
||||
endif
|
||||
$(info SoftDevice: $(NRF52_SOFTDEVICE))
|
||||
LINKER_SCRIPT := $(CONTIKI_CPU)/ld/nrf52-$(NRF52_DK_REVISION)-sd.ld
|
||||
else
|
||||
LINKER_SCRIPT := $(CONTIKI_CPU)/ld/nrf52.ld
|
||||
endif
|
||||
|
||||
OUTPUT_FILENAME := $(CONTIKI_PROJECT)
|
||||
MAKEFILE_NAME := $(MAKEFILE_LIST)
|
||||
MAKEFILE_DIR := $(dir $(MAKEFILE_NAME) )
|
||||
|
||||
TEMPLATE_PATH = $(NRF52_SDK_ROOT)/components/toolchain/gcc
|
||||
|
||||
OBJECT_DIRECTORY = $(OBJECTDIR)
|
||||
LISTING_DIRECTORY := $(OBJECTDIR)
|
||||
OUTPUT_BINARY_DIRECTORY := bin_$(TARGET)
|
||||
|
||||
MK := mkdir
|
||||
RM := rm -rf
|
||||
|
||||
# Toolchain commands
|
||||
CC := arm-none-eabi-gcc
|
||||
AS := arm-none-eabi-as
|
||||
AR := arm-none-eabi-ar
|
||||
LD := arm-none-eabi-ld
|
||||
NM := arm-none-eabi-nm
|
||||
OBJDUMP := arm-none-eabi-objdump
|
||||
OBJCOPY := arm-none-eabi-objcopy
|
||||
SIZE := arm-none-eabi-size
|
||||
|
||||
# JLink
|
||||
JLINK := $(NRF52_JLINK_PATH)/JLinkExe
|
||||
JLINK_OPTS = -Device NRF52 -if swd -speed 1000
|
||||
ifneq ($(NRF52_JLINK_SN),)
|
||||
JLINK_OPTS += -SelectEmuBySN $(NRF52_JLINK_SN)
|
||||
endif
|
||||
|
||||
#function for removing duplicates in a list
|
||||
remduplicates = $(strip $(if $1,$(firstword $1) $(call remduplicates,$(filter-out $(firstword $1),$1))))
|
||||
|
||||
### CPU-dependent directories
|
||||
CONTIKI_CPU_DIRS += . dev ble #compat
|
||||
|
||||
### CPU-dependent source files
|
||||
CONTIKI_CPU_SOURCEFILES += clock.c rtimer-arch.c uart0.c putchar.c watchdog.c
|
||||
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
CONTIKI_CPU_SOURCEFILES += ble-core.c ble-mac.c
|
||||
endif
|
||||
|
||||
CONTIKI_SOURCEFILES += $(CONTIKI_CPU_SOURCEFILES)
|
||||
|
||||
#source common to all targets
|
||||
C_SOURCE_FILES += $(NRF52_SDK_ROOT)/components/drivers_nrf/common/nrf_drv_common.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/gpiote/nrf_drv_gpiote.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/rtc/nrf_drv_rtc.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/clock/nrf_drv_clock.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/timer/nrf_drv_timer.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/wdt/nrf_drv_wdt.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/rng/nrf_drv_rng.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/delay/nrf_delay.c \
|
||||
$(NRF52_SDK_ROOT)/components/drivers_nrf/uart/nrf_drv_uart.c \
|
||||
$(NRF52_SDK_ROOT)/components/libraries/util/app_error.c \
|
||||
$(NRF52_SDK_ROOT)/components/toolchain/system_nrf52.c
|
||||
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
C_SOURCE_FILES += $(NRF52_SDK_ROOT)/components/softdevice/common/softdevice_handler/softdevice_handler.c \
|
||||
$(NRF52_SDK_ROOT)/components/ble/common/ble_advdata.c
|
||||
else
|
||||
C_SOURCE_FILES += $(NRF52_SDK_ROOT)/components/libraries/fifo/app_fifo.c \
|
||||
$(NRF52_SDK_ROOT)/components/libraries/util/app_util_platform.c
|
||||
endif
|
||||
|
||||
#assembly files common to all targets
|
||||
ASM_SOURCE_FILES = $(NRF52_SDK_ROOT)/components/toolchain/gcc/gcc_startup_nrf52.s
|
||||
|
||||
#includes common to all targets
|
||||
INC_PATHS += components/drivers_nrf/gpiote
|
||||
INC_PATHS += components/drivers_nrf/hal
|
||||
INC_PATHS += components/drivers_nrf/config
|
||||
INC_PATHS += components/drivers_nrf/delay
|
||||
INC_PATHS += components/drivers_nrf/uart
|
||||
INC_PATHS += components/drivers_nrf/common
|
||||
INC_PATHS += components/drivers_nrf/rtc
|
||||
INC_PATHS += components/drivers_nrf/wdt
|
||||
INC_PATHS += components/drivers_nrf/rng
|
||||
INC_PATHS += components/drivers_nrf/clock
|
||||
INC_PATHS += components/drivers_nrf/timer
|
||||
INC_PATHS += components/libraries/util
|
||||
INC_PATHS += components/libraries/timer
|
||||
INC_PATHS += components/device
|
||||
INC_PATHS += components/toolchain/gcc
|
||||
INC_PATHS += components/toolchain
|
||||
INC_PATHS += examples/bsp
|
||||
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
INC_PATHS += components/softdevice/s1xx_iot/headers
|
||||
INC_PATHS += components/softdevice/s1xx_iot/headers/nrf52
|
||||
INC_PATHS += components/softdevice/common/softdevice_handler
|
||||
INC_PATHS += components/ble/common
|
||||
INC_PATHS += components/iot/common
|
||||
INC_PATHS += components/iot/ble_ipsp
|
||||
else
|
||||
INC_PATHS += components/drivers_nrf/nrf_soc_nosd
|
||||
INC_PATHS += components/libraries/fifo
|
||||
endif
|
||||
|
||||
EXTERNALDIRS += $(addprefix $(NRF52_SDK_ROOT)/, $(INC_PATHS))
|
||||
|
||||
# Sorting removes duplicates
|
||||
BUILD_DIRECTORIES := $(sort $(OUTPUT_BINARY_DIRECTORY) $(LISTING_DIRECTORY))
|
||||
|
||||
# Clean files and directories
|
||||
CLEAN += bin_$(TARGET) lst_$(TARGET) nrf52832.a *.elf *.hex
|
||||
|
||||
#flags common to all targets
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
CFLAGS += -DSOFTDEVICE_PRESENT
|
||||
CFLAGS += -DS132
|
||||
endif
|
||||
|
||||
ifeq ($(SMALL),1)
|
||||
CFLAGS += -Os
|
||||
else
|
||||
CFLAGS += -O2
|
||||
endif
|
||||
|
||||
CFLAGS += -DNRF52
|
||||
CFLAGS += -DBOARD_$(shell echo $(NRF52_DK_REVISION) | tr a-z A-Z)
|
||||
CFLAGS += -D__HEAP_SIZE=512
|
||||
CFLAGS += -DSWI_DISABLE0
|
||||
CFLAGS += -DCONFIG_GPIO_AS_PINRESET
|
||||
CFLAGS += -DBLE_STACK_SUPPORT_REQD
|
||||
CFLAGS += -mcpu=cortex-m4
|
||||
CFLAGS += -mthumb -mabi=aapcs --std=gnu99
|
||||
CFLAGS += -Wall -Werror
|
||||
CFLAGS += -ggdb
|
||||
CFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
||||
# keep every function in separate section. This will allow linker to dump unused functions
|
||||
CFLAGS += -ffunction-sections -fdata-sections -fno-strict-aliasing
|
||||
CFLAGS += -fno-builtin --short-enums
|
||||
|
||||
# keep every function in separate section. This will allow linker to dump unused functions
|
||||
LDFLAGS += -Xlinker -Map=$(LISTING_DIRECTORY)/$(OUTPUT_FILENAME).map
|
||||
LDFLAGS += -mthumb -mabi=aapcs -L $(TEMPLATE_PATH) -T$(LINKER_SCRIPT)
|
||||
LDFLAGS += -mcpu=cortex-m4
|
||||
LDFLAGS += -mfloat-abi=hard -mfpu=fpv4-sp-d16
|
||||
# let linker to dump unused sections
|
||||
LDFLAGS += -Wl,--gc-sections
|
||||
# use newlib in nano version
|
||||
LDFLAGS += --specs=nano.specs -lc -lnosys
|
||||
|
||||
# Assembler flags
|
||||
ifneq ($(NRF52_WITHOUT_SOFTDEVICE),1)
|
||||
ASMFLAGS += -DSOFTDEVICE_PRESENT
|
||||
ASMFLAGS += -DS132
|
||||
endif
|
||||
ASMFLAGS += -x assembler-with-cpp
|
||||
ASMFLAGS += -DSWI_DISABLE0
|
||||
ASMFLAGS += -DNRF52
|
||||
ASMFLAGS += -DBOARD_$(shell echo $(NRF52_DK_REVISION) | tr a-z A-Z)
|
||||
ASMFLAGS += -DCONFIG_GPIO_AS_PINRESET
|
||||
ASMFLAGS += -DBLE_STACK_SUPPORT_REQD
|
||||
|
||||
C_SOURCE_FILE_NAMES = $(notdir $(C_SOURCE_FILES))
|
||||
C_PATHS = $(call remduplicates, $(dir $(C_SOURCE_FILES) ) )
|
||||
C_OBJECTS = $(addprefix $(OBJECT_DIRECTORY)/, $(C_SOURCE_FILE_NAMES:.c=.o) )
|
||||
|
||||
ASM_SOURCE_FILE_NAMES = $(notdir $(ASM_SOURCE_FILES))
|
||||
ASM_PATHS = $(call remduplicates, $(dir $(ASM_SOURCE_FILES) ))
|
||||
ASM_OBJECTS = $(addprefix $(OBJECT_DIRECTORY)/, $(ASM_SOURCE_FILE_NAMES:.s=.o) )
|
||||
|
||||
vpath %.c $(C_PATHS)
|
||||
vpath %.s $(ASM_PATHS)
|
||||
|
||||
OBJECTS = $(C_OBJECTS) $(ASM_OBJECTS)
|
||||
|
||||
TARGET_LIBS= nrf52832.a $(NRF52_SDK_ROOT)/components/iot/ble_6lowpan/lib/ble_6lowpan.a
|
||||
|
||||
### Don't treat the .elf as intermediate
|
||||
.PRECIOUS: %.hex %.bin
|
||||
|
||||
nrf52832.a: $(OBJECTS)
|
||||
$(TRACE_AR)
|
||||
$(Q)$(AR) $(AROPTS) $@ $^
|
||||
|
||||
### Compilation rules
|
||||
CUSTOM_RULE_LINK=1
|
||||
|
||||
%.elf: $(TARGET_STARTFILES) %.co $(PROJECT_OBJECTFILES) $(PROJECT_LIBRARIES) contiki-$(TARGET).a $(TARGET_LIBS)
|
||||
$(TRACE_LD)
|
||||
$(Q)$(CC) $(LDFLAGS) ${filter %o %.co %.a,$^} -o $@
|
||||
|
||||
# Assemble files
|
||||
$(OBJECT_DIRECTORY)/%.o: %.s
|
||||
@echo Compiling file: $(notdir $<)
|
||||
$(Q)$(CC) $(ASMFLAGS) $(addprefix -I$(NRF52_SDK_ROOT)/, $(INC_PATHS)) -c -o $@ $<
|
||||
|
||||
# Create binary file from the .out file
|
||||
%.bin: %.elf
|
||||
@echo Preparing: $@
|
||||
$(Q)$(OBJCOPY) -O binary $^ $@
|
||||
|
||||
# Create binary .hex file from the .out file
|
||||
%.hex: %.elf
|
||||
@echo Preparing: $@
|
||||
$(Q)$(OBJCOPY) -O ihex $^ $@
|
||||
|
||||
### We don't really need the .hex and .bin for the .$(TARGET) but let's make
|
||||
### sure they get built
|
||||
%.$(TARGET): %.elf %.hex %.bin
|
||||
cp $*.elf $@
|
||||
$(Q)$(SIZE) $@
|
||||
|
||||
%.jlink:
|
||||
sed -e 's/#OUTPUT_FILENAME#/$*.hex/' $(CONTIKI_CPU)/flash.jlink > $@
|
||||
|
||||
%.flash: %.hex %.jlink
|
||||
@echo Flashing: $^
|
||||
$(JLINK) $(JLINK_OPTS) -CommanderScript $*.jlink
|
||||
|
||||
softdevice.jlink:
|
||||
sed -e 's,#OUTPUT_FILENAME#,$(NRF52_SOFTDEVICE),' $(CONTIKI_CPU)/flash.jlink > $@
|
||||
|
||||
softdevice.flash: softdevice.jlink
|
||||
@echo Flashing: $(notdir $(NRF52_SOFTDEVICE))
|
||||
$(JLINK) $(JLINK_OPTS) -CommanderScript $^
|
||||
|
||||
erase:
|
||||
$(JLINK) $(JLINK_OPTS) -CommanderScript $(CONTIKI_CPU)/erase.jlink
|
||||
|
||||
.PHONY: softdevice.jlink
|
Loading…
Add table
Add a link
Reference in a new issue