2016-08-15 22:41:07 +02:00
|
|
|
# Define the CPU family so we can differentiate between them in the code
|
2019-08-29 17:41:49 +02:00
|
|
|
CFLAGS += -DCPU_FAM_$(call uppercase_and_underscore,$(CPU_FAM))
|
2016-02-08 18:22:11 +01:00
|
|
|
|
2020-02-06 19:52:05 +01:00
|
|
|
# Generate ASF compatible model definition
|
|
|
|
CFLAGS += -D__$(call uppercase_and_underscore,$(CPU_MODEL))__
|
|
|
|
|
2020-03-10 12:15:35 +01:00
|
|
|
# Compute CPU_LINE
|
|
|
|
LINE := $(shell echo $(CPU_MODEL) | sed -E -e 's/^sam([a-z][0-9][0-9])(.)([0-9][0-9])(.)/\1 \2 \3 \4/')
|
|
|
|
FAMILY := $(word 1, $(LINE))
|
|
|
|
TYPE1 := $(word 2, $(LINE))
|
|
|
|
MEMORY := $(word 3, $(LINE))
|
|
|
|
TYPE2 := $(word 4, $(LINE))
|
|
|
|
|
|
|
|
# ROM length is directly encoded in the part number
|
|
|
|
ROM_LEN := $(shell echo $$((1 << $(MEMORY))))
|
|
|
|
|
|
|
|
# get vendor file to extract RAM length
|
|
|
|
VENDOR_FILE := $(shell find $(RIOTCPU)/sam0_common/include/vendor/sam$(FAMILY) -name $(CPU_MODEL).h | grep include.*/sam)
|
|
|
|
RAM_LEN := $(shell sed -E -n 's/\#define (HMCRAMC0_SIZE|HSRAM_SIZE).*(0x[[:xdigit:]]*).*/\2/p' $(VENDOR_FILE))
|
2017-10-13 18:45:35 +02:00
|
|
|
|
|
|
|
ROM_START_ADDR ?= 0x00000000
|
|
|
|
RAM_START_ADDR ?= 0x20000000
|
|
|
|
|
2016-02-08 18:22:11 +01:00
|
|
|
# this CPU implementation doesn't use CMSIS initialization
|
2019-08-27 16:06:41 +02:00
|
|
|
CFLAGS += -DDONT_USE_CMSIS_INIT
|
|
|
|
CFLAGS += -DDONT_USE_PREDEFINED_CORE_HANDLERS
|
|
|
|
CFLAGS += -DDONT_USE_PREDEFINED_PERIPHERALS_HANDLERS
|
2016-02-08 18:22:11 +01:00
|
|
|
|
2017-10-13 18:45:35 +02:00
|
|
|
# For Cortex-M cpu we use the common cortexm.ld linker script
|
|
|
|
LINKER_SCRIPT ?= cortexm.ld
|
2016-12-15 11:39:19 +01:00
|
|
|
|
2019-08-27 16:06:41 +02:00
|
|
|
INCLUDES += -I$(RIOTCPU)/sam0_common/include
|